@elderbyte/ngx-starter 13.8.1 → 13.9.2
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/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/url/elder-url-fragment-params.service.mjs +4 -4
- 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 +4 -4
- package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +4 -4
- 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 +28 -17
- package/esm2020/lib/components/select/elder-select-base.mjs +20 -6
- package/esm2020/lib/components/select/elder-select-chip.directive.mjs +18 -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 +15 -10
- 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 +48 -32
- 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 +1039 -888
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +1035 -888
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -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/select/elder-select/elder-select.component.d.ts +5 -2
- package/lib/components/select/elder-select-base.d.ts +12 -2
- package/lib/components/select/elder-select-chip.directive.d.ts +7 -0
- package/lib/components/select/elder-select.module.d.ts +3 -2
- 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 +14 -14
- package/lib/components/select/popup/selection-model-popup.directive.d.ts +2 -1
- 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 +16 -0
- package/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.scss +24 -0
- package/theming/_elder-common.scss +13 -8
package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs
CHANGED
|
@@ -154,9 +154,9 @@ export class ElderLocalDateInputComponent extends FormFieldBaseComponent {
|
|
|
154
154
|
: a === b;
|
|
155
155
|
}
|
|
156
156
|
}
|
|
157
|
-
ElderLocalDateInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
158
|
-
ElderLocalDateInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.
|
|
159
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
157
|
+
ElderLocalDateInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderLocalDateInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
158
|
+
ElderLocalDateInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.10", type: ElderLocalDateInputComponent, selector: "elder-local-date-input", inputs: { zone: "zone", datePickerEnabled: "datePickerEnabled", datePickerTouchUi: "datePickerTouchUi", allowNull: "allowNull", isoValue: "isoValue", dateValue: "dateValue", isoDateValue: "isoDateValue" }, outputs: { blur: "blur", valueUpdatedBlur: "valueUpdatedBlur", isoValueChange: "isoValueChange", dateValueChange: "dateValueChange", isoDateValueChange: "isoDateValueChange" }, providers: buildFormIntegrationProviders(ElderLocalDateInputComponent), viewQueries: [{ propertyName: "picker", first: true, predicate: MatDatepicker, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<mat-form-field fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n>\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n <input matInput elderNoSpinner fxFlex\n type=\"date\"\n [name]=\"name + '-inner'\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder | translate\"\n [ngModel]=\"date$ | async | date: 'yyyy-MM-dd'\"\n (ngModelChange)=\"onDateInputChanged($event)\"\n (blur)=\"blur.next($event)\"\n >\n <input style=\"display: none\" [matDatepicker]=\"picker\" (dateChange)=\"onDatepickerInputChange($event)\">\n\n <ng-container matSuffix>\n <mat-datepicker-toggle\n *ngIf=\"!isLocked && datePickerEnabled\"\n [for]=\"picker\">\n </mat-datepicker-toggle>\n\n <!-- valueWrapper.value && -->\n <button mat-icon-button type=\"button\"\n *ngIf=\"allowNull\"\n [disabled]=\"isLocked\"\n (click)=\"clear($event)\" aria-label=\"Clear\"\n elderStopEventPropagation\n >\n <mat-icon>close</mat-icon>\n </button>\n\n </ng-container>\n\n <mat-datepicker [touchUi]=\"datePickerTouchUi\" #picker></mat-datepicker>\n\n</mat-form-field>\n\n", styles: ["input::-webkit-calendar-picker-indicator{display:none}\n"], components: [{ type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i2.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i3.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: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i2.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }], directives: [{ type: i5.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: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatLabel, selector: "mat-label" }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { type: i8.ElderFormFieldNoSpinnerDirective, selector: "input[elderNoSpinner]", inputs: ["elderNoSpinner"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i9.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { type: i1.MatSuffix, selector: "[matSuffix]" }, { type: i10.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }], pipes: { "translate": i11.TranslatePipe, "date": i6.DatePipe, "async": i6.AsyncPipe }, viewProviders: [ViewProviders.ParentControlContainer], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
159
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderLocalDateInputComponent, decorators: [{
|
|
160
160
|
type: Component,
|
|
161
161
|
args: [{ selector: 'elder-local-date-input', changeDetection: ChangeDetectionStrategy.OnPush, providers: buildFormIntegrationProviders(ElderLocalDateInputComponent), viewProviders: [ViewProviders.ParentControlContainer], template: "<mat-form-field fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n>\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n <input matInput elderNoSpinner fxFlex\n type=\"date\"\n [name]=\"name + '-inner'\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder | translate\"\n [ngModel]=\"date$ | async | date: 'yyyy-MM-dd'\"\n (ngModelChange)=\"onDateInputChanged($event)\"\n (blur)=\"blur.next($event)\"\n >\n <input style=\"display: none\" [matDatepicker]=\"picker\" (dateChange)=\"onDatepickerInputChange($event)\">\n\n <ng-container matSuffix>\n <mat-datepicker-toggle\n *ngIf=\"!isLocked && datePickerEnabled\"\n [for]=\"picker\">\n </mat-datepicker-toggle>\n\n <!-- valueWrapper.value && -->\n <button mat-icon-button type=\"button\"\n *ngIf=\"allowNull\"\n [disabled]=\"isLocked\"\n (click)=\"clear($event)\" aria-label=\"Clear\"\n elderStopEventPropagation\n >\n <mat-icon>close</mat-icon>\n </button>\n\n </ng-container>\n\n <mat-datepicker [touchUi]=\"datePickerTouchUi\" #picker></mat-datepicker>\n\n</mat-form-field>\n\n", styles: ["input::-webkit-calendar-picker-indicator{display:none}\n"] }]
|
|
162
162
|
}], ctorParameters: function () { return []; }, propDecorators: { zone: [{
|
|
@@ -187,4 +187,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
187
187
|
}], isoDateValue: [{
|
|
188
188
|
type: Input
|
|
189
189
|
}] } });
|
|
190
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-local-date-input.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-local-date-input/elder-local-date-input.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-local-date-input/elder-local-date-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, Output, Input, ViewChild} from '@angular/core';\nimport {FormFieldBaseComponent} from '../../../common/forms/form-field-base.component';\nimport {LocalDate, ZoneId} from '@js-joda/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {buildFormIntegrationProviders} from '../../../common/forms/template-composite-control';\nimport {ViewProviders} from '../../../common/forms/view-providers';\nimport {combineLatest, Observable, of, Subject} from 'rxjs';\nimport {catchError, map} from 'rxjs/operators';\nimport {MatDatepicker, MatDatepickerInputEvent} from '@angular/material/datepicker';\nimport {TimeUtil} from '../../../common/time/time-util';\nimport {IsoDateStr} from '../../../common/time/date-util';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\n@Component({\n  selector: 'elder-local-date-input',\n  templateUrl: './elder-local-date-input.component.html',\n  styleUrls: ['./elder-local-date-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: buildFormIntegrationProviders(ElderLocalDateInputComponent),\n  viewProviders: [ViewProviders.ParentControlContainer]\n})\nexport class ElderLocalDateInputComponent extends FormFieldBaseComponent<LocalDate> implements OnInit {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private _allowNull = false;\n\n  @Input()\n  public zone = ZoneId.systemDefault();\n\n  /** If true, date picker functionality is enabled. */\n  @Input()\n  public datePickerEnabled = true;\n\n  /** If true, touch optimized mode of date picker is enabled. */\n  @Input()\n  public datePickerTouchUi = false;\n\n  @ViewChild(MatDatepicker, {static: true})\n  public picker: MatDatepicker<Date>;\n\n  public readonly date$: Observable<Date>;\n\n  @Output()\n  public readonly blur = new Subject<FocusEvent>();\n\n  /**\n   * Emits the updated value after the control blurred.\n   * (update & blur) events must have happened.\n   */\n  @Output()\n  public readonly valueUpdatedBlur: Observable<LocalDate>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    super();\n    this.date$ = this.mapIgnoreErrorObservable(this.value$, (v: LocalDate) => TimeUtil.localDateToDate(v, this.zone));\n    this.valueUpdatedBlur = combineLatest([this.valueUpdated, this.blur]).pipe(\n      map(([value, focusEvent]) => value)\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  /**\n   * Allows the user to select 'nothing' / null.\n   */\n  @Input()\n  public set allowNull(val: boolean) {\n    this._allowNull = coerceBooleanProperty(val);\n  }\n\n  public get allowNull(): boolean {\n    return this._allowNull;\n  }\n\n  @Output()\n  public get isoValueChange(): Observable<string | null> {\n    return this.mapIgnoreErrorObservable(this.valueChange, (d: LocalDate) => d.toJSON());\n  }\n\n  @Input()\n  public set isoValue(value: string | null) {\n    this.value = this.mapIgnoreError(value, (d: string) => LocalDate.parse(d));\n  }\n\n  @Output()\n  public get dateValueChange(): Observable<Date | null> {\n    return this.mapIgnoreErrorObservable(this.valueChange, (d: LocalDate) => TimeUtil.localDateToDate(d));\n  }\n\n  @Input()\n  public set dateValue(value: Date | null) {\n    this.value = this.mapIgnoreError(value, (d: Date) => TimeUtil.dateToLocalDate(d));\n  }\n\n  @Output()\n  public get isoDateValueChange(): Observable<IsoDateStr | null> {\n    return this.mapIgnoreErrorObservable(this.valueChange, (d: LocalDate) => TimeUtil.localDateToDate(d).toISOString());\n  }\n\n  @Input()\n  public set isoDateValue(value: IsoDateStr | null) {\n    this.value = this.mapIgnoreError(value, (d: IsoDateStr) => TimeUtil.dateToLocalDate(new Date(d)));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public clear(event: Event): void {\n    this.updateValue(null);\n  }\n\n  public openDatePicker(): void {\n    this.picker.open();\n  }\n\n  public onDateInputChanged(newDate: string): void {\n    try {\n\n      this.logger.debug('onDateInputChanged: \"' + newDate + '\"');\n\n      if (newDate === '' || newDate.startsWith('0')) {\n        return;\n      } // Ignore while updating the year\n      this.setDateStrInternally(newDate);\n    } catch (err) {\n      this.logger.error('Failed to parse from date-input-changed event: ' + newDate, err);\n    }\n  }\n\n  public onDatepickerInputChange(event: MatDatepickerInputEvent<Date>): void {\n    this.logger.debug('Datepicker Input has changed: ' + event.value);\n    this.setDateInternally(event.value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private mapIgnoreError(value: Date | string, conversionFn: (d: Date | string) => LocalDate): LocalDate {\n    try {\n      const ld = value ? conversionFn(value) : null;\n      this.logger.info('Setting local date: ' + ld);\n      return ld;\n    } catch (err) {\n      this.logger.warn('Failed to apply value to dateValue: ' + value, err);\n    }\n  }\n\n  private mapIgnoreErrorObservable<T>(date: Observable<LocalDate>, conversionFn: (d: LocalDate) => T): Observable<T | null> {\n    return date.pipe(\n      map(localDate => localDate ? conversionFn(localDate) : null),\n      catchError(err => {\n        this.logger.error('Failed to convert local date!', err);\n        return of(null);\n      })\n    );\n  }\n\n  private setDateStrInternally(date: string): void {\n    if (date) {\n      this.updateValue(LocalDate.parse(date));\n    } else {\n      this.updateValue(null);\n    }\n  }\n\n  private setDateInternally(date: Date): void {\n    if (date) {\n      this.updateValue(TimeUtil.dateToLocalDate(date));\n    } else {\n      this.updateValue(null);\n    }\n  }\n\n  protected valuesEquals(a: LocalDate, b: LocalDate): boolean {\n    return (a && b)\n      ? a.equals(b)\n      : a === b;\n  }\n\n}\n","<mat-form-field fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [color]=\"color\"\n>\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n  <input matInput elderNoSpinner fxFlex\n         type=\"date\"\n         [name]=\"name + '-inner'\"\n         [required]=\"required\"\n         [readonly]=\"readonly\"\n         [disabled]=\"disabled\"\n         [placeholder]=\"placeholder | translate\"\n         [ngModel]=\"date$ | async | date: 'yyyy-MM-dd'\"\n         (ngModelChange)=\"onDateInputChanged($event)\"\n         (blur)=\"blur.next($event)\"\n  >\n  <input style=\"display: none\" [matDatepicker]=\"picker\" (dateChange)=\"onDatepickerInputChange($event)\">\n\n  <ng-container matSuffix>\n    <mat-datepicker-toggle\n      *ngIf=\"!isLocked && datePickerEnabled\"\n      [for]=\"picker\">\n    </mat-datepicker-toggle>\n\n    <!-- valueWrapper.value && -->\n    <button mat-icon-button type=\"button\"\n            *ngIf=\"allowNull\"\n            [disabled]=\"isLocked\"\n            (click)=\"clear($event)\" aria-label=\"Clear\"\n            elderStopEventPropagation\n    >\n      <mat-icon>close</mat-icon>\n    </button>\n\n  </ng-container>\n\n  <mat-datepicker [touchUi]=\"datePickerTouchUi\" #picker></mat-datepicker>\n\n</mat-form-field>\n\n"]}
|
|
190
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-local-date-input.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-local-date-input/elder-local-date-input.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-local-date-input/elder-local-date-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, Output, Input, ViewChild} from '@angular/core';\nimport {FormFieldBaseComponent} from '../../../common/forms/form-field-base.component';\nimport {LocalDate, ZoneId} from '@js-joda/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {buildFormIntegrationProviders} from '../../../common/forms/template-composite-control';\nimport {ViewProviders} from '../../../common/forms/view-providers';\nimport {combineLatest, Observable, of, Subject} from 'rxjs';\nimport {catchError, map} from 'rxjs/operators';\nimport {MatDatepicker, MatDatepickerInputEvent} from '@angular/material/datepicker';\nimport {TimeUtil} from '../../../common/time/time-util';\nimport {IsoDateStr} from '../../../common/time/date-util';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\n@Component({\n  selector: 'elder-local-date-input',\n  templateUrl: './elder-local-date-input.component.html',\n  styleUrls: ['./elder-local-date-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: buildFormIntegrationProviders(ElderLocalDateInputComponent),\n  viewProviders: [ViewProviders.ParentControlContainer]\n})\nexport class ElderLocalDateInputComponent extends FormFieldBaseComponent<LocalDate> implements OnInit {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private _allowNull = false;\n\n  @Input()\n  public zone = ZoneId.systemDefault();\n\n  /** If true, date picker functionality is enabled. */\n  @Input()\n  public datePickerEnabled = true;\n\n  /** If true, touch optimized mode of date picker is enabled. */\n  @Input()\n  public datePickerTouchUi = false;\n\n  @ViewChild(MatDatepicker, {static: true})\n  public picker: MatDatepicker<Date>;\n\n  public readonly date$: Observable<Date>;\n\n  @Output()\n  public readonly blur = new Subject<FocusEvent>();\n\n  /**\n   * Emits the updated value after the control blurred.\n   * (update & blur) events must have happened.\n   */\n  @Output()\n  public readonly valueUpdatedBlur: Observable<LocalDate>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    super();\n    this.date$ = this.mapIgnoreErrorObservable(this.value$, (v: LocalDate) => TimeUtil.localDateToDate(v, this.zone));\n    this.valueUpdatedBlur = combineLatest([this.valueUpdated, this.blur]).pipe(\n      map(([value, focusEvent]) => value)\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  /**\n   * Allows the user to select 'nothing' / null.\n   */\n  @Input()\n  public set allowNull(val: boolean) {\n    this._allowNull = coerceBooleanProperty(val);\n  }\n\n  public get allowNull(): boolean {\n    return this._allowNull;\n  }\n\n  @Output()\n  public get isoValueChange(): Observable<string | null> {\n    return this.mapIgnoreErrorObservable(this.valueChange, (d: LocalDate) => d.toJSON());\n  }\n\n  @Input()\n  public set isoValue(value: string | null) {\n    this.value = this.mapIgnoreError(value, (d: string) => LocalDate.parse(d));\n  }\n\n  @Output()\n  public get dateValueChange(): Observable<Date | null> {\n    return this.mapIgnoreErrorObservable(this.valueChange, (d: LocalDate) => TimeUtil.localDateToDate(d));\n  }\n\n  @Input()\n  public set dateValue(value: Date | null) {\n    this.value = this.mapIgnoreError(value, (d: Date) => TimeUtil.dateToLocalDate(d));\n  }\n\n  @Output()\n  public get isoDateValueChange(): Observable<IsoDateStr | null> {\n    return this.mapIgnoreErrorObservable(this.valueChange, (d: LocalDate) => TimeUtil.localDateToDate(d).toISOString());\n  }\n\n  @Input()\n  public set isoDateValue(value: IsoDateStr | null) {\n    this.value = this.mapIgnoreError(value, (d: IsoDateStr) => TimeUtil.dateToLocalDate(new Date(d)));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public clear(event: Event): void {\n    this.updateValue(null);\n  }\n\n  public openDatePicker(): void {\n    this.picker.open();\n  }\n\n  public onDateInputChanged(newDate: string): void {\n    try {\n\n      this.logger.debug('onDateInputChanged: \"' + newDate + '\"');\n\n      if (newDate === '' || newDate.startsWith('0')) {\n        return;\n      } // Ignore while updating the year\n      this.setDateStrInternally(newDate);\n    } catch (err) {\n      this.logger.error('Failed to parse from date-input-changed event: ' + newDate, err);\n    }\n  }\n\n  public onDatepickerInputChange(event: MatDatepickerInputEvent<Date>): void {\n    this.logger.debug('Datepicker Input has changed: ' + event.value);\n    this.setDateInternally(event.value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private mapIgnoreError(value: Date | string, conversionFn: (d: Date | string) => LocalDate): LocalDate {\n    try {\n      const ld = value ? conversionFn(value) : null;\n      this.logger.info('Setting local date: ' + ld);\n      return ld;\n    } catch (err) {\n      this.logger.warn('Failed to apply value to dateValue: ' + value, err);\n    }\n  }\n\n  private mapIgnoreErrorObservable<T>(date: Observable<LocalDate>, conversionFn: (d: LocalDate) => T): Observable<T | null> {\n    return date.pipe(\n      map(localDate => localDate ? conversionFn(localDate) : null),\n      catchError(err => {\n        this.logger.error('Failed to convert local date!', err);\n        return of(null);\n      })\n    );\n  }\n\n  private setDateStrInternally(date: string): void {\n    if (date) {\n      this.updateValue(LocalDate.parse(date));\n    } else {\n      this.updateValue(null);\n    }\n  }\n\n  private setDateInternally(date: Date): void {\n    if (date) {\n      this.updateValue(TimeUtil.dateToLocalDate(date));\n    } else {\n      this.updateValue(null);\n    }\n  }\n\n  protected valuesEquals(a: LocalDate, b: LocalDate): boolean {\n    return (a && b)\n      ? a.equals(b)\n      : a === b;\n  }\n\n}\n","<mat-form-field fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [color]=\"color\"\n>\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n  <input matInput elderNoSpinner fxFlex\n         type=\"date\"\n         [name]=\"name + '-inner'\"\n         [required]=\"required\"\n         [readonly]=\"readonly\"\n         [disabled]=\"disabled\"\n         [placeholder]=\"placeholder | translate\"\n         [ngModel]=\"date$ | async | date: 'yyyy-MM-dd'\"\n         (ngModelChange)=\"onDateInputChanged($event)\"\n         (blur)=\"blur.next($event)\"\n  >\n  <input style=\"display: none\" [matDatepicker]=\"picker\" (dateChange)=\"onDatepickerInputChange($event)\">\n\n  <ng-container matSuffix>\n    <mat-datepicker-toggle\n      *ngIf=\"!isLocked && datePickerEnabled\"\n      [for]=\"picker\">\n    </mat-datepicker-toggle>\n\n    <!-- valueWrapper.value && -->\n    <button mat-icon-button type=\"button\"\n            *ngIf=\"allowNull\"\n            [disabled]=\"isLocked\"\n            (click)=\"clear($event)\" aria-label=\"Clear\"\n            elderStopEventPropagation\n    >\n      <mat-icon>close</mat-icon>\n    </button>\n\n  </ng-container>\n\n  <mat-datepicker [touchUi]=\"datePickerTouchUi\" #picker></mat-datepicker>\n\n</mat-form-field>\n\n"]}
|
package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs
CHANGED
|
@@ -72,9 +72,9 @@ export class ElderLocalTimeInputComponent extends FormFieldBaseComponent {
|
|
|
72
72
|
: a === b;
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
|
-
ElderLocalTimeInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
76
|
-
ElderLocalTimeInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.
|
|
77
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
75
|
+
ElderLocalTimeInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderLocalTimeInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
76
|
+
ElderLocalTimeInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.10", type: ElderLocalTimeInputComponent, selector: "elder-local-time-input", inputs: { isoValue: "isoValue" }, outputs: { isoValueChange: "isoValueChange" }, providers: buildFormIntegrationProviders(ElderLocalTimeInputComponent), usesInheritance: true, ngImport: i0, template: "<mat-form-field fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n>\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n <input matInput fxFlex=\"grow\"\n [name]=\"name + '-inner'\"\n type=\"time\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [min]=\"min\"\n [max]=\"max\"\n [placeholder]=\"placeholder | translate\"\n [ngModel]=\"hourMinuteStr$ | async\"\n (ngModelChange)=\"onHourMinuteChanged($event)\">\n</mat-form-field>\n", styles: [""], components: [{ type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }], directives: [{ type: i2.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: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatLabel, selector: "mat-label" }, { type: i4.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: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i6.ElderMinDirective, selector: "[min][formControlName],[min][formControl],[min][ngModel]", inputs: ["min"] }, { type: i7.ElderMaxDirective, selector: "[max][formControlName],[max][formControl],[max][ngModel]", inputs: ["max"] }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "translate": i8.TranslatePipe, "async": i3.AsyncPipe }, viewProviders: [ViewProviders.ParentControlContainer], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
77
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderLocalTimeInputComponent, decorators: [{
|
|
78
78
|
type: Component,
|
|
79
79
|
args: [{ selector: 'elder-local-time-input', changeDetection: ChangeDetectionStrategy.OnPush, providers: buildFormIntegrationProviders(ElderLocalTimeInputComponent), viewProviders: [ViewProviders.ParentControlContainer], template: "<mat-form-field fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [color]=\"color\"\n>\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n <input matInput fxFlex=\"grow\"\n [name]=\"name + '-inner'\"\n type=\"time\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [min]=\"min\"\n [max]=\"max\"\n [placeholder]=\"placeholder | translate\"\n [ngModel]=\"hourMinuteStr$ | async\"\n (ngModelChange)=\"onHourMinuteChanged($event)\">\n</mat-form-field>\n", styles: [""] }]
|
|
80
80
|
}], ctorParameters: function () { return []; }, propDecorators: { isoValueChange: [{
|
|
@@ -82,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
82
82
|
}], isoValue: [{
|
|
83
83
|
type: Input
|
|
84
84
|
}] } });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-local-time-input.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-local-time-input/elder-local-time-input.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-local-time-input/elder-local-time-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAU,uBAAuB,EAAE,MAAM,EAAE,KAAK,EAAC,MAAM,eAAe,CAAC;AACxF,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAqB,SAAS,EAAC,MAAM,eAAe,CAAC;AAE5D,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;AACnC,OAAO,EAAC,6BAA6B,EAAC,MAAM,kDAAkD,CAAC;AAC/F,OAAO,EAAC,aAAa,EAAC,MAAM,sCAAsC,CAAC;AACnE,OAAO,EAAC,sBAAsB,EAAC,MAAM,iDAAiD,CAAC;;;;;;;;;;AAWvF,MAAM,OAAO,4BAA6B,SAAQ,sBAAiC;IAYjF;;;;gFAI4E;IAE5E;QACE,KAAK,EAAE,CAAC;QAjBV;;;;oFAI4E;QAE3D,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAavE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CACpC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CACxD,CAAC;IACJ,CAAC;IAED;;;;gFAI4E;IAErE,QAAQ;IACf,CAAC;IAED;;;;gFAI4E;IAE5E,IACW,cAAc;QACvB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAC1B,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CACzC,CAAC;IACJ,CAAC;IAED,IACW,QAAQ,CAAC,KAAoB;QACtC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACrD,CAAC;IAED;;;;gFAI4E;IAGrE,mBAAmB,CAAC,KAAa;QACtC,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;SAC1C;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;SACxB;IACH,CAAC;IAED;;;;gFAI4E;IAElE,YAAY,CAAC,CAAY,EAAE,CAAY;QAC/C,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;YACb,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;YACb,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IACd,CAAC;;0HA9EU,4BAA4B;8GAA5B,4BAA4B,kIAH5B,6BAA6B,CAAC,4BAA4B,CAAC,iDCfxE,soBAmBA,4nEDHiB,CAAC,aAAa,CAAC,sBAAsB,CAAC;4FAE1C,4BAA4B;kBARxC,SAAS;+BACE,wBAAwB,mBAGjB,uBAAuB,CAAC,MAAM,aACpC,6BAA6B,8BAA8B,iBACvD,CAAC,aAAa,CAAC,sBAAsB,CAAC;0EA4C1C,cAAc;sBADxB,MAAM;gBAQI,QAAQ;sBADlB,KAAK","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, Output, Input} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {Instant, LocalDate, LocalTime} from '@js-joda/core';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {buildFormIntegrationProviders} from '../../../common/forms/template-composite-control';\nimport {ViewProviders} from '../../../common/forms/view-providers';\nimport {FormFieldBaseComponent} from '../../../common/forms/form-field-base.component';\nimport {Interval} from '../../../common/time/interval';\n\n@Component({\n  selector: 'elder-local-time-input',\n  templateUrl: './elder-local-time-input.component.html',\n  styleUrls: ['./elder-local-time-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: buildFormIntegrationProviders(ElderLocalTimeInputComponent),\n  viewProviders: [ViewProviders.ParentControlContainer]\n})\nexport class ElderLocalTimeInputComponent extends FormFieldBaseComponent<LocalTime> implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly hourMinuteStr$: Observable<string>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    super();\n\n    this.hourMinuteStr$ = this.value$.pipe(\n      map(localTime => localTime ? localTime.toJSON() : null)\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  @Output()\n  public get isoValueChange(): Observable<string | null> {\n    return this.valueChange.pipe(\n      map(time => time ? time.toJSON() : null)\n    );\n  }\n\n  @Input()\n  public set isoValue(value: string | null) {\n    this.value = value ? LocalTime.parse(value) : null;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public methods                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n\n  public onHourMinuteChanged(event: string): void {\n    if (event) {\n      this.updateValue(LocalTime.parse(event));\n    } else {\n      this.updateValue(null);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: LocalTime, b: LocalTime): boolean {\n    return (a && b)\n      ? a.equals(b)\n      : a === b;\n  }\n}\n","<mat-form-field fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [color]=\"color\"\n>\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n  <input matInput fxFlex=\"grow\"\n         [name]=\"name + '-inner'\"\n         type=\"time\"\n         [required]=\"required\"\n         [readonly]=\"readonly\"\n         [disabled]=\"disabled\"\n         [min]=\"min\"\n         [max]=\"max\"\n         [placeholder]=\"placeholder | translate\"\n         [ngModel]=\"hourMinuteStr$ | async\"\n         (ngModelChange)=\"onHourMinuteChanged($event)\">\n</mat-form-field>\n"]}
|
|
@@ -28,8 +28,8 @@ export { ElderDurationInputComponent } from './duration/elder-duration-input/eld
|
|
|
28
28
|
export { ElderPeriodInputComponent } from './period/elder-period-input/elder-period-input.component';
|
|
29
29
|
export class ElderTimeModule {
|
|
30
30
|
}
|
|
31
|
-
ElderTimeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
32
|
-
ElderTimeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.
|
|
31
|
+
ElderTimeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderTimeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
32
|
+
ElderTimeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderTimeModule, declarations: [ElderDateSwitcherComponent,
|
|
33
33
|
ElderIntervalInputComponent,
|
|
34
34
|
ElderDateTimeInputComponent,
|
|
35
35
|
ElderLocalTimeInputComponent,
|
|
@@ -58,7 +58,7 @@ ElderTimeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version
|
|
|
58
58
|
ElderLocalDateInputComponent,
|
|
59
59
|
ElderDurationInputComponent,
|
|
60
60
|
ElderPeriodInputComponent] });
|
|
61
|
-
ElderTimeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.
|
|
61
|
+
ElderTimeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderTimeModule, providers: [
|
|
62
62
|
{ provide: DateAdapter, useClass: CustomDateAdapter }
|
|
63
63
|
], imports: [[
|
|
64
64
|
// common
|
|
@@ -78,7 +78,7 @@ ElderTimeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version
|
|
|
78
78
|
// translations
|
|
79
79
|
TranslateModule, ElderFormsDirectivesModule
|
|
80
80
|
]] });
|
|
81
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
81
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderTimeModule, decorators: [{
|
|
82
82
|
type: NgModule,
|
|
83
83
|
args: [{
|
|
84
84
|
imports: [
|
|
@@ -127,12 +127,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
127
127
|
*/
|
|
128
128
|
export class ElderDatesModule {
|
|
129
129
|
}
|
|
130
|
-
ElderDatesModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
131
|
-
ElderDatesModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.
|
|
132
|
-
ElderDatesModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.
|
|
130
|
+
ElderDatesModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderDatesModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
131
|
+
ElderDatesModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderDatesModule, imports: [ElderTimeModule], exports: [ElderTimeModule] });
|
|
132
|
+
ElderDatesModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderDatesModule, imports: [[
|
|
133
133
|
ElderTimeModule
|
|
134
134
|
], ElderTimeModule] });
|
|
135
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
135
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderDatesModule, decorators: [{
|
|
136
136
|
type: NgModule,
|
|
137
137
|
args: [{
|
|
138
138
|
imports: [
|
|
@@ -143,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
143
143
|
],
|
|
144
144
|
}]
|
|
145
145
|
}] });
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-time.module.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-time.module.ts"],"names":[],"mappings":"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","sourcesContent":["import {NgModule} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {MatButtonModule} from '@angular/material/button';\nimport {DateAdapter, MatNativeDateModule} from '@angular/material/core';\nimport {MatDatepickerModule} from '@angular/material/datepicker';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatTooltipModule} from '@angular/material/tooltip';\nimport {FormsModule} from '@angular/forms';\nimport {FlexLayoutModule} from '@angular/flex-layout';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {ElderDateSwitcherComponent} from './elder-date-switcher/elder-date-switcher.component';\nimport {CustomDateAdapter} from './date-adapters/custom-date-adapter';\nimport {ElderIntervalInputComponent} from './elder-interval-input/elder-interval-input.component';\nimport {ElderDateTimeInputComponent} from './elder-date-time-input/elder-date-time-input.component';\nimport {ElderLocalTimeInputComponent} from './elder-local-time-input/elder-local-time-input.component';\nimport {ElderLocalDateInputComponent} from './elder-local-date-input/elder-local-date-input.component';\nimport {ElderDurationInputComponent} from './duration/elder-duration-input/elder-duration-input.component';\nimport {ElderFormsDirectivesModule} from '../forms/directives/elder-forms-directives.module';\nimport {ElderPeriodInputComponent} from './period/elder-period-input/elder-period-input.component';\n\nexport {ElderDateSwitcherComponent} from './elder-date-switcher/elder-date-switcher.component';\nexport {ElderIntervalInputComponent} from './elder-interval-input/elder-interval-input.component';\nexport {ElderDateTimeInputComponent} from './elder-date-time-input/elder-date-time-input.component';\nexport {ElderLocalTimeInputComponent} from './elder-local-time-input/elder-local-time-input.component';\nexport {ElderLocalDateInputComponent} from './elder-local-date-input/elder-local-date-input.component';\nexport {ElderDurationInputComponent} from './duration/elder-duration-input/elder-duration-input.component';\nexport {ElderPeriodInputComponent} from './period/elder-period-input/elder-period-input.component';\n\n\n@NgModule({\n  imports: [\n    // common\n    CommonModule, MatNativeDateModule,\n\n    // navigation\n\n    // layout\n    FlexLayoutModule,\n\n    // forms\n    FormsModule,\n\n    // form controls\n    MatInputModule, MatDatepickerModule,\n\n    // buttons & indicators\n    MatButtonModule, MatIconModule,\n\n    // popups & modals\n    MatTooltipModule,\n\n    // data matTable\n\n    // translations\n    TranslateModule, ElderFormsDirectivesModule\n  ],\n  declarations: [\n    ElderDateSwitcherComponent,\n    ElderIntervalInputComponent,\n    ElderDateTimeInputComponent,\n    ElderLocalTimeInputComponent,\n    ElderLocalDateInputComponent,\n    ElderDurationInputComponent,\n    ElderPeriodInputComponent\n  ],\n  exports: [\n    ElderDateSwitcherComponent,\n    ElderDateTimeInputComponent,\n    ElderIntervalInputComponent,\n    ElderLocalTimeInputComponent,\n    ElderLocalDateInputComponent,\n    ElderDurationInputComponent,\n    ElderPeriodInputComponent\n  ],\n  providers: [\n    {provide: DateAdapter, useClass: CustomDateAdapter}\n  ]\n})\nexport class ElderTimeModule {\n}\n\n/**\n * @deprecated Please switch to the ElderTimeModule\n */\n@NgModule({\n  imports: [\n    ElderTimeModule\n  ],\n  exports: [\n    ElderTimeModule\n  ],\n})\nexport class ElderDatesModule {\n}\n"]}
|
package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs
CHANGED
|
@@ -103,9 +103,9 @@ export class ElderPeriodInputComponent extends FormFieldBaseComponent {
|
|
|
103
103
|
: a === b;
|
|
104
104
|
}
|
|
105
105
|
}
|
|
106
|
-
ElderPeriodInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
107
|
-
ElderPeriodInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.
|
|
108
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
106
|
+
ElderPeriodInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderPeriodInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
107
|
+
ElderPeriodInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.10", type: ElderPeriodInputComponent, selector: "elder-period-input", inputs: { isoValue: "isoValue", format: "format", periodFormat: "periodFormat" }, outputs: { isoValueChange: "isoValueChange" }, providers: buildFormIntegrationProviders(ElderPeriodInputComponent), usesInheritance: true, ngImport: i0, template: "<div fxLayout=\"row\" fxFlex=\"none\" *ngIf=\"periodContext$ | async as periodCtx\">\n\n <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.days\">\n <input matInput elderNoSpinner\n [name]=\"name + '-inner-days'\"\n type=\"number\" class=\"period-input\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [ngModel]=\"round(periodCtx?.bucket?.days)\"\n (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withDays($event))\">\n <span matSuffix class=\"suffix\">d</span>\n </mat-form-field>\n\n <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.months\">\n <input matInput elderNoSpinner\n [name]=\"name + '-inner-months'\"\n type=\"number\" class=\"period-input\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [ngModel]=\"round(periodCtx?.bucket?.months)\"\n (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withMonths($event))\">\n <span matSuffix class=\"suffix\">mnt</span>\n </mat-form-field>\n\n <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.years\">\n <input matInput elderNoSpinner\n [name]=\"name + '-inner-years'\"\n type=\"number\" class=\"period-input\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [ngModel]=\"round(periodCtx?.bucket?.years)\"\n (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withYears($event))\">\n <span matSuffix class=\"suffix\">yrs</span>\n </mat-form-field>\n\n\n</div>\n", styles: [".period-field{width:50px}.suffix{margin-left:4px;opacity:.7;font-size:12px}.period-input{text-align:right}input.period-input::-webkit-outer-spin-button,input.period-input::-webkit-inner-spin-button{display:none}input.period-input{-moz-appearance:textfield}\n"], components: [{ type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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.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: i4.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: i5.ElderFormFieldNoSpinnerDirective, selector: "input[elderNoSpinner]", inputs: ["elderNoSpinner"] }, { type: i6.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1.MatSuffix, selector: "[matSuffix]" }], pipes: { "async": i2.AsyncPipe }, viewProviders: [ViewProviders.ParentControlContainer], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
108
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderPeriodInputComponent, decorators: [{
|
|
109
109
|
type: Component,
|
|
110
110
|
args: [{ selector: 'elder-period-input', changeDetection: ChangeDetectionStrategy.OnPush, providers: buildFormIntegrationProviders(ElderPeriodInputComponent), viewProviders: [ViewProviders.ParentControlContainer], template: "<div fxLayout=\"row\" fxFlex=\"none\" *ngIf=\"periodContext$ | async as periodCtx\">\n\n <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.days\">\n <input matInput elderNoSpinner\n [name]=\"name + '-inner-days'\"\n type=\"number\" class=\"period-input\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [ngModel]=\"round(periodCtx?.bucket?.days)\"\n (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withDays($event))\">\n <span matSuffix class=\"suffix\">d</span>\n </mat-form-field>\n\n <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.months\">\n <input matInput elderNoSpinner\n [name]=\"name + '-inner-months'\"\n type=\"number\" class=\"period-input\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [ngModel]=\"round(periodCtx?.bucket?.months)\"\n (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withMonths($event))\">\n <span matSuffix class=\"suffix\">mnt</span>\n </mat-form-field>\n\n <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.years\">\n <input matInput elderNoSpinner\n [name]=\"name + '-inner-years'\"\n type=\"number\" class=\"period-input\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [ngModel]=\"round(periodCtx?.bucket?.years)\"\n (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withYears($event))\">\n <span matSuffix class=\"suffix\">yrs</span>\n </mat-form-field>\n\n\n</div>\n", styles: [".period-field{width:50px}.suffix{margin-left:4px;opacity:.7;font-size:12px}.period-input{text-align:right}input.period-input::-webkit-outer-spin-button,input.period-input::-webkit-inner-spin-button{display:none}input.period-input{-moz-appearance:textfield}\n"] }]
|
|
111
111
|
}], ctorParameters: function () { return []; }, propDecorators: { isoValueChange: [{
|
|
@@ -117,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
117
117
|
}], periodFormat: [{
|
|
118
118
|
type: Input
|
|
119
119
|
}] } });
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-period-input.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/period/elder-period-input/elder-period-input.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/period/elder-period-input/elder-period-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, Output, Input} from '@angular/core';\nimport {buildFormIntegrationProviders} from '../../../../common/forms/template-composite-control';\nimport {ViewProviders} from '../../../../common/forms/view-providers';\nimport {FormFieldBaseComponent} from '../../../../common/forms/form-field-base.component';\nimport {Period} from '@js-joda/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {PeriodFormat} from '../period-format';\nimport {PeriodBucket} from '../period-bucket';\n\n\nclass PeriodInputContext {\n  constructor(\n    public readonly bucket: PeriodBucket,\n    public readonly format: PeriodFormat,\n  ) {\n  }\n}\n\n\n/**\n *\n * Days\n * Weeks\n * Months\n * Years\n *\n */\n@Component({\n  selector: 'elder-period-input',\n  templateUrl: './elder-period-input.component.html',\n  styleUrls: ['./elder-period-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: buildFormIntegrationProviders(ElderPeriodInputComponent),\n  viewProviders: [ViewProviders.ParentControlContainer]\n})\nexport class ElderPeriodInputComponent extends FormFieldBaseComponent<Period> implements OnInit {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly periodFormat$ = new BehaviorSubject<PeriodFormat>(PeriodFormat.DEFAULT);\n  public readonly periodContext$: Observable<PeriodInputContext>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    super();\n\n\n    this.periodContext$ = combineLatest([this.value$, this.periodFormat$]).pipe(\n      map(\n        ([period, format]) => {\n\n          this.log.debug('Got period', period);\n\n          return new PeriodInputContext(\n            format.bucket(period),\n            format\n          );\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  @Output()\n  public get isoValueChange(): Observable<string | null> {\n    return this.valueChange.pipe(\n      map(period => period ? period.toJSON() : null)\n    );\n  }\n\n  @Input()\n  public set isoValue(value: string | null) {\n    if (value) {\n      this.value = Period.parse(value);\n    } else {\n      this.value = null;\n    }\n  }\n\n  /**\n   * yyyy:MM:ww:dd\n   * @param periodFormat\n   */\n  @Input()\n  public set format(periodFormat: string) {\n    this.periodFormat = PeriodFormat.parse(periodFormat);\n  }\n\n  @Input()\n  public set periodFormat(format: PeriodFormat) {\n    this.periodFormat$.next(format);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public round(value: number): number {\n    return Math.round(value);\n  }\n\n  public onBucketChanged(bucket: PeriodBucket): void {\n    this.value = bucket.toPeriod();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: Period, b: Period): boolean {\n    return (a && b)\n      ? a.equals(b)\n      : a === b;\n  }\n\n}\n","<div fxLayout=\"row\" fxFlex=\"none\" *ngIf=\"periodContext$ | async as periodCtx\">\n\n  <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.days\">\n    <input matInput elderNoSpinner\n           [name]=\"name + '-inner-days'\"\n           type=\"number\" class=\"period-input\"\n           [required]=\"required\"\n           [readonly]=\"readonly\"\n           [disabled]=\"disabled\"\n           [ngModel]=\"round(periodCtx?.bucket?.days)\"\n           (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withDays($event))\">\n    <span matSuffix class=\"suffix\">d</span>\n  </mat-form-field>\n\n  <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.months\">\n    <input matInput elderNoSpinner\n           [name]=\"name + '-inner-months'\"\n           type=\"number\" class=\"period-input\"\n           [required]=\"required\"\n           [readonly]=\"readonly\"\n           [disabled]=\"disabled\"\n           [ngModel]=\"round(periodCtx?.bucket?.months)\"\n           (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withMonths($event))\">\n    <span matSuffix class=\"suffix\">mnt</span>\n  </mat-form-field>\n\n  <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.years\">\n    <input matInput elderNoSpinner\n           [name]=\"name + '-inner-years'\"\n           type=\"number\" class=\"period-input\"\n           [required]=\"required\"\n           [readonly]=\"readonly\"\n           [disabled]=\"disabled\"\n           [ngModel]=\"round(periodCtx?.bucket?.years)\"\n           (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withYears($event))\">\n    <span matSuffix class=\"suffix\">yrs</span>\n  </mat-form-field>\n\n\n</div>\n"]}
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-period-input.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/period/elder-period-input/elder-period-input.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/period/elder-period-input/elder-period-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, Output, Input} from '@angular/core';\nimport {buildFormIntegrationProviders} from '../../../../common/forms/template-composite-control';\nimport {ViewProviders} from '../../../../common/forms/view-providers';\nimport {FormFieldBaseComponent} from '../../../../common/forms/form-field-base.component';\nimport {Period} from '@js-joda/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {PeriodFormat} from '../period-format';\nimport {PeriodBucket} from '../period-bucket';\n\n\nclass PeriodInputContext {\n  constructor(\n    public readonly bucket: PeriodBucket,\n    public readonly format: PeriodFormat,\n  ) {\n  }\n}\n\n\n/**\n *\n * Days\n * Weeks\n * Months\n * Years\n *\n */\n@Component({\n  selector: 'elder-period-input',\n  templateUrl: './elder-period-input.component.html',\n  styleUrls: ['./elder-period-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: buildFormIntegrationProviders(ElderPeriodInputComponent),\n  viewProviders: [ViewProviders.ParentControlContainer]\n})\nexport class ElderPeriodInputComponent extends FormFieldBaseComponent<Period> implements OnInit {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly periodFormat$ = new BehaviorSubject<PeriodFormat>(PeriodFormat.DEFAULT);\n  public readonly periodContext$: Observable<PeriodInputContext>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    super();\n\n\n    this.periodContext$ = combineLatest([this.value$, this.periodFormat$]).pipe(\n      map(\n        ([period, format]) => {\n\n          this.log.debug('Got period', period);\n\n          return new PeriodInputContext(\n            format.bucket(period),\n            format\n          );\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  @Output()\n  public get isoValueChange(): Observable<string | null> {\n    return this.valueChange.pipe(\n      map(period => period ? period.toJSON() : null)\n    );\n  }\n\n  @Input()\n  public set isoValue(value: string | null) {\n    if (value) {\n      this.value = Period.parse(value);\n    } else {\n      this.value = null;\n    }\n  }\n\n  /**\n   * yyyy:MM:ww:dd\n   * @param periodFormat\n   */\n  @Input()\n  public set format(periodFormat: string) {\n    this.periodFormat = PeriodFormat.parse(periodFormat);\n  }\n\n  @Input()\n  public set periodFormat(format: PeriodFormat) {\n    this.periodFormat$.next(format);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public round(value: number): number {\n    return Math.round(value);\n  }\n\n  public onBucketChanged(bucket: PeriodBucket): void {\n    this.value = bucket.toPeriod();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: Period, b: Period): boolean {\n    return (a && b)\n      ? a.equals(b)\n      : a === b;\n  }\n\n}\n","<div fxLayout=\"row\" fxFlex=\"none\" *ngIf=\"periodContext$ | async as periodCtx\">\n\n  <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.days\">\n    <input matInput elderNoSpinner\n           [name]=\"name + '-inner-days'\"\n           type=\"number\" class=\"period-input\"\n           [required]=\"required\"\n           [readonly]=\"readonly\"\n           [disabled]=\"disabled\"\n           [ngModel]=\"round(periodCtx?.bucket?.days)\"\n           (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withDays($event))\">\n    <span matSuffix class=\"suffix\">d</span>\n  </mat-form-field>\n\n  <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.months\">\n    <input matInput elderNoSpinner\n           [name]=\"name + '-inner-months'\"\n           type=\"number\" class=\"period-input\"\n           [required]=\"required\"\n           [readonly]=\"readonly\"\n           [disabled]=\"disabled\"\n           [ngModel]=\"round(periodCtx?.bucket?.months)\"\n           (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withMonths($event))\">\n    <span matSuffix class=\"suffix\">mnt</span>\n  </mat-form-field>\n\n  <mat-form-field class=\"period-field\" *ngIf=\"periodCtx.format.years\">\n    <input matInput elderNoSpinner\n           [name]=\"name + '-inner-years'\"\n           type=\"number\" class=\"period-input\"\n           [required]=\"required\"\n           [readonly]=\"readonly\"\n           [disabled]=\"disabled\"\n           [ngModel]=\"round(periodCtx?.bucket?.years)\"\n           (ngModelChange)=\"onBucketChanged(periodCtx.bucket.withYears($event))\">\n    <span matSuffix class=\"suffix\">yrs</span>\n  </mat-form-field>\n\n\n</div>\n"]}
|
|
@@ -9,10 +9,10 @@ import * as i0 from "@angular/core";
|
|
|
9
9
|
export * from './elder-toast.service';
|
|
10
10
|
export class ElderToastModule {
|
|
11
11
|
}
|
|
12
|
-
ElderToastModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
13
|
-
ElderToastModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.
|
|
14
|
-
ElderToastModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.
|
|
15
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
12
|
+
ElderToastModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderToastModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
ElderToastModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderToastModule, declarations: [StandardToastComponent], imports: [CommonModule, MatSnackBarModule, FlexModule, MatIconModule, MatButtonModule] });
|
|
14
|
+
ElderToastModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderToastModule, imports: [[CommonModule, MatSnackBarModule, FlexModule, MatIconModule, MatButtonModule]] });
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderToastModule, decorators: [{
|
|
16
16
|
type: NgModule,
|
|
17
17
|
args: [{
|
|
18
18
|
declarations: [StandardToastComponent],
|
|
@@ -20,4 +20,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
20
20
|
imports: [CommonModule, MatSnackBarModule, FlexModule, MatIconModule, MatButtonModule]
|
|
21
21
|
}]
|
|
22
22
|
}] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItdG9hc3QubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy90b2FzdHMvZWxkZXItdG9hc3QubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUNoRCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDckQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDBCQUEwQixDQUFDOztBQUV6RCxjQUFjLHVCQUF1QixDQUFDO0FBUXRDLE1BQU0sT0FBTyxnQkFBZ0I7OzhHQUFoQixnQkFBZ0I7K0dBQWhCLGdCQUFnQixpQkFKWixzQkFBc0IsYUFFM0IsWUFBWSxFQUFFLGlCQUFpQixFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsZUFBZTsrR0FFMUUsZ0JBQWdCLFlBRmxCLENBQUMsWUFBWSxFQUFFLGlCQUFpQixFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsZUFBZSxDQUFDOzRGQUUzRSxnQkFBZ0I7a0JBTDVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ3RDLE9BQU8sRUFBRyxFQUFFO29CQUNaLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLGVBQWUsQ0FBQztpQkFDdkYiLCJzb3VyY2VzQ29udGVudCI6WyJcblxuXG5pbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTWF0U25hY2tCYXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zbmFjay1iYXInO1xuaW1wb3J0IHsgU3RhbmRhcmRUb2FzdENvbXBvbmVudCB9IGZyb20gJy4vc3RhbmRhcmQtdG9hc3Qvc3RhbmRhcmQtdG9hc3QuY29tcG9uZW50JztcbmltcG9ydCB7RmxleE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZmxleC1sYXlvdXQnO1xuaW1wb3J0IHtNYXRJY29uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7TWF0QnV0dG9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuXG5leHBvcnQgKiBmcm9tICcuL2VsZGVyLXRvYXN0LnNlcnZpY2UnO1xuXG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1N0YW5kYXJkVG9hc3RDb21wb25lbnRdLFxuICBleHBvcnRzIDogW10sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hdFNuYWNrQmFyTW9kdWxlLCBGbGV4TW9kdWxlLCBNYXRJY29uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGVdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyVG9hc3RNb2R1bGUge1xuXG59XG4iXX0=
|
|
@@ -160,9 +160,9 @@ export class ElderToastService {
|
|
|
160
160
|
);
|
|
161
161
|
}
|
|
162
162
|
}
|
|
163
|
-
ElderToastService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
164
|
-
ElderToastService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.
|
|
165
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
163
|
+
ElderToastService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderToastService, deps: [{ token: i1.TranslateService }, { token: i2.MatSnackBar }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
164
|
+
ElderToastService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderToastService, providedIn: 'root' });
|
|
165
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderToastService, decorators: [{
|
|
166
166
|
type: Injectable,
|
|
167
167
|
args: [{
|
|
168
168
|
providedIn: 'root'
|
|
@@ -173,9 +173,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
173
173
|
*/
|
|
174
174
|
export class ToastService extends ElderToastService {
|
|
175
175
|
}
|
|
176
|
-
ToastService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
177
|
-
ToastService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.
|
|
178
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
176
|
+
ToastService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ToastService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
177
|
+
ToastService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ToastService, providedIn: 'root' });
|
|
178
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ToastService, decorators: [{
|
|
179
179
|
type: Injectable,
|
|
180
180
|
args: [{
|
|
181
181
|
providedIn: 'root'
|
|
@@ -186,12 +186,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
|
|
|
186
186
|
*/
|
|
187
187
|
export class EbsToastService extends ElderToastService {
|
|
188
188
|
}
|
|
189
|
-
EbsToastService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
|
190
|
-
EbsToastService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.
|
|
191
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
|
189
|
+
EbsToastService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: EbsToastService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
190
|
+
EbsToastService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: EbsToastService, providedIn: 'root' });
|
|
191
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: EbsToastService, decorators: [{
|
|
192
192
|
type: Injectable,
|
|
193
193
|
args: [{
|
|
194
194
|
providedIn: 'root'
|
|
195
195
|
}]
|
|
196
196
|
}] });
|
|
197
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-toast.service.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/toasts/elder-toast.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {Subject, Observable} from 'rxjs';\nimport {Toast} from './toast';\nimport {ToastType} from './toast-type';\nimport {TranslateService} from '@ngx-translate/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {catchError} from 'rxjs/operators';\nimport {MatSnackBar} from '@angular/material/snack-bar';\nimport {HttpErrorResponse} from '@angular/common/http';\nimport {IStandardErrorDetail} from '../../common/errors/standard-error-detail';\nimport {StandardToastComponent} from './standard-toast/standard-toast.component';\nimport {ErrorUtil} from '../errors/error-util';\n\nexport * from './toast';\nexport * from './toast-type';\n\nexport interface ToastErrorDetails {\n  status: string;\n  detail?: string;\n}\n\nexport interface ToastOptions {\n  msg?: string;\n  detail?: string;\n  interpolateParams?: Object;\n  displayDurationMs?: number;\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ElderToastService {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private subject = new Subject<Toast>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private translate: TranslateService,\n    private snackBar: MatSnackBar\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get notifications(): Observable<Toast> {\n    return this.subject.asObservable();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public info(msg: string, options?: ToastOptions): void {\n    options = this.prepareOptions(msg, options);\n    this.translateMessage(options).subscribe(\n      (translatedMsg) => this.toast({\n        status: 'Info',\n        message: translatedMsg,\n        detail: options.detail,\n        type: ToastType.Success\n      }, options?.displayDurationMs || 3000)\n    );\n  }\n\n  public warn(msg: string, options?: ToastOptions): void {\n    options = this.prepareOptions(msg, options);\n    this.translateMessage(options).subscribe(\n      (translatedMsg) => this.toast({\n        status: 'Warning',\n        message: translatedMsg,\n        detail: options.detail,\n        type: ToastType.Warning\n      }, options?.displayDurationMs || 5000)\n    );\n  }\n\n  public error(msg: string, error: any, options?: ToastOptions): void {\n\n    this.logger.error(msg, error);\n\n    options = this.prepareOptions(msg, options);\n    this.translateMessage(options).subscribe(\n      (translatedMsg) => {\n        const errDetail = this.errorToToast(error);\n        this.toast({\n          status: errDetail.status,\n          message: translatedMsg,\n          detail: errDetail.detail,\n          type: ToastType.Error\n        }, options?.displayDurationMs || 10000);\n      }\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API (Old)                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * @deprecated Use info()\n   */\n  public pushInfoRaw(msg: string): void {\n    this.info(msg);\n  }\n\n  /**\n   * @deprecated Use info()\n   */\n  public pushInfo(msgKey: string, interpolateParams?: Object) {\n    this.info(msgKey, interpolateParams);\n  }\n\n  /**\n   * @deprecated Use error()\n   */\n  public pushErrorRaw(msg: string, error?: any) {\n    this.error(msg, error);\n  }\n\n  /**\n   * @deprecated Use error()\n   */\n  public pushError(msgKey: string, interpolateParams?: any, error?: any) {\n    this.error(msgKey, error, interpolateParams);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private prepareOptions(msg: string, options?: ToastOptions): ToastOptions {\n    options = options ? options : {};\n    options.msg = msg;\n    return options;\n  }\n\n  private errorToToast(error: any): ToastErrorDetails {\n    const errorDetail = ErrorUtil.buildExceptionDetail(error);\n    if (errorDetail) {\n      return {\n        status: errorDetail.title,\n        detail: errorDetail.detail\n      };\n    } else {\n      return {\n        status: 'Unknown Error',\n        detail: JSON.stringify(error)\n      };\n    }\n\n  }\n\n  private toast(\n    toast: Toast,\n    durationMs: number\n  ): void {\n    this.subject.next(toast);\n    this.showToast(toast, durationMs);\n  }\n\n  private showToast(\n    toast: Toast,\n    durationMs: number = 5000\n  ): void {\n    this.snackBar.openFromComponent(\n      StandardToastComponent,\n      {\n        data: toast,\n        duration: durationMs,\n        panelClass: 'elder-primary-toast'\n      }\n    );\n    /*\n    this.snackBar.open(\n      toast.status + ': ' + toast.message + ' -> ' + toast.detail,\n      'OK', {\n        duration: 3000,\n        panelClass: this.toastClass(toast.type)\n      }\n      );*/\n  }\n\n  private toastClass(type: ToastType): string {\n    switch (type) {\n      case ToastType.Success:\n        return 'elder-success-toast';\n      case ToastType.Warning:\n        return 'elder-warning-toast';\n      case ToastType.Error:\n        return 'elder-error-toast';\n    }\n  }\n\n  private translateMessage(\n    options: ToastOptions\n  ): Observable<string> {\n    return this.translate.get(options.msg, options.interpolateParams)\n      .pipe(\n        catchError(err => options.msg) // // no translation found, we use the translation key\n      );\n  }\n\n}\n\n/**\n * @deprecated Please switch to ElderToastService\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class ToastService extends ElderToastService {\n}\n\n/**\n * @deprecated Please switch to EbsToastService\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class EbsToastService extends ElderToastService {\n}\n"]}
|
|
197
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-toast.service.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/toasts/elder-toast.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {Subject, Observable} from 'rxjs';\nimport {Toast} from './toast';\nimport {ToastType} from './toast-type';\nimport {TranslateService} from '@ngx-translate/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {catchError} from 'rxjs/operators';\nimport {MatSnackBar} from '@angular/material/snack-bar';\nimport {HttpErrorResponse} from '@angular/common/http';\nimport {IStandardErrorDetail} from '../../common/errors/standard-error-detail';\nimport {StandardToastComponent} from './standard-toast/standard-toast.component';\nimport {ErrorUtil} from '../errors/error-util';\n\nexport * from './toast';\nexport * from './toast-type';\n\nexport interface ToastErrorDetails {\n  status: string;\n  detail?: string;\n}\n\nexport interface ToastOptions {\n  msg?: string;\n  detail?: string;\n  interpolateParams?: Object;\n  displayDurationMs?: number;\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ElderToastService {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private subject = new Subject<Toast>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private translate: TranslateService,\n    private snackBar: MatSnackBar\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get notifications(): Observable<Toast> {\n    return this.subject.asObservable();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public info(msg: string, options?: ToastOptions): void {\n    options = this.prepareOptions(msg, options);\n    this.translateMessage(options).subscribe(\n      (translatedMsg) => this.toast({\n        status: 'Info',\n        message: translatedMsg,\n        detail: options.detail,\n        type: ToastType.Success\n      }, options?.displayDurationMs || 3000)\n    );\n  }\n\n  public warn(msg: string, options?: ToastOptions): void {\n    options = this.prepareOptions(msg, options);\n    this.translateMessage(options).subscribe(\n      (translatedMsg) => this.toast({\n        status: 'Warning',\n        message: translatedMsg,\n        detail: options.detail,\n        type: ToastType.Warning\n      }, options?.displayDurationMs || 5000)\n    );\n  }\n\n  public error(msg: string, error: any, options?: ToastOptions): void {\n\n    this.logger.error(msg, error);\n\n    options = this.prepareOptions(msg, options);\n    this.translateMessage(options).subscribe(\n      (translatedMsg) => {\n        const errDetail = this.errorToToast(error);\n        this.toast({\n          status: errDetail.status,\n          message: translatedMsg,\n          detail: errDetail.detail,\n          type: ToastType.Error\n        }, options?.displayDurationMs || 10000);\n      }\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API (Old)                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * @deprecated Use info()\n   */\n  public pushInfoRaw(msg: string): void {\n    this.info(msg);\n  }\n\n  /**\n   * @deprecated Use info()\n   */\n  public pushInfo(msgKey: string, interpolateParams?: Object) {\n    this.info(msgKey, interpolateParams);\n  }\n\n  /**\n   * @deprecated Use error()\n   */\n  public pushErrorRaw(msg: string, error?: any) {\n    this.error(msg, error);\n  }\n\n  /**\n   * @deprecated Use error()\n   */\n  public pushError(msgKey: string, interpolateParams?: any, error?: any) {\n    this.error(msgKey, error, interpolateParams);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private prepareOptions(msg: string, options?: ToastOptions): ToastOptions {\n    options = options ? options : {};\n    options.msg = msg;\n    return options;\n  }\n\n  private errorToToast(error: any): ToastErrorDetails {\n    const errorDetail = ErrorUtil.buildExceptionDetail(error);\n    if (errorDetail) {\n      return {\n        status: errorDetail.title,\n        detail: errorDetail.detail\n      };\n    } else {\n      return {\n        status: 'Unknown Error',\n        detail: JSON.stringify(error)\n      };\n    }\n\n  }\n\n  private toast(\n    toast: Toast,\n    durationMs: number\n  ): void {\n    this.subject.next(toast);\n    this.showToast(toast, durationMs);\n  }\n\n  private showToast(\n    toast: Toast,\n    durationMs: number = 5000\n  ): void {\n    this.snackBar.openFromComponent(\n      StandardToastComponent,\n      {\n        data: toast,\n        duration: durationMs,\n        panelClass: 'elder-primary-toast'\n      }\n    );\n    /*\n    this.snackBar.open(\n      toast.status + ': ' + toast.message + ' -> ' + toast.detail,\n      'OK', {\n        duration: 3000,\n        panelClass: this.toastClass(toast.type)\n      }\n      );*/\n  }\n\n  private toastClass(type: ToastType): string {\n    switch (type) {\n      case ToastType.Success:\n        return 'elder-success-toast';\n      case ToastType.Warning:\n        return 'elder-warning-toast';\n      case ToastType.Error:\n        return 'elder-error-toast';\n    }\n  }\n\n  private translateMessage(\n    options: ToastOptions\n  ): Observable<string> {\n    return this.translate.get(options.msg, options.interpolateParams)\n      .pipe(\n        catchError(err => options.msg) // // no translation found, we use the translation key\n      );\n  }\n\n}\n\n/**\n * @deprecated Please switch to ElderToastService\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class ToastService extends ElderToastService {\n}\n\n/**\n * @deprecated Please switch to EbsToastService\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class EbsToastService extends ElderToastService {\n}\n"]}
|