@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.
- package/esm2020/lib/common/data/data-context/data-context-builder.mjs +4 -3
- package/esm2020/lib/common/enums/elder-enum-translation.service.mjs +4 -4
- package/esm2020/lib/common/forms/form-field-base.component.mjs +4 -4
- package/esm2020/lib/common/forms/multi-model-base.component.mjs +4 -4
- package/esm2020/lib/common/forms/template-composite-control.mjs +4 -4
- package/esm2020/lib/common/forms/value-accessor-base.mjs +4 -4
- package/esm2020/lib/common/http/http-client-builder.service.mjs +4 -4
- package/esm2020/lib/common/http/http-client-pristine.mjs +4 -4
- package/esm2020/lib/common/http/transfer/data-transfer-factory.mjs +4 -4
- package/esm2020/lib/common/templates/template-slot-manager.mjs +34 -6
- package/esm2020/lib/common/url/elder-url-fragment-params.service.mjs +4 -4
- package/esm2020/lib/common/utils/filter-util.mjs +11 -2
- package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +4 -4
- package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +5 -5
- package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +4 -4
- package/esm2020/lib/components/auditing/elder-audit.module.mjs +5 -5
- package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +4 -4
- package/esm2020/lib/components/button-group/elder-button-group.module.mjs +5 -5
- package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +4 -4
- package/esm2020/lib/components/card-organizer/card-organizer/elder-stack-card.directive.mjs +4 -4
- 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 +5 -5
- package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +4 -4
- package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +19 -19
- package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +5 -5
- package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +5 -5
- package/esm2020/lib/components/connectivity/elder-connectivity.service.mjs +4 -4
- package/esm2020/lib/components/connectivity/offline-indicator/elder-offline-indicator.component.mjs +4 -4
- package/esm2020/lib/components/containers/elder-containers.module.mjs +5 -5
- package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +4 -4
- package/esm2020/lib/components/csv/elder-csv-export-btn/elder-csv-export-btn.component.mjs +4 -4
- package/esm2020/lib/components/csv/elder-csv-stream-exporter-builder.service.mjs +4 -4
- package/esm2020/lib/components/csv/elder-csv.module.mjs +5 -5
- package/esm2020/lib/components/currency/elder-currency.module.mjs +5 -5
- package/esm2020/lib/components/currency/elder-currency.pipe.mjs +4 -4
- package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +5 -5
- package/esm2020/lib/components/data-transfer/elder-data-transfer.service.mjs +4 -4
- package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +4 -4
- package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +4 -4
- package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +4 -4
- package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +4 -4
- package/esm2020/lib/components/data-view/base/elder-data-view-base.mjs +4 -4
- package/esm2020/lib/components/data-view/base/elder-data-view-base.module.mjs +5 -5
- package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +4 -4
- package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +5 -5
- package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +7 -7
- package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +4 -4
- package/esm2020/lib/components/data-view/common/selection/data-context-selection.directive.mjs +4 -4
- package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +4 -4
- package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +11 -11
- package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +5 -5
- package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.component.mjs +4 -4
- package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +5 -5
- package/esm2020/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +4 -4
- package/esm2020/lib/components/data-view/table/elder-number-cell.directive.mjs +4 -4
- package/esm2020/lib/components/data-view/table/elder-paginator-intl.mjs +4 -4
- package/esm2020/lib/components/data-view/table/elder-table/elder-table-toolbar.directive.mjs +4 -4
- 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 +4 -4
- package/esm2020/lib/components/data-view/table/elder-table-extension.directive.mjs +4 -4
- package/esm2020/lib/components/data-view/table/elder-table-root.directive.mjs +4 -4
- package/esm2020/lib/components/data-view/table/elder-table-row.directive.mjs +4 -4
- package/esm2020/lib/components/data-view/table/elder-table-sort.directive.mjs +4 -4
- package/esm2020/lib/components/data-view/table/elder-table.module.mjs +5 -5
- package/esm2020/lib/components/data-view/table/model/elder-table-model.mjs +4 -4
- package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +4 -4
- package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +8 -8
- package/esm2020/lib/components/dialogs/elder-dialog.service.mjs +4 -4
- package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +4 -4
- package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +4 -4
- package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog.directive.mjs +4 -4
- package/esm2020/lib/components/errors/elder-error.module.mjs +5 -5
- package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +4 -4
- package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +4 -4
- package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +5 -5
- package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +4 -4
- package/esm2020/lib/components/files/elder-file-drop-zone.directive.mjs +4 -4
- package/esm2020/lib/components/files/elder-file-select.directive.mjs +4 -4
- package/esm2020/lib/components/files/elder-file.module.mjs +5 -5
- package/esm2020/lib/components/files/file-select/file-select.component.mjs +4 -4
- package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +4 -4
- package/esm2020/lib/components/forms/clipboard/elder-clipboard.service.mjs +4 -4
- package/esm2020/lib/components/forms/directives/base/elder-class-hostbinding-base.mjs +34 -0
- package/esm2020/lib/components/forms/directives/elder-clipboard-put.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-delayed-focus.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-form-field-dense.directive.mjs +10 -25
- package/esm2020/lib/components/forms/directives/elder-form-field-label.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-form-field-no-hint.directive.mjs +34 -0
- package/esm2020/lib/components/forms/directives/elder-form-field-no-spinner.directive.mjs +11 -32
- package/esm2020/lib/components/forms/directives/elder-forms-directives.module.mjs +24 -18
- package/esm2020/lib/components/forms/directives/elder-key-event.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-max.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-min.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-next-focusable.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-plug-parent-form.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-stop-event-propagation.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-tab-focus-trap.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-touched.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +4 -4
- package/esm2020/lib/components/forms/directives/validation/elder-multiple-of.validator.mjs +4 -4
- package/esm2020/lib/components/forms/directives/validation/elder-required-ignore-zero.validator.mjs +4 -4
- package/esm2020/lib/components/forms/elder-forms.module.mjs +5 -5
- package/esm2020/lib/components/forms/search/elder-search-context.directive.mjs +4 -4
- package/esm2020/lib/components/forms/search/elder-search-input.directive.mjs +4 -4
- package/esm2020/lib/components/forms/search/elder-search.module.mjs +5 -5
- package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +4 -4
- package/esm2020/lib/components/forms/search/search-box/elder-search-panel.component.mjs +4 -4
- package/esm2020/lib/components/global-search/elder-global-search.component.mjs +4 -4
- package/esm2020/lib/components/global-search/elder-global-search.module.mjs +5 -5
- package/esm2020/lib/components/global-search/elder-global-search.service.mjs +4 -4
- package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +4 -4
- package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +5 -5
- package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +4 -4
- package/esm2020/lib/components/headers/elder-header.module.mjs +5 -5
- package/esm2020/lib/components/http-support/elder-http-client.service.mjs +4 -4
- package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +5 -5
- package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +4 -4
- package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +4 -4
- package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog.service.mjs +4 -4
- package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +4 -4
- package/esm2020/lib/components/i18n/entities/elder-localized-text-column.directive.mjs +4 -4
- package/esm2020/lib/components/i18n/entities/elder-localized-texts.directive.mjs +4 -4
- package/esm2020/lib/components/i18n/entities/picker/i18n-pick-async.pipe.mjs +4 -4
- package/esm2020/lib/components/i18n/entities/picker/i18n-pick.pipe.mjs +4 -4
- package/esm2020/lib/components/i18n/entities/picker/localisation-picker.service.mjs +4 -4
- package/esm2020/lib/components/i18n/language/elder-language-interceptor.mjs +4 -4
- package/esm2020/lib/components/i18n/language/elder-language.module.mjs +5 -5
- package/esm2020/lib/components/i18n/language/elder-language.service.mjs +4 -4
- package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +4 -4
- package/esm2020/lib/components/i18n/locales/elder-locales-de-ch.module.mjs +5 -5
- package/esm2020/lib/components/iframes/elder-iframe.module.mjs +5 -5
- package/esm2020/lib/components/iframes/iframe-close.directive.mjs +4 -4
- package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +4 -4
- package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +4 -4
- package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +4 -4
- package/esm2020/lib/components/iframes/iframe.service.mjs +4 -4
- package/esm2020/lib/components/infinitescroll/elder-infinite-autocomplete.directive.mjs +4 -4
- package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.directive.mjs +4 -4
- package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.module.mjs +8 -8
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +4 -4
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +4 -4
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +5 -5
- package/esm2020/lib/components/labels/elder-labels.module.mjs +5 -5
- package/esm2020/lib/components/labels/labels-input/labels-input.component.mjs +4 -4
- package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +4 -4
- package/esm2020/lib/components/measures/directives/elder-unit-select.directive.mjs +4 -4
- package/esm2020/lib/components/measures/elder-measures.module.mjs +9 -9
- package/esm2020/lib/components/measures/elder-quantity-transform.pipe.mjs +4 -4
- package/esm2020/lib/components/measures/elder-quantity.pipe.mjs +4 -4
- package/esm2020/lib/components/measures/elder-unit.service.mjs +4 -4
- package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +4 -4
- package/esm2020/lib/components/measures/util/elder-quantity.service.mjs +4 -4
- package/esm2020/lib/components/multi-autocomplete/elder-multi-auto-complete.module.mjs +5 -5
- package/esm2020/lib/components/multi-autocomplete/elder-multi-autocomplete.component.mjs +4 -4
- package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +4 -4
- package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +5 -5
- package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +5 -5
- package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +4 -4
- package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +4 -4
- package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +4 -4
- package/esm2020/lib/components/navigation/toolbar/elder-toolbar-column.directive.mjs +4 -4
- package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +5 -5
- package/esm2020/lib/components/navigation/toolbar/elder-toolbar.service.mjs +8 -6
- package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +19 -15
- package/esm2020/lib/components/navigation/toolbar/toolbar-column-position.mjs +1 -1
- package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.component.mjs +4 -4
- package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.service.mjs +4 -4
- package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +4 -4
- package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +4 -4
- package/esm2020/lib/components/overlays/elder-overlay.component.mjs +4 -4
- package/esm2020/lib/components/overlays/elder-overlay.module.mjs +5 -5
- package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +4 -4
- package/esm2020/lib/components/panels/elder-panel.module.mjs +5 -5
- package/esm2020/lib/components/panels/flat/elder-panel.component.mjs +4 -4
- package/esm2020/lib/components/select/auto/elder-auto-select-first.directive.mjs +4 -4
- package/esm2020/lib/components/select/elder-select/elder-select.component.mjs +17 -15
- package/esm2020/lib/components/select/elder-select-base.mjs +21 -6
- package/esm2020/lib/components/select/elder-select-chip.directive.mjs +4 -4
- package/esm2020/lib/components/select/elder-select-on-tab.directive.mjs +4 -4
- package/esm2020/lib/components/select/elder-select-value.directive.mjs +4 -4
- package/esm2020/lib/components/select/elder-select.module.mjs +9 -8
- package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +30 -5
- package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +18 -24
- package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +7 -5
- package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +4 -4
- package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +4 -4
- package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +5 -5
- package/esm2020/lib/components/select-list/elder-select-list.module.mjs +5 -5
- package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +4 -4
- package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +4 -4
- package/esm2020/lib/components/shell/drawers/elder-route-outlet-drawer.service.mjs +4 -4
- package/esm2020/lib/components/shell/drawers/elder-router-outlet.service.mjs +4 -4
- package/esm2020/lib/components/shell/elder-shell-slot.directive.mjs +4 -4
- package/esm2020/lib/components/shell/elder-shell.module.mjs +5 -5
- package/esm2020/lib/components/shell/elder-shell.service.mjs +4 -4
- package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +4 -4
- package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +13 -13
- package/esm2020/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.mjs +4 -4
- package/esm2020/lib/components/tabs/elder-tab/elder-tab.directive.mjs +4 -4
- package/esm2020/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.mjs +4 -4
- package/esm2020/lib/components/tabs/elder-tab.module.mjs +5 -5
- package/esm2020/lib/components/time/date-adapters/custom-date-adapter.mjs +4 -4
- package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +4 -4
- package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +4 -4
- package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +4 -4
- package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +4 -4
- package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +4 -4
- package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +4 -4
- package/esm2020/lib/components/time/elder-time.module.mjs +9 -9
- package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +4 -4
- package/esm2020/lib/components/toasts/elder-toast.module.mjs +5 -5
- package/esm2020/lib/components/toasts/elder-toast.service.mjs +10 -10
- package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +4 -4
- package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +5 -5
- package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +4 -4
- package/esm2020/lib/components/viewers/elder-svg-viewer/elder-svg-viewer.component.mjs +4 -4
- package/esm2020/lib/components/viewers/elder-viewers.module.mjs +5 -5
- package/esm2020/lib/features/event-source/elder-event-source.service.mjs +4 -4
- package/esm2020/lib/features/kafent/access-token-provider.mjs +4 -4
- package/esm2020/lib/features/kafent/kafent-config.mjs +4 -4
- package/esm2020/lib/features/kafent/kafent-event-stream.mjs +4 -4
- package/esm2020/lib/features/kafent/kafent-event.service.mjs +4 -4
- package/esm2020/lib/features/kafent/kafent-live-event-request.mjs +1 -1
- package/esm2020/lib/features/kafent/kafent.module.mjs +5 -5
- package/esm2020/lib/features/kafent/sse/kafent-event-stream-sse.service.mjs +4 -4
- package/esm2020/lib/pipes/bytes.pipe.mjs +4 -4
- package/esm2020/lib/pipes/elder-pipes.module.mjs +12 -10
- package/esm2020/lib/pipes/elder-repeat.pipe.mjs +4 -4
- package/esm2020/lib/pipes/elder-round.pipe.mjs +4 -4
- package/esm2020/lib/pipes/elder-safe-url.pipe.mjs +4 -4
- package/esm2020/lib/pipes/elder-trim.pipe.mjs +40 -0
- package/esm2020/lib/pipes/iso-duration.pipe.mjs +4 -4
- package/esm2020/lib/pipes/iso-interval-parse.pipe.mjs +4 -4
- package/esm2020/lib/pipes/iso-interval.pipe.mjs +4 -4
- package/esm2020/lib/pipes/time-ago.pipe.mjs +4 -4
- package/esm2020/lib/pipes/time-duration.pipe.mjs +4 -4
- package/esm2020/lib/pipes/weight.pipe.mjs +4 -4
- package/fesm2015/elderbyte-ngx-starter.mjs +1086 -943
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +1085 -943
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/common/templates/template-slot-manager.d.ts +13 -1
- package/lib/components/forms/directives/base/elder-class-hostbinding-base.d.ts +32 -0
- package/lib/components/forms/directives/elder-form-field-dense.directive.d.ts +3 -17
- package/lib/components/forms/directives/elder-form-field-no-hint.directive.d.ts +19 -0
- package/lib/components/forms/directives/elder-form-field-no-spinner.directive.d.ts +3 -17
- package/lib/components/forms/directives/elder-forms-directives.module.d.ts +5 -3
- package/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.d.ts +13 -10
- package/lib/components/navigation/toolbar/toolbar-column-position.d.ts +9 -1
- package/lib/components/select/elder-select-base.d.ts +10 -2
- package/lib/components/select/elder-select.module.d.ts +2 -1
- package/lib/components/select/multi/elder-multi-select-base.d.ts +9 -0
- package/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.d.ts +0 -3
- package/lib/components/select/popup/selection-model-popup.directive.d.ts +2 -1
- package/lib/components/shell/shell/elder-shell.component.d.ts +3 -2
- package/lib/pipes/elder-pipes.module.d.ts +4 -2
- package/lib/pipes/elder-trim.pipe.d.ts +17 -0
- package/package.json +1 -1
- package/src/lib/components/select/elder-select/elder-select.component.scss +4 -0
- package/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.scss +4 -0
- package/theming/_elder-common.scss +13 -8
|
@@ -10,12 +10,17 @@ import * as i1 from "@angular/material/form-field";
|
|
|
10
10
|
import * as i2 from "@angular/material/icon";
|
|
11
11
|
import * as i3 from "@angular/material/chips";
|
|
12
12
|
import * as i4 from "../../../input/autocomplete/elder-autocomplete/elder-autocomplete.component";
|
|
13
|
-
import * as i5 from "@angular/
|
|
14
|
-
import * as i6 from "@angular/
|
|
15
|
-
import * as i7 from "
|
|
16
|
-
import * as i8 from "
|
|
17
|
-
import * as i9 from "
|
|
18
|
-
import * as i10 from "@
|
|
13
|
+
import * as i5 from "@angular/material/button";
|
|
14
|
+
import * as i6 from "@angular/common";
|
|
15
|
+
import * as i7 from "../../../forms/directives/elder-form-field-dense.directive";
|
|
16
|
+
import * as i8 from "../../../forms/directives/elder-form-field-no-hint.directive";
|
|
17
|
+
import * as i9 from "@angular/flex-layout/flex";
|
|
18
|
+
import * as i10 from "@angular/material/input";
|
|
19
|
+
import * as i11 from "@angular/material/autocomplete";
|
|
20
|
+
import * as i12 from "../../../input/autocomplete/elder-autocomplete.directive";
|
|
21
|
+
import * as i13 from "../../../forms/directives/elder-stop-event-propagation.directive";
|
|
22
|
+
import * as i14 from "@ngx-translate/core";
|
|
23
|
+
import * as i15 from "../../../../pipes/elder-trim.pipe";
|
|
19
24
|
class SelectChip {
|
|
20
25
|
constructor(value, displayText, color, removeable) {
|
|
21
26
|
this.value = value;
|
|
@@ -41,6 +46,7 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
|
|
|
41
46
|
this.chipColorResolver$ = new BehaviorSubject((value) => undefined);
|
|
42
47
|
this.selectable = true;
|
|
43
48
|
this.allowRemove = true;
|
|
49
|
+
this.placeholder = '...';
|
|
44
50
|
this.selectChips$ = combineLatest([
|
|
45
51
|
this.entities$,
|
|
46
52
|
this.displayPropertyResolver$,
|
|
@@ -112,21 +118,9 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
|
|
|
112
118
|
onOptionSelected(selectedValue) {
|
|
113
119
|
if (selectedValue) {
|
|
114
120
|
this.resetInput();
|
|
115
|
-
this.
|
|
121
|
+
this.appendEntity(selectedValue);
|
|
116
122
|
}
|
|
117
123
|
}
|
|
118
|
-
addLabels(labels) {
|
|
119
|
-
const current = this.entities ? this.entities : [];
|
|
120
|
-
this.updateValueByEntities([...current, ...labels]);
|
|
121
|
-
}
|
|
122
|
-
addLabel(label) {
|
|
123
|
-
this.addLabels([label]);
|
|
124
|
-
}
|
|
125
|
-
removeLabel(toRemove) {
|
|
126
|
-
const remaining = this.entities
|
|
127
|
-
.filter(l => !this.isEqual(l, toRemove));
|
|
128
|
-
this.updateValueByEntities(remaining);
|
|
129
|
-
}
|
|
130
124
|
/***************************************************************************
|
|
131
125
|
* *
|
|
132
126
|
* Private methods *
|
|
@@ -149,11 +143,11 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
|
|
|
149
143
|
}
|
|
150
144
|
}
|
|
151
145
|
}
|
|
152
|
-
ElderMultiSelectChipsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
153
|
-
ElderMultiSelectChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.
|
|
154
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
146
|
+
ElderMultiSelectChipsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderMultiSelectChipsComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
147
|
+
ElderMultiSelectChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.10", type: ElderMultiSelectChipsComponent, selector: "elder-multi-select-chips", inputs: { allowRemove: "allowRemove", chipTemplate: "chipTemplate", chipColorResolver: "chipColorResolver" }, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), queries: [{ propertyName: "chipTemplateQuery", first: true, predicate: ElderSelectChipDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "inputControl", first: true, predicate: ["chipInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\n [elderDense]=\"dense\"\n [elderNoHint]=\"noHint\"\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n <mat-icon *ngIf=\"icon\" disabled\n class=\"leading-icon prefix-padding noselect\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\">\n {{icon}}\n </mat-icon>\n\n\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"leading-icon prefix-padding noselect\"\n color=\"warn\">\n warning\n </mat-icon>\n </ng-container>\n\n <!-- A dynamic input -->\n\n <mat-chip-list selectable #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [color]=\"chipModel.color\" selectable selected\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeEntity(chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <input matInput type=\"text\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [name]=\"name + '-multi-chips-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matChipInputFor]=\"chips\"\n [matAutocomplete]\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n autocomplete=\"off\"\n #chipInput>\n\n </mat-chip-list>\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n <button matSuffix mat-icon-button type=\"button\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>add</mat-icon>\n </button>\n\n\n <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n {{chipModel.displayText | elderTrim:20}}\n</ng-template>\n\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.clickable-chip{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.MatChipList, selector: "mat-chip-list", inputs: ["errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { type: i4.ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: ["isOptionDisabledFn", "isOptionHiddenFn", "enabled", "valueTemplate", "suggestionsDc", "displayPropertyResolver"], outputs: ["optionSelected"], exportAs: ["elderAutocomplete"] }, { type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.ElderFormFieldDenseDirective, selector: "mat-form-field[elderDense]", inputs: ["elderDense"] }, { type: i8.ElderFormFieldNoHintDirective, selector: "mat-form-field[elderNoHint]", inputs: ["elderNoHint"] }, { type: i9.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: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.MatChipRemove, selector: "[matChipRemove]" }, { type: i10.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: i3.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { type: i11.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i12.ElderAutocompleteDirective, selector: "[elderElderAutocomplete]", inputs: ["queryFilter", "filters", "sorts", "elderElderAutocomplete"] }, { type: i1.MatSuffix, selector: "[matSuffix]" }, { type: i13.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { type: i1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }], pipes: { "async": i6.AsyncPipe, "translate": i14.TranslatePipe, "elderTrim": i15.ElderTrimPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
148
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderMultiSelectChipsComponent, decorators: [{
|
|
155
149
|
type: Component,
|
|
156
|
-
args: [{ selector: 'elder-multi-select-chips', changeDetection: ChangeDetectionStrategy.OnPush, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), template: "<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\n>\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\n <mat-chip-list selectable #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect\"\n [color]=\"chipModel.color\" selectable selected\n [removable]=\"chipModel.removeable\"\n (removed)=\"
|
|
150
|
+
args: [{ selector: 'elder-multi-select-chips', changeDetection: ChangeDetectionStrategy.OnPush, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), template: "<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\n [elderDense]=\"dense\"\n [elderNoHint]=\"noHint\"\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n <mat-icon *ngIf=\"icon\" disabled\n class=\"leading-icon prefix-padding noselect\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\">\n {{icon}}\n </mat-icon>\n\n\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"leading-icon prefix-padding noselect\"\n color=\"warn\">\n warning\n </mat-icon>\n </ng-container>\n\n <!-- A dynamic input -->\n\n <mat-chip-list selectable #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [color]=\"chipModel.color\" selectable selected\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeEntity(chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <input matInput type=\"text\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [name]=\"name + '-multi-chips-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matChipInputFor]=\"chips\"\n [matAutocomplete]\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n autocomplete=\"off\"\n #chipInput>\n\n </mat-chip-list>\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n <button matSuffix mat-icon-button type=\"button\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>add</mat-icon>\n </button>\n\n\n <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n {{chipModel.displayText | elderTrim:20}}\n</ng-template>\n\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.clickable-chip{cursor:pointer}\n"] }]
|
|
157
151
|
}], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { allowRemove: [{
|
|
158
152
|
type: Input
|
|
159
153
|
}], inputControl: [{
|
|
@@ -167,4 +161,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
167
161
|
}], chipColorResolver: [{
|
|
168
162
|
type: Input
|
|
169
163
|
}] } });
|
|
170
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-chips.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, NgZone, ViewChild, ElementRef, Input, ContentChild, TemplateRef} from '@angular/core';\nimport {ElderMultiSelectBase} from '../elder-multi-select-base';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {ThemePalette} from '@angular/material/core/common-behaviors/color';\nimport {TextResolverFn} from '../../elder-select-base';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderSelectChipDirective} from '../../elder-select-chip.directive';\nimport {buildFormIntegrationProviders} from '../../../../common/forms/template-composite-control';\n\nclass SelectChip<T> {\n  constructor(\n    public readonly value: T,\n    public readonly displayText: string,\n    public readonly color: ThemePalette,\n    public readonly removeable: boolean\n  ) {\n  }\n}\n\n\n@Component({\n  selector: 'elder-multi-select-chips',\n  templateUrl: './elder-multi-select-chips.component.html',\n  styleUrls: ['./elder-multi-select-chips.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent)\n})\nexport class ElderMultiSelectChipsComponent<TId = any, TEntity = any, TValue = any>\n  extends ElderMultiSelectBase<TId, TEntity, TValue>\n  implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly selectChips$: Observable<SelectChip<TEntity>[]>;\n\n  private readonly chipColorResolver$ = new BehaviorSubject<(o1: any) => ThemePalette>((value: TEntity) => undefined);\n\n\n  public selectable = true;\n\n  @Input()\n  public allowRemove = true;\n\n\n  @ViewChild('chipInput', {static: false})\n  private inputControl: ElementRef<HTMLInputElement>;\n\n  @ContentChild(ElderSelectChipDirective, {read: TemplateRef, static: true})\n  public chipTemplateQuery: TemplateRef<any>;\n  private _chipTemplate: TemplateRef<any>;\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    zone: NgZone\n  ) {\n    super(zone);\n    this.selectChips$ = combineLatest(\n      [\n        this.entities$,\n        this.displayPropertyResolver$,\n        this.chipColorResolver$\n      ]\n    ).pipe(\n      map(([values, dPR, cCR]) => {\n        if (values) {\n          return values.map(\n            v => new SelectChip<TEntity>(\n              v,\n              dPR(v),\n              cCR(v),\n              this.allowRemove\n            )\n          );\n        } else {\n          return <SelectChip<TEntity>[]>[];\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set chipTemplate(template: TemplateRef<any>) {\n    this._chipTemplate = template;\n  }\n\n  public get chipTemplate(): TemplateRef<any> {\n    return this._chipTemplate || this.chipTemplateQuery;\n  }\n\n  /**\n   * A function which returns the color of a given label object.\n   */\n  @Input()\n  public set chipColorResolver(fn: (o1: any) => ThemePalette) {\n    if (typeof fn !== 'function') {\n      throw new Error('chipColorResolver must be a function!');\n    }\n    this.chipColorResolver$.next(fn);\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 onOptionSelected(selectedValue: TEntity): void {\n    if (selectedValue) {\n      this.resetInput();\n      this.addLabel(selectedValue);\n    }\n  }\n\n  public addLabels(labels: TEntity[]) {\n    const current = this.entities ? this.entities : [];\n    this.updateValueByEntities([...current, ...labels]);\n  }\n\n  public addLabel(label: any) {\n    this.addLabels([label]);\n  }\n\n  public removeLabel(toRemove: TEntity): void {\n    const remaining = this.entities\n      .filter(l => !this.isEqual(l, toRemove));\n    this.updateValueByEntities(remaining);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\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 resetInput(): void {\n    if (this.inputControl) {\n      this.inputControl.nativeElement.value = '';\n    } else {\n      this.log.error('Failed to reset inputControl since it was not found!');\n    }\n  }\n\n}\n","<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [floatLabel]=\"floatLabel\"\n                [color]=\"color\"\n>\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\n  <mat-chip-list selectable #chips>\n    <mat-chip *ngFor=\"let chipModel of chipValues\"\n              class=\"noselect\"\n              [color]=\"chipModel.color\" selectable selected\n              [removable]=\"chipModel.removeable\"\n              (removed)=\"removeLabel(chipModel.value)\"\n    >\n      <ng-container\n        *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n      </ng-container>\n      <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n    </mat-chip>\n\n    <input matInput type=\"text\"\n           [disabled]=\"disabled\"\n           [required]=\"required\"\n           [readonly]=\"readonly\"\n           [name]=\"name + '-multi-chips-inner-input'\"\n           [placeholder]=\"placeholder | translate\"\n           [matChipInputFor]=\"chips\"\n           [matAutocomplete]\n           [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n           autocomplete=\"off\"\n           #chipInput>\n  </mat-chip-list>\n\n  <elder-autocomplete\n    #elderAuto=\"elderAutocomplete\"\n    [suggestionsDc]=\"suggestionsDc$ | async\"\n    [valueTemplate]=\"valueTemplate\"\n    [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n    [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n    [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n    (optionSelected)=\"onOptionSelected($any($event))\"\n  ></elder-autocomplete>\n\n  <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n  {{chipModel.displayText}}\n</ng-template>\n\n"]}
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-chips.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, NgZone, ViewChild, ElementRef, Input, ContentChild, TemplateRef} from '@angular/core';\nimport {ElderMultiSelectBase} from '../elder-multi-select-base';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {ThemePalette} from '@angular/material/core/common-behaviors/color';\nimport {TextResolverFn} from '../../elder-select-base';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderSelectChipDirective} from '../../elder-select-chip.directive';\nimport {buildFormIntegrationProviders} from '../../../../common/forms/template-composite-control';\n\nclass SelectChip<T> {\n  constructor(\n    public readonly value: T,\n    public readonly displayText: string,\n    public readonly color: ThemePalette,\n    public readonly removeable: boolean\n  ) {\n  }\n}\n\n\n@Component({\n  selector: 'elder-multi-select-chips',\n  templateUrl: './elder-multi-select-chips.component.html',\n  styleUrls: ['./elder-multi-select-chips.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent)\n})\nexport class ElderMultiSelectChipsComponent<TId = any, TEntity = any, TValue = any>\n  extends ElderMultiSelectBase<TId, TEntity, TValue>\n  implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly selectChips$: Observable<SelectChip<TEntity>[]>;\n\n  private readonly chipColorResolver$ = new BehaviorSubject<(o1: any) => ThemePalette>((value: TEntity) => undefined);\n\n\n  public selectable = true;\n\n  @Input()\n  public allowRemove = true;\n\n\n  @ViewChild('chipInput', {static: false})\n  private inputControl: ElementRef<HTMLInputElement>;\n\n  @ContentChild(ElderSelectChipDirective, {read: TemplateRef, static: true})\n  public chipTemplateQuery: TemplateRef<any>;\n  private _chipTemplate: TemplateRef<any>;\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    zone: NgZone\n  ) {\n    super(zone);\n    this.placeholder = '...';\n    this.selectChips$ = combineLatest(\n      [\n        this.entities$,\n        this.displayPropertyResolver$,\n        this.chipColorResolver$\n      ]\n    ).pipe(\n      map(([values, dPR, cCR]) => {\n        if (values) {\n          return values.map(\n            v => new SelectChip<TEntity>(\n              v,\n              dPR(v),\n              cCR(v),\n              this.allowRemove\n            )\n          );\n        } else {\n          return <SelectChip<TEntity>[]>[];\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set chipTemplate(template: TemplateRef<any>) {\n    this._chipTemplate = template;\n  }\n\n  public get chipTemplate(): TemplateRef<any> {\n    return this._chipTemplate || this.chipTemplateQuery;\n  }\n\n  /**\n   * A function which returns the color of a given label object.\n   */\n  @Input()\n  public set chipColorResolver(fn: (o1: any) => ThemePalette) {\n    if (typeof fn !== 'function') {\n      throw new Error('chipColorResolver must be a function!');\n    }\n    this.chipColorResolver$.next(fn);\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 onOptionSelected(selectedValue: TEntity): void {\n    if (selectedValue) {\n      this.resetInput();\n      this.appendEntity(selectedValue);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\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 resetInput(): void {\n    if (this.inputControl) {\n      this.inputControl.nativeElement.value = '';\n    } else {\n      this.log.error('Failed to reset inputControl since it was not found!');\n    }\n  }\n\n}\n","<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [floatLabel]=\"floatLabel\"\n                [color]=\"color\"\n                [elderDense]=\"dense\"\n                [elderNoHint]=\"noHint\"\n>\n\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n  <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n    <mat-icon *ngIf=\"icon\" disabled\n              class=\"leading-icon prefix-padding noselect\"\n              [class.loading]=\"state.loading\"\n              [color]=\"state?.error ? 'warn' : color\">\n      {{icon}}\n    </mat-icon>\n\n\n    <mat-icon *ngIf=\"!icon && state?.error\"\n              class=\"leading-icon prefix-padding noselect\"\n              color=\"warn\">\n      warning\n    </mat-icon>\n  </ng-container>\n\n  <!-- A dynamic input -->\n\n  <mat-chip-list selectable #chips>\n    <mat-chip *ngFor=\"let chipModel of chipValues\"\n              class=\"noselect clickable-chip\"\n              [color]=\"chipModel.color\" selectable selected\n              [removable]=\"chipModel.removeable\"\n              (removed)=\"removeEntity(chipModel.value)\"\n              (click)=\"onCurrentClicked(chipModel.value)\"\n    >\n      <ng-container\n        *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n      </ng-container>\n      <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n    </mat-chip>\n\n    <input matInput type=\"text\"\n           [disabled]=\"disabled\"\n           [required]=\"required\"\n           [readonly]=\"readonly\"\n           [name]=\"name + '-multi-chips-inner-input'\"\n           [placeholder]=\"placeholder | translate\"\n           [matChipInputFor]=\"chips\"\n           [matAutocomplete]\n           [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n           autocomplete=\"off\"\n           #chipInput>\n\n  </mat-chip-list>\n\n  <elder-autocomplete\n    #elderAuto=\"elderAutocomplete\"\n    [suggestionsDc]=\"suggestionsDc$ | async\"\n    [valueTemplate]=\"valueTemplate\"\n    [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n    [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n    [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n    (optionSelected)=\"onOptionSelected($any($event))\"\n  ></elder-autocomplete>\n\n  <button matSuffix mat-icon-button type=\"button\"\n          *ngIf=\"selectionPopup\"\n          [disabled]=\"isLocked\"\n          (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n          elderStopEventPropagation\n          tabIndex=\"-1\"\n  >\n    <mat-icon>add</mat-icon>\n  </button>\n\n\n  <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n  {{chipModel.displayText | elderTrim:20}}\n</ng-template>\n\n"]}
|
|
@@ -14,6 +14,7 @@ export class ElderDataViewSelectionMode {
|
|
|
14
14
|
constructor() {
|
|
15
15
|
this.sorts = [];
|
|
16
16
|
this.filters = [];
|
|
17
|
+
this.multi = false;
|
|
17
18
|
}
|
|
18
19
|
}
|
|
19
20
|
export function createSelectionModel() {
|
|
@@ -63,9 +64,10 @@ export class SelectionModelPopupDirective {
|
|
|
63
64
|
/**
|
|
64
65
|
* Let the user choose some entities and return the selection.
|
|
65
66
|
*/
|
|
66
|
-
choose(filters, sorts) {
|
|
67
|
+
choose(filters, sorts, multi = false) {
|
|
67
68
|
this.dataViewSelectionMode.filters = filters || [];
|
|
68
69
|
this.dataViewSelectionMode.sorts = sorts || [];
|
|
70
|
+
this.dataViewSelectionMode.multi = multi;
|
|
69
71
|
const dialogRef = this.openSelectDialog();
|
|
70
72
|
return dialogRef.afterClosed().pipe(switchMap((chosenEntities) => {
|
|
71
73
|
if (chosenEntities) {
|
|
@@ -95,8 +97,8 @@ export class SelectionModelPopupDirective {
|
|
|
95
97
|
});
|
|
96
98
|
}
|
|
97
99
|
}
|
|
98
|
-
SelectionModelPopupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
99
|
-
SelectionModelPopupDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.
|
|
100
|
+
SelectionModelPopupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: SelectionModelPopupDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: i1.MatDialog }, { token: ElderDataViewSelectionMode }], target: i0.ɵɵFactoryTarget.Directive });
|
|
101
|
+
SelectionModelPopupDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.10", type: SelectionModelPopupDirective, selector: "[elderSelectionModelPopup]", inputs: { elderSelectionModelPopupTransform: "elderSelectionModelPopupTransform" }, providers: [
|
|
100
102
|
{
|
|
101
103
|
provide: SelectionModel,
|
|
102
104
|
useFactory: createSelectionModel
|
|
@@ -107,7 +109,7 @@ SelectionModelPopupDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12
|
|
|
107
109
|
},
|
|
108
110
|
ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box
|
|
109
111
|
], ngImport: i0 });
|
|
110
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
112
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: SelectionModelPopupDirective, decorators: [{
|
|
111
113
|
type: Directive,
|
|
112
114
|
args: [{
|
|
113
115
|
selector: '[elderSelectionModelPopup]',
|
|
@@ -127,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
127
129
|
type: Input,
|
|
128
130
|
args: ['elderSelectionModelPopupTransform']
|
|
129
131
|
}] } });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-model-popup.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/popup/selection-model-popup.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Input, OnDestroy, OnInit, TemplateRef, ViewContainerRef} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {MatDialog, MatDialogRef} from '@angular/material/dialog';\nimport {\n  ISelectionModelDialogOptions,\n  TemplatedSelectionDialogComponent\n} from './templated-selection-dialog/templated-selection-dialog.component';\nimport {switchMap} from 'rxjs/operators';\nimport {EMPTY, Observable, of} from 'rxjs';\nimport {SelectionModel} from '../../../common/selection/selection-model';\nimport {Sort} from '../../../common/data/sort';\nimport {Filter} from '../../../common/data/filter';\nimport {ElderTableProviders} from '../../data-view/table/model/elder-table-model-provider';\n\n\n/**\n * Configures the selection mode on supporting components.\n */\nexport class ElderDataViewSelectionMode {\n\n  public sorts: Sort[] = [];\n  public filters: Filter[] = [];\n\n  constructor() { }\n}\n\nexport function createSelectionModel(): SelectionModel<any> {\n  return new SelectionModel<any>();\n}\n\nexport function createDataViewSelection(): ElderDataViewSelectionMode {\n  return new ElderDataViewSelectionMode();\n}\n\n@Directive({\n  selector: '[elderSelectionModelPopup]',\n  providers: [\n    {\n      provide: SelectionModel,\n      useFactory: createSelectionModel\n    },\n    {\n      provide: ElderDataViewSelectionMode,\n      useFactory: createDataViewSelection\n    },\n    ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box\n  ]\n})\nexport class SelectionModelPopupDirective implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private _transformerFn: (o: any) => any;\n\n  @Input('elderSelectionModelPopupTransform')\n  public set elderSelectionModelPopupTransform(fn: (o: any) => any) {\n    this._transformerFn = fn;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly templateRef: TemplateRef<any>,\n    private readonly viewContainer: ViewContainerRef,\n    private readonly dialog: MatDialog,\n    private readonly dataViewSelectionMode: ElderDataViewSelectionMode\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Host Listeners                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void { }\n\n  public ngOnDestroy(): void { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Let the user choose some entities and return the selection.\n   */\n  public choose(filters?: Filter[], sorts?: Sort[]): Observable<any[]> {\n\n    this.dataViewSelectionMode.filters = filters || [];\n    this.dataViewSelectionMode.sorts = sorts || [];\n\n    const dialogRef = this.openSelectDialog();\n\n    return dialogRef.afterClosed().pipe(\n      switchMap((chosenEntities: any[]) => {\n        if (chosenEntities) {\n          return this._transformerFn\n            ? of(chosenEntities.map(value => this._transformerFn(value)))\n            : of(chosenEntities);\n        } else {\n          return EMPTY;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private openSelectDialog(): MatDialogRef<TemplatedSelectionDialogComponent> {\n    return this.dialog.open(\n      TemplatedSelectionDialogComponent,\n      {\n        width: '90vw',\n        height: '90vh',\n        panelClass: 'custom-dialog-container',\n        data: <ISelectionModelDialogOptions> {\n          selectionComponentTemplate: this.templateRef\n        },\n        viewContainerRef: this.viewContainer\n      }\n    );\n  }\n\n}\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-model-popup.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/popup/selection-model-popup.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Input, OnDestroy, OnInit, TemplateRef, ViewContainerRef} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {MatDialog, MatDialogRef} from '@angular/material/dialog';\nimport {\n  ISelectionModelDialogOptions,\n  TemplatedSelectionDialogComponent\n} from './templated-selection-dialog/templated-selection-dialog.component';\nimport {switchMap} from 'rxjs/operators';\nimport {EMPTY, Observable, of} from 'rxjs';\nimport {SelectionModel} from '../../../common/selection/selection-model';\nimport {Sort} from '../../../common/data/sort';\nimport {Filter} from '../../../common/data/filter';\nimport {ElderTableProviders} from '../../data-view/table/model/elder-table-model-provider';\n\n\n/**\n * Configures the selection mode on supporting components.\n */\nexport class ElderDataViewSelectionMode {\n\n  public sorts: Sort[] = [];\n  public filters: Filter[] = [];\n  public multi: boolean = false;\n\n  constructor() { }\n}\n\nexport function createSelectionModel(): SelectionModel<any> {\n  return new SelectionModel<any>();\n}\n\nexport function createDataViewSelection(): ElderDataViewSelectionMode {\n  return new ElderDataViewSelectionMode();\n}\n\n@Directive({\n  selector: '[elderSelectionModelPopup]',\n  providers: [\n    {\n      provide: SelectionModel,\n      useFactory: createSelectionModel\n    },\n    {\n      provide: ElderDataViewSelectionMode,\n      useFactory: createDataViewSelection\n    },\n    ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box\n  ]\n})\nexport class SelectionModelPopupDirective implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private _transformerFn: (o: any) => any;\n\n  @Input('elderSelectionModelPopupTransform')\n  public set elderSelectionModelPopupTransform(fn: (o: any) => any) {\n    this._transformerFn = fn;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly templateRef: TemplateRef<any>,\n    private readonly viewContainer: ViewContainerRef,\n    private readonly dialog: MatDialog,\n    private readonly dataViewSelectionMode: ElderDataViewSelectionMode\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Host Listeners                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void { }\n\n  public ngOnDestroy(): void { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Let the user choose some entities and return the selection.\n   */\n  public choose(\n    filters?: Filter[],\n    sorts?: Sort[],\n    multi = false\n  ): Observable<any[]> {\n\n    this.dataViewSelectionMode.filters = filters || [];\n    this.dataViewSelectionMode.sorts = sorts || [];\n    this.dataViewSelectionMode.multi = multi;\n\n    const dialogRef = this.openSelectDialog();\n\n    return dialogRef.afterClosed().pipe(\n      switchMap((chosenEntities: any[]) => {\n        if (chosenEntities) {\n          return this._transformerFn\n            ? of(chosenEntities.map(value => this._transformerFn(value)))\n            : of(chosenEntities);\n        } else {\n          return EMPTY;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private openSelectDialog(): MatDialogRef<TemplatedSelectionDialogComponent> {\n    return this.dialog.open(\n      TemplatedSelectionDialogComponent,\n      {\n        width: '90vw',\n        height: '90vh',\n        panelClass: 'custom-dialog-container',\n        data: <ISelectionModelDialogOptions> {\n          selectionComponentTemplate: this.templateRef\n        },\n        viewContainerRef: this.viewContainer\n      }\n    );\n  }\n\n}\n"]}
|
|
@@ -35,13 +35,13 @@ export class TemplatedSelectionDialogComponent {
|
|
|
35
35
|
ngOnInit() {
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
|
-
TemplatedSelectionDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
39
|
-
TemplatedSelectionDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.
|
|
40
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
38
|
+
TemplatedSelectionDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: TemplatedSelectionDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i2.SelectionModel }], target: i0.ɵɵFactoryTarget.Component });
|
|
39
|
+
TemplatedSelectionDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.10", type: TemplatedSelectionDialogComponent, selector: "elder-templated-selection-dialog", ngImport: i0, template: "<div fxFill fxLayout=\"column\">\n\n <mat-toolbar color=\"primary\">\n <button mat-icon-button type=\"button\" mat-dialog-close>\n <mat-icon>close</mat-icon>\n </button>\n\n <span fxFlex></span>\n\n <button mat-flat-button type=\"submit\" color=\"accent\"\n *ngIf=\"selectionModel.selection | async as selection\"\n [disabled]=\"!selection || selection.length === 0\"\n [mat-dialog-close]=\"selection\"\n >\n {{'actions.select' | translate}}\n </button>\n\n </mat-toolbar>\n\n <div fxLayout=\"column\" fxFlex>\n <ng-container *ngTemplateOutlet=\"data.selectionComponentTemplate\"></ng-container>\n </div>\n\n <!--\n <div fxLayout=\"row\" fxLayoutAlign=\"end center\" fxLayoutGap=\"12px\">\n\n </div>\n -->\n\n</div>\n", styles: [""], components: [{ type: i3.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { 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"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { type: i6.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { 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: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i7.AsyncPipe, "translate": i8.TranslatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
40
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: TemplatedSelectionDialogComponent, decorators: [{
|
|
41
41
|
type: Component,
|
|
42
42
|
args: [{ selector: 'elder-templated-selection-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div fxFill fxLayout=\"column\">\n\n <mat-toolbar color=\"primary\">\n <button mat-icon-button type=\"button\" mat-dialog-close>\n <mat-icon>close</mat-icon>\n </button>\n\n <span fxFlex></span>\n\n <button mat-flat-button type=\"submit\" color=\"accent\"\n *ngIf=\"selectionModel.selection | async as selection\"\n [disabled]=\"!selection || selection.length === 0\"\n [mat-dialog-close]=\"selection\"\n >\n {{'actions.select' | translate}}\n </button>\n\n </mat-toolbar>\n\n <div fxLayout=\"column\" fxFlex>\n <ng-container *ngTemplateOutlet=\"data.selectionComponentTemplate\"></ng-container>\n </div>\n\n <!--\n <div fxLayout=\"row\" fxLayoutAlign=\"end center\" fxLayoutGap=\"12px\">\n\n </div>\n -->\n\n</div>\n", styles: [""] }]
|
|
43
43
|
}], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
44
44
|
type: Inject,
|
|
45
45
|
args: [MAT_DIALOG_DATA]
|
|
46
46
|
}] }, { type: i2.SelectionModel }]; } });
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGVkLXNlbGVjdGlvbi1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9zZWxlY3QvcG9wdXAvdGVtcGxhdGVkLXNlbGVjdGlvbi1kaWFsb2cvdGVtcGxhdGVkLXNlbGVjdGlvbi1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9zZWxlY3QvcG9wdXAvdGVtcGxhdGVkLXNlbGVjdGlvbi1kaWFsb2cvdGVtcGxhdGVkLXNlbGVjdGlvbi1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBVSx1QkFBdUIsRUFBZSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFOUYsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBQyxlQUFlLEVBQWUsTUFBTSwwQkFBMEIsQ0FBQzs7Ozs7Ozs7OztBQWF2RSxNQUFNLE9BQU8saUNBQWlDO0lBVTVDOzs7O2dGQUk0RTtJQUU1RSxZQUNVLFNBQTBELEVBQ3pCLElBQWtDLEVBQzNELGNBQW1DO1FBRjNDLGNBQVMsR0FBVCxTQUFTLENBQWlEO1FBQ3pCLFNBQUksR0FBSixJQUFJLENBQThCO1FBQzNELG1CQUFjLEdBQWQsY0FBYyxDQUFxQjtRQWpCckQ7Ozs7b0ZBSTRFO1FBRTNELFFBQUcsR0FBRyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7SUFjdEUsQ0FBQztJQUVEOzs7O2dGQUk0RTtJQUVyRSxRQUFRO0lBQ2YsQ0FBQzs7K0hBL0JVLGlDQUFpQyw4Q0FrQmxDLGVBQWU7bUhBbEJkLGlDQUFpQyx3RUNoQjlDLHV4QkE4QkE7NEZEZGEsaUNBQWlDO2tCQU43QyxTQUFTOytCQUNFLGtDQUFrQyxtQkFHM0IsdUJBQXVCLENBQUMsTUFBTTs7MEJBb0I1QyxNQUFNOzJCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgT25Jbml0LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgVGVtcGxhdGVSZWYsIEluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1NlbGVjdGlvbk1vZGVsfSBmcm9tICcuLi8uLi8uLi8uLi9jb21tb24vc2VsZWN0aW9uL3NlbGVjdGlvbi1tb2RlbCc7XG5pbXBvcnQge0xvZ2dlckZhY3Rvcnl9IGZyb20gJ0BlbGRlcmJ5dGUvdHMtbG9nZ2VyJztcbmltcG9ydCB7TUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dSZWZ9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVNlbGVjdGlvbk1vZGVsRGlhbG9nT3B0aW9ucyB7XG4gIHJlYWRvbmx5IHNlbGVjdGlvbkNvbXBvbmVudFRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xufVxuXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VsZGVyLXRlbXBsYXRlZC1zZWxlY3Rpb24tZGlhbG9nJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RlbXBsYXRlZC1zZWxlY3Rpb24tZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vdGVtcGxhdGVkLXNlbGVjdGlvbi1kaWFsb2cuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgVGVtcGxhdGVkU2VsZWN0aW9uRGlhbG9nQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogRmllbGRzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIHJlYWRvbmx5IGxvZyA9IExvZ2dlckZhY3RvcnkuZ2V0TG9nZ2VyKHRoaXMuY29uc3RydWN0b3IubmFtZSk7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIENvbnN0cnVjdG9yICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxUZW1wbGF0ZWRTZWxlY3Rpb25EaWFsb2dDb21wb25lbnQ+LFxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgcmVhZG9ubHkgZGF0YTogSVNlbGVjdGlvbk1vZGVsRGlhbG9nT3B0aW9ucyxcbiAgICBwdWJsaWMgcmVhZG9ubHkgc2VsZWN0aW9uTW9kZWw6IFNlbGVjdGlvbk1vZGVsPGFueT5cbiAgKSB7XG5cbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb21wb25lbnQgRXZlbnRzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHB1YmxpYyBuZ09uSW5pdCgpIHtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQdWJsaWMgQVBJICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG59XG4iLCI8ZGl2IGZ4RmlsbCBmeExheW91dD1cImNvbHVtblwiPlxuXG4gIDxtYXQtdG9vbGJhciBjb2xvcj1cInByaW1hcnlcIj5cbiAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiB0eXBlPVwiYnV0dG9uXCIgbWF0LWRpYWxvZy1jbG9zZT5cbiAgICAgIDxtYXQtaWNvbj5jbG9zZTwvbWF0LWljb24+XG4gICAgPC9idXR0b24+XG5cbiAgICA8c3BhbiBmeEZsZXg+PC9zcGFuPlxuXG4gICAgPGJ1dHRvbiBtYXQtZmxhdC1idXR0b24gdHlwZT1cInN1Ym1pdFwiIGNvbG9yPVwiYWNjZW50XCJcbiAgICAgICAgICAgICpuZ0lmPVwic2VsZWN0aW9uTW9kZWwuc2VsZWN0aW9uIHwgYXN5bmMgYXMgc2VsZWN0aW9uXCJcbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCIhc2VsZWN0aW9uIHx8IHNlbGVjdGlvbi5sZW5ndGggPT09IDBcIlxuICAgICAgICAgICAgW21hdC1kaWFsb2ctY2xvc2VdPVwic2VsZWN0aW9uXCJcbiAgICA+XG4gICAgICB7eydhY3Rpb25zLnNlbGVjdCcgfCB0cmFuc2xhdGV9fVxuICAgIDwvYnV0dG9uPlxuXG4gIDwvbWF0LXRvb2xiYXI+XG5cbiAgPGRpdiBmeExheW91dD1cImNvbHVtblwiIGZ4RmxleD5cbiAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiZGF0YS5zZWxlY3Rpb25Db21wb25lbnRUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxuICA8L2Rpdj5cblxuICA8IS0tXG4gIDxkaXYgZnhMYXlvdXQ9XCJyb3dcIiBmeExheW91dEFsaWduPVwiZW5kIGNlbnRlclwiIGZ4TGF5b3V0R2FwPVwiMTJweFwiPlxuXG4gIDwvZGl2PlxuICAtLT5cblxuPC9kaXY+XG4iXX0=
|
|
@@ -111,14 +111,14 @@ export class ElderChipListSelectComponent {
|
|
|
111
111
|
entity[this.idField] : entity;
|
|
112
112
|
}
|
|
113
113
|
}
|
|
114
|
-
ElderChipListSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
115
|
-
ElderChipListSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.
|
|
114
|
+
ElderChipListSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderChipListSelectComponent, deps: [{ token: i1.SelectionModel, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
115
|
+
ElderChipListSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.10", type: ElderChipListSelectComponent, selector: "elder-chip-list-select", inputs: { data$: "data$", idField: "idField", displayField: "displayField", color: "color", stacked: "stacked", data: "data", selection: "selection", selectionMultiEnabled: "selectionMultiEnabled" }, outputs: { itemClick: "itemClick", selectionChange: "selectionChange", selectionSingleChange: "selectionSingleChange" }, providers: [
|
|
116
116
|
{
|
|
117
117
|
provide: ELDER_DATA_VIEW,
|
|
118
118
|
useExisting: forwardRef(() => ElderChipListSelectComponent)
|
|
119
119
|
}
|
|
120
120
|
], ngImport: i0, template: "\n<div fxLayout=\"column\" fxFill>\n\n <mat-chip-list [ngClass]=\"{'mat-chip-list-stacked' : stacked}\">\n <mat-chip *ngFor=\"let chip of data$ | async\" selected\n [color]=\"isSelected(chip) ? color : 'undefined'\"\n (click)=\"onItemClick(chip)\">\n {{getDisplayText(chip)}}\n </mat-chip>\n </mat-chip-list>\n\n</div>\n\n", styles: [".select-item{padding-left:16px;padding-right:16px;min-height:56px;border-radius:0;font-size:16px;font-weight:400}elder-select-list-item a.select-item-inactive mat-icon{color:#757575}.nested-items-container{overflow:hidden;padding-left:20px}\n"], components: [{ type: i2.MatChipList, selector: "mat-chip-list", inputs: ["errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }], directives: [{ type: i3.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i3.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }], pipes: { "async": i4.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
121
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
121
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderChipListSelectComponent, decorators: [{
|
|
122
122
|
type: Component,
|
|
123
123
|
args: [{ selector: 'elder-chip-list-select', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
124
124
|
{
|
|
@@ -151,4 +151,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
151
151
|
}], selectionMultiEnabled: [{
|
|
152
152
|
type: Input
|
|
153
153
|
}] } });
|
|
154
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-chip-list-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, OnInit, Optional, Output} from '@angular/core';\nimport {SelectionModel} from '../../../common/selection/selection-model';\nimport {ELDER_DATA_VIEW} from '../../data-view/base/elder-data-view';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n@Component({\n  selector: 'elder-chip-list-select',\n  templateUrl: './elder-chip-list-select.component.html',\n  styleUrls: ['./elder-chip-list-select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ELDER_DATA_VIEW,\n      useExisting: forwardRef(() => ElderChipListSelectComponent)\n    }\n  ]\n})\nexport class ElderChipListSelectComponent implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  @Input()\n  public data$: BehaviorSubject<any[]> = new BehaviorSubject<any>([]);\n\n  /**\n   * The property used to compare two values.\n   * Useful if the values are entities with an id property.\n   */\n  @Input()\n  public idField = 'id';\n\n  /**\n   * The property whose values should be used for item display.\n   */\n  @Input()\n  public displayField: string = null;\n\n  /**\n   * The color used to indicated selection.\n   */\n  @Input()\n  public color: string;\n\n  /**\n   * If the chip list should be stacked.\n   */\n  @Input()\n  public stacked: false;\n\n  @Output()\n  public itemClick: EventEmitter<any> = new EventEmitter<any>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    @Optional() public selectionModel: SelectionModel<any>,\n  ) {\n    if (!selectionModel) {\n      this.selectionModel = new SelectionModel<any>(false, [], entity => entity ? this.getId(entity) : 0);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set data(data: any[]) {\n    this.data$.next(data);\n  }\n\n  @Input()\n  public set selection(selection: any[]) {\n    this.selectionModel.replaceSelection(selection);\n  }\n\n  @Output()\n  public get selectionChange(): Observable<any[]> {\n    return this.selectionModel.changed;\n  }\n\n  @Output()\n  public get selectionSingleChange(): Observable<any> {\n    return this.selectionModel.changed.pipe(\n      map(selection => {\n        if (selection.length > 0) {\n          return selection[0];\n        } else {\n          return null;\n        }\n      })\n    );\n  }\n\n  @Input()\n  public set selectionMultiEnabled(enableMultiSelection: boolean) {\n    if (this.selectionModel) {\n      this.selectionModel.isMultipleSelection = enableMultiSelection;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Component Events                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the user clicks on item\n   */\n  public onItemClick(entity: any): void {\n    this.selectionModel.toggle(entity);\n    this.itemClick.next(entity);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public getDisplayText(value: any): any {\n    if (this.displayField && value) {\n      return (<any>value)[this.displayField];\n    }\n    return value;\n  }\n\n  public isSelected(value: any): boolean {\n    return this.selectionModel.isSelected(value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private getId(entity: any): any {\n    return entity[this.idField] ?\n      entity[this.idField] : entity;\n  }\n\n\n}\n","\n<div fxLayout=\"column\" fxFill>\n\n  <mat-chip-list [ngClass]=\"{'mat-chip-list-stacked' : stacked}\">\n    <mat-chip *ngFor=\"let chip of data$ | async\" selected\n              [color]=\"isSelected(chip) ? color : 'undefined'\"\n              (click)=\"onItemClick(chip)\">\n      {{getDisplayText(chip)}}\n    </mat-chip>\n  </mat-chip-list>\n\n</div>\n\n"]}
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-chip-list-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, OnInit, Optional, Output} from '@angular/core';\nimport {SelectionModel} from '../../../common/selection/selection-model';\nimport {ELDER_DATA_VIEW} from '../../data-view/base/elder-data-view';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n@Component({\n  selector: 'elder-chip-list-select',\n  templateUrl: './elder-chip-list-select.component.html',\n  styleUrls: ['./elder-chip-list-select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ELDER_DATA_VIEW,\n      useExisting: forwardRef(() => ElderChipListSelectComponent)\n    }\n  ]\n})\nexport class ElderChipListSelectComponent implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  @Input()\n  public data$: BehaviorSubject<any[]> = new BehaviorSubject<any>([]);\n\n  /**\n   * The property used to compare two values.\n   * Useful if the values are entities with an id property.\n   */\n  @Input()\n  public idField = 'id';\n\n  /**\n   * The property whose values should be used for item display.\n   */\n  @Input()\n  public displayField: string = null;\n\n  /**\n   * The color used to indicated selection.\n   */\n  @Input()\n  public color: string;\n\n  /**\n   * If the chip list should be stacked.\n   */\n  @Input()\n  public stacked: false;\n\n  @Output()\n  public itemClick: EventEmitter<any> = new EventEmitter<any>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    @Optional() public selectionModel: SelectionModel<any>,\n  ) {\n    if (!selectionModel) {\n      this.selectionModel = new SelectionModel<any>(false, [], entity => entity ? this.getId(entity) : 0);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set data(data: any[]) {\n    this.data$.next(data);\n  }\n\n  @Input()\n  public set selection(selection: any[]) {\n    this.selectionModel.replaceSelection(selection);\n  }\n\n  @Output()\n  public get selectionChange(): Observable<any[]> {\n    return this.selectionModel.changed;\n  }\n\n  @Output()\n  public get selectionSingleChange(): Observable<any> {\n    return this.selectionModel.changed.pipe(\n      map(selection => {\n        if (selection.length > 0) {\n          return selection[0];\n        } else {\n          return null;\n        }\n      })\n    );\n  }\n\n  @Input()\n  public set selectionMultiEnabled(enableMultiSelection: boolean) {\n    if (this.selectionModel) {\n      this.selectionModel.isMultipleSelection = enableMultiSelection;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Component Events                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the user clicks on item\n   */\n  public onItemClick(entity: any): void {\n    this.selectionModel.toggle(entity);\n    this.itemClick.next(entity);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public getDisplayText(value: any): any {\n    if (this.displayField && value) {\n      return (<any>value)[this.displayField];\n    }\n    return value;\n  }\n\n  public isSelected(value: any): boolean {\n    return this.selectionModel.isSelected(value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private getId(entity: any): any {\n    return entity[this.idField] ?\n      entity[this.idField] : entity;\n  }\n\n\n}\n","\n<div fxLayout=\"column\" fxFill>\n\n  <mat-chip-list [ngClass]=\"{'mat-chip-list-stacked' : stacked}\">\n    <mat-chip *ngFor=\"let chip of data$ | async\" selected\n              [color]=\"isSelected(chip) ? color : 'undefined'\"\n              (click)=\"onItemClick(chip)\">\n      {{getDisplayText(chip)}}\n    </mat-chip>\n  </mat-chip-list>\n\n</div>\n\n"]}
|
|
@@ -9,8 +9,8 @@ import * as i0 from "@angular/core";
|
|
|
9
9
|
export { ElderChipListSelectComponent } from './chip-list-select/elder-chip-list-select.component';
|
|
10
10
|
export class ElderChipListSelectModule {
|
|
11
11
|
}
|
|
12
|
-
ElderChipListSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
13
|
-
ElderChipListSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.
|
|
12
|
+
ElderChipListSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderChipListSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
ElderChipListSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderChipListSelectModule, declarations: [ElderChipListSelectComponent], imports: [
|
|
14
14
|
// Angular
|
|
15
15
|
CommonModule,
|
|
16
16
|
// Third Party
|
|
@@ -18,7 +18,7 @@ ElderChipListSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0
|
|
|
18
18
|
// Material
|
|
19
19
|
MatChipsModule,
|
|
20
20
|
A11yModule], exports: [ElderChipListSelectComponent] });
|
|
21
|
-
ElderChipListSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.
|
|
21
|
+
ElderChipListSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderChipListSelectModule, imports: [[
|
|
22
22
|
// Angular
|
|
23
23
|
CommonModule,
|
|
24
24
|
// Third Party
|
|
@@ -27,7 +27,7 @@ ElderChipListSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0
|
|
|
27
27
|
MatChipsModule,
|
|
28
28
|
A11yModule
|
|
29
29
|
]] });
|
|
30
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderChipListSelectModule, decorators: [{
|
|
31
31
|
type: NgModule,
|
|
32
32
|
args: [{
|
|
33
33
|
imports: [
|
|
@@ -47,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
47
47
|
]
|
|
48
48
|
}]
|
|
49
49
|
}] });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItY2hpcC1saXN0LXNlbGVjdC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL3NlbGVjdC1jaGlwLWxpc3QvZWxkZXItY2hpcC1saXN0LXNlbGVjdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNwRCxPQUFPLEVBQUMsNEJBQTRCLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUNqRyxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7O0FBRXZELE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBc0JqRyxNQUFNLE9BQU8seUJBQXlCOzt1SEFBekIseUJBQXlCO3dIQUF6Qix5QkFBeUIsaUJBTmxDLDRCQUE0QjtRQVo1QixVQUFVO1FBQ1YsWUFBWTtRQUVaLGNBQWM7UUFDZCxlQUFlLEVBQUUsZ0JBQWdCO1FBRWpDLFdBQVc7UUFDWCxjQUFjO1FBQ2QsVUFBVSxhQU9WLDRCQUE0Qjt3SEFHbkIseUJBQXlCLFlBbkIzQjtZQUNQLFVBQVU7WUFDVixZQUFZO1lBRVosY0FBYztZQUNkLGVBQWUsRUFBRSxnQkFBZ0I7WUFFakMsV0FBVztZQUNYLGNBQWM7WUFDZCxVQUFVO1NBRVg7NEZBUVUseUJBQXlCO2tCQXBCckMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsVUFBVTt3QkFDVixZQUFZO3dCQUVaLGNBQWM7d0JBQ2QsZUFBZSxFQUFFLGdCQUFnQjt3QkFFakMsV0FBVzt3QkFDWCxjQUFjO3dCQUNkLFVBQVU7cUJBRVg7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLDRCQUE0QjtxQkFDN0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLDRCQUE0QjtxQkFDN0I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7RmxleExheW91dE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZmxleC1sYXlvdXQnO1xuaW1wb3J0IHtBMTF5TW9kdWxlfSBmcm9tICdAYW5ndWxhci9jZGsvYTExeSc7XG5pbXBvcnQge1RyYW5zbGF0ZU1vZHVsZX0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQge0VsZGVyQ2hpcExpc3RTZWxlY3RDb21wb25lbnR9IGZyb20gJy4vY2hpcC1saXN0LXNlbGVjdC9lbGRlci1jaGlwLWxpc3Qtc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQge01hdENoaXBzTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jaGlwcyc7XG5cbmV4cG9ydCB7RWxkZXJDaGlwTGlzdFNlbGVjdENvbXBvbmVudH0gZnJvbSAnLi9jaGlwLWxpc3Qtc2VsZWN0L2VsZGVyLWNoaXAtbGlzdC1zZWxlY3QuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIC8vIEFuZ3VsYXJcbiAgICBDb21tb25Nb2R1bGUsXG5cbiAgICAvLyBUaGlyZCBQYXJ0eVxuICAgIFRyYW5zbGF0ZU1vZHVsZSwgRmxleExheW91dE1vZHVsZSxcblxuICAgIC8vIE1hdGVyaWFsXG4gICAgTWF0Q2hpcHNNb2R1bGUsXG4gICAgQTExeU1vZHVsZVxuXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEVsZGVyQ2hpcExpc3RTZWxlY3RDb21wb25lbnRcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVsZGVyQ2hpcExpc3RTZWxlY3RDb21wb25lbnRcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckNoaXBMaXN0U2VsZWN0TW9kdWxlIHsgfVxuIl19
|
|
@@ -12,18 +12,18 @@ export { ElderSelectListComponent } from './select-list/elder-select-list.compon
|
|
|
12
12
|
export { ElderSelectListItemComponent } from './select-list-item/elder-select-list-item.component';
|
|
13
13
|
export class ElderSelectListModule {
|
|
14
14
|
}
|
|
15
|
-
ElderSelectListModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
16
|
-
ElderSelectListModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.
|
|
15
|
+
ElderSelectListModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderSelectListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
16
|
+
ElderSelectListModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderSelectListModule, declarations: [ElderSelectListComponent, ElderSelectListItemComponent], imports: [CommonModule,
|
|
17
17
|
MatIconModule, MatButtonModule,
|
|
18
18
|
A11yModule,
|
|
19
19
|
TranslateModule, FlexLayoutModule], exports: [ElderSelectListComponent, ElderSelectListItemComponent] });
|
|
20
|
-
ElderSelectListModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.
|
|
20
|
+
ElderSelectListModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderSelectListModule, imports: [[
|
|
21
21
|
CommonModule,
|
|
22
22
|
MatIconModule, MatButtonModule,
|
|
23
23
|
A11yModule,
|
|
24
24
|
TranslateModule, FlexLayoutModule
|
|
25
25
|
]] });
|
|
26
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderSelectListModule, decorators: [{
|
|
27
27
|
type: NgModule,
|
|
28
28
|
args: [{
|
|
29
29
|
declarations: [ElderSelectListComponent, ElderSelectListItemComponent],
|
|
@@ -36,4 +36,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
36
36
|
]
|
|
37
37
|
}]
|
|
38
38
|
}] });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItc2VsZWN0LWxpc3QubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9zZWxlY3QtbGlzdC9lbGRlci1zZWxlY3QtbGlzdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDckYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDbkcsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFDN0MsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHFCQUFxQixDQUFDOztBQUVwRCxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUNuRixPQUFPLEVBQUMsNEJBQTRCLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQWVqRyxNQUFNLE9BQU8scUJBQXFCOzttSEFBckIscUJBQXFCO29IQUFyQixxQkFBcUIsaUJBWGpCLHdCQUF3QixFQUFFLDRCQUE0QixhQUduRSxZQUFZO1FBRVosYUFBYSxFQUFFLGVBQWU7UUFDOUIsVUFBVTtRQUVWLGVBQWUsRUFBRSxnQkFBZ0IsYUFQekIsd0JBQXdCLEVBQUUsNEJBQTRCO29IQVVyRCxxQkFBcUIsWUFUdkI7WUFDUCxZQUFZO1lBRVosYUFBYSxFQUFFLGVBQWU7WUFDOUIsVUFBVTtZQUVWLGVBQWUsRUFBRSxnQkFBZ0I7U0FDbEM7NEZBRVUscUJBQXFCO2tCQVpqQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHdCQUF3QixFQUFFLDRCQUE0QixDQUFDO29CQUN0RSxPQUFPLEVBQUUsQ0FBQyx3QkFBd0IsRUFBRSw0QkFBNEIsQ0FBQztvQkFDakUsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBRVosYUFBYSxFQUFFLGVBQWU7d0JBQzlCLFVBQVU7d0JBRVYsZUFBZSxFQUFFLGdCQUFnQjtxQkFDbEM7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEVsZGVyU2VsZWN0TGlzdENvbXBvbmVudCB9IGZyb20gJy4vc2VsZWN0LWxpc3QvZWxkZXItc2VsZWN0LWxpc3QuY29tcG9uZW50JztcbmltcG9ydCB7IEVsZGVyU2VsZWN0TGlzdEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL3NlbGVjdC1saXN0LWl0ZW0vZWxkZXItc2VsZWN0LWxpc3QtaXRlbS5jb21wb25lbnQnO1xuaW1wb3J0IHtGbGV4TGF5b3V0TW9kdWxlfSBmcm9tICdAYW5ndWxhci9mbGV4LWxheW91dCc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHtBMTF5TW9kdWxlfSBmcm9tICdAYW5ndWxhci9jZGsvYTExeSc7XG5pbXBvcnQge1RyYW5zbGF0ZU1vZHVsZX0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5cbmV4cG9ydCB7RWxkZXJTZWxlY3RMaXN0Q29tcG9uZW50fSBmcm9tICcuL3NlbGVjdC1saXN0L2VsZGVyLXNlbGVjdC1saXN0LmNvbXBvbmVudCc7XG5leHBvcnQge0VsZGVyU2VsZWN0TGlzdEl0ZW1Db21wb25lbnR9IGZyb20gJy4vc2VsZWN0LWxpc3QtaXRlbS9lbGRlci1zZWxlY3QtbGlzdC1pdGVtLmNvbXBvbmVudCc7XG5cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbRWxkZXJTZWxlY3RMaXN0Q29tcG9uZW50LCBFbGRlclNlbGVjdExpc3RJdGVtQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW0VsZGVyU2VsZWN0TGlzdENvbXBvbmVudCwgRWxkZXJTZWxlY3RMaXN0SXRlbUNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG5cbiAgICBNYXRJY29uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsXG4gICAgQTExeU1vZHVsZSxcblxuICAgIFRyYW5zbGF0ZU1vZHVsZSwgRmxleExheW91dE1vZHVsZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyU2VsZWN0TGlzdE1vZHVsZSB7IH1cbiJdfQ==
|