@elderbyte/ngx-starter 16.4.6 → 17.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/common/enums/elder-enum-translation.service.mjs +5 -5
- package/esm2022/lib/common/forms/elder-form-field-control-base.directive.mjs +5 -5
- package/esm2022/lib/common/forms/elder-from-field-base.mjs +5 -5
- package/esm2022/lib/common/forms/elder-from-field-customizable-base.mjs +4 -4
- package/esm2022/lib/common/forms/elder-from-field-entity-base.mjs +5 -5
- package/esm2022/lib/common/forms/elder-from-field-multi-entity-base.mjs +5 -5
- package/esm2022/lib/common/forms/form-field-base.component.mjs +4 -4
- package/esm2022/lib/common/forms/multi-model-base.component.mjs +4 -4
- package/esm2022/lib/common/forms/template-composite-control.mjs +4 -4
- package/esm2022/lib/common/forms/value-accessor-base.mjs +4 -4
- package/esm2022/lib/common/http/http-client-builder.service.mjs +5 -5
- package/esm2022/lib/common/http/http-client-pristine.mjs +5 -5
- package/esm2022/lib/common/http/transfer/data-transfer-factory.mjs +5 -5
- package/esm2022/lib/common/url/elder-router.service.mjs +5 -5
- package/esm2022/lib/common/url/elder-url-fragment-params.service.mjs +5 -5
- package/esm2022/lib/components/access-denied/elder-access-denied.component.mjs +5 -5
- package/esm2022/lib/components/access-denied/elder-access-denied.module.mjs +5 -5
- package/esm2022/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +5 -5
- package/esm2022/lib/components/auditing/elder-audit.module.mjs +5 -5
- package/esm2022/lib/components/badge/elder-badge/elder-badge.component.mjs +5 -5
- package/esm2022/lib/components/badge/elder-badge.directive.mjs +5 -5
- package/esm2022/lib/components/badge/elder-badge.module.mjs +5 -5
- package/esm2022/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +5 -5
- package/esm2022/lib/components/button-group/elder-button-group.module.mjs +5 -5
- package/esm2022/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +5 -5
- package/esm2022/lib/components/card-organizer/card-organizer/elder-stack-card.directive.mjs +5 -5
- package/esm2022/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +5 -5
- package/esm2022/lib/components/card-organizer/elder-card-organizer.module.mjs +5 -5
- package/esm2022/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +4 -4
- package/esm2022/lib/components/cards/elder-card/elder-card.component.mjs +20 -20
- package/esm2022/lib/components/cards/elder-card/elder-card.module.mjs +5 -5
- package/esm2022/lib/components/chips/elder-chip-label.directive.mjs +6 -6
- package/esm2022/lib/components/chips/elder-chips.module.mjs +5 -5
- package/esm2022/lib/components/connectivity/elder-connectivity.module.mjs +5 -5
- package/esm2022/lib/components/connectivity/elder-connectivity.service.mjs +5 -5
- package/esm2022/lib/components/connectivity/offline-indicator/elder-offline-indicator.component.mjs +5 -5
- package/esm2022/lib/components/containers/elder-containers.module.mjs +5 -5
- package/esm2022/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +5 -5
- package/esm2022/lib/components/csv/elder-csv-export-btn/elder-csv-export-btn.component.mjs +5 -5
- package/esm2022/lib/components/csv/elder-csv-stream-exporter-builder.service.mjs +5 -5
- package/esm2022/lib/components/csv/elder-csv.module.mjs +5 -5
- package/esm2022/lib/components/currency/elder-currency.module.mjs +5 -5
- package/esm2022/lib/components/currency/elder-currency.pipe.mjs +5 -5
- package/esm2022/lib/components/data-transfer/elder-data-transfer.module.mjs +5 -5
- package/esm2022/lib/components/data-transfer/elder-data-transfer.service.mjs +5 -5
- package/esm2022/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +5 -5
- package/esm2022/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +5 -5
- package/esm2022/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +5 -5
- package/esm2022/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +5 -5
- package/esm2022/lib/components/data-view/base/elder-data-view-base.mjs +5 -5
- package/esm2022/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +5 -5
- package/esm2022/lib/components/data-view/common/elder-data-common.module.mjs +5 -5
- package/esm2022/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +10 -10
- package/esm2022/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +5 -5
- package/esm2022/lib/components/data-view/common/selection/data-context-selection.directive.mjs +6 -6
- package/esm2022/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +5 -5
- package/esm2022/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +15 -15
- package/esm2022/lib/components/data-view/grid/elder-grid.module.mjs +5 -5
- package/esm2022/lib/components/data-view/master-detail/elder-detail-dialog/elder-detail-dialog.component.mjs +6 -6
- package/esm2022/lib/components/data-view/master-detail/elder-detail.directive.mjs +5 -5
- package/esm2022/lib/components/data-view/master-detail/elder-master-activation.directive.mjs +5 -5
- package/esm2022/lib/components/data-view/master-detail/elder-master-detail.component.mjs +5 -5
- package/esm2022/lib/components/data-view/master-detail/elder-master-detail.module.mjs +5 -5
- package/esm2022/lib/components/data-view/master-detail/elder-master-detail.service.mjs +5 -5
- package/esm2022/lib/components/data-view/master-detail/elder-master.directive.mjs +5 -5
- package/esm2022/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.component.mjs +6 -6
- package/esm2022/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +5 -5
- package/esm2022/lib/components/data-view/table/activation/elder-delete-active.directive.mjs +5 -5
- package/esm2022/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +5 -5
- package/esm2022/lib/components/data-view/table/elder-number-cell.directive.mjs +6 -6
- package/esm2022/lib/components/data-view/table/elder-paginator-intl.mjs +5 -5
- package/esm2022/lib/components/data-view/table/elder-table/elder-table-toolbar.directive.mjs +5 -5
- package/esm2022/lib/components/data-view/table/elder-table/elder-table.component.mjs +7 -7
- package/esm2022/lib/components/data-view/table/elder-table-column.directive.mjs +5 -5
- package/esm2022/lib/components/data-view/table/elder-table-extension.directive.mjs +6 -6
- package/esm2022/lib/components/data-view/table/elder-table-root.directive.mjs +5 -5
- package/esm2022/lib/components/data-view/table/elder-table-row.directive.mjs +5 -5
- package/esm2022/lib/components/data-view/table/elder-table-sort.directive.mjs +5 -5
- package/esm2022/lib/components/data-view/table/elder-table.module.mjs +5 -5
- package/esm2022/lib/components/data-view/table/model/elder-table-model.mjs +5 -5
- package/esm2022/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +5 -5
- package/esm2022/lib/components/dialogs/elder-dialog.module.mjs +5 -5
- package/esm2022/lib/components/dialogs/elder-dialog.service.mjs +5 -5
- package/esm2022/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +6 -6
- package/esm2022/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +6 -6
- package/esm2022/lib/components/dialogs/selection-dialog/elder-selection-dialog.directive.mjs +5 -5
- package/esm2022/lib/components/errors/elder-error.module.mjs +5 -5
- package/esm2022/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +5 -5
- package/esm2022/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +4 -4
- package/esm2022/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +5 -5
- package/esm2022/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +5 -5
- package/esm2022/lib/components/files/drag-n-drop/elder-drop-zone/elder-drop-zone.component.mjs +5 -5
- package/esm2022/lib/components/files/drag-n-drop/global-drag-drop.service.mjs +5 -5
- package/esm2022/lib/components/files/elder-file-drop-zone.directive.mjs +5 -5
- package/esm2022/lib/components/files/elder-file-select.directive.mjs +5 -5
- package/esm2022/lib/components/files/elder-file.module.mjs +5 -5
- package/esm2022/lib/components/files/file-select/file-select.component.mjs +5 -5
- package/esm2022/lib/components/files/file-upload/file-upload.component.mjs +5 -5
- package/esm2022/lib/components/forms/clipboard/elder-clipboard.service.mjs +5 -5
- package/esm2022/lib/components/forms/directives/base/elder-class-hostbinding-base.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-clipboard-put.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-delayed-focus.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-form-field-dense.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-form-field-label.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-form-field-no-hint.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-form-field-no-spinner.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-forms-directives.module.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-initial-value.directive.mjs +6 -6
- package/esm2022/lib/components/forms/directives/elder-input-pattern.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-key-event.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-next-focusable.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-plug-parent-form.directive.mjs +4 -4
- package/esm2022/lib/components/forms/directives/elder-stop-event-propagation.directive.mjs +4 -4
- package/esm2022/lib/components/forms/directives/elder-tab-focus-trap.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-touched.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +6 -6
- package/esm2022/lib/components/forms/directives/validation/elder-validation-error.directive.mjs +5 -5
- package/esm2022/lib/components/forms/directives/validation/strategies/common-validation-message-strategy.mjs +5 -5
- package/esm2022/lib/components/forms/directives/validation/strategies/dynamic-validation-message-strategy.mjs +5 -5
- package/esm2022/lib/components/forms/directives/validation/validation-message-renderer.service.mjs +5 -5
- package/esm2022/lib/components/forms/directives/validation/validators/elder-max.validator.mjs +4 -4
- package/esm2022/lib/components/forms/directives/validation/validators/elder-min.validator.mjs +4 -4
- package/esm2022/lib/components/forms/directives/validation/validators/elder-multiple-of.validator.mjs +4 -4
- package/esm2022/lib/components/forms/directives/validation/validators/elder-required-ignore-zero.validator.mjs +4 -4
- package/esm2022/lib/components/forms/elder-forms.module.mjs +5 -5
- package/esm2022/lib/components/forms/search/domain/context/search-context.service.mjs +5 -5
- package/esm2022/lib/components/forms/search/domain/url/elder-search-url.directive.mjs +5 -5
- package/esm2022/lib/components/forms/search/domain/url/elder-search-url.service.mjs +5 -5
- package/esm2022/lib/components/forms/search/elder-search-context.directive.mjs +5 -5
- package/esm2022/lib/components/forms/search/elder-search-input.directive.mjs +6 -6
- package/esm2022/lib/components/forms/search/elder-search.module.mjs +5 -5
- package/esm2022/lib/components/forms/search/search-box/elder-search-box.component.mjs +5 -5
- package/esm2022/lib/components/forms/search/search-box/elder-search-panel.component.mjs +5 -5
- package/esm2022/lib/components/global-search/elder-global-search.component.mjs +5 -5
- package/esm2022/lib/components/global-search/elder-global-search.module.mjs +5 -5
- package/esm2022/lib/components/global-search/elder-global-search.service.mjs +5 -5
- package/esm2022/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +5 -5
- package/esm2022/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +5 -5
- package/esm2022/lib/components/headers/elder-header/elder-header.component.mjs +5 -5
- package/esm2022/lib/components/headers/elder-header.module.mjs +5 -5
- package/esm2022/lib/components/http-support/elder-http-client.service.mjs +5 -5
- package/esm2022/lib/components/i18n/entities/elder-i18n-entities.module.mjs +5 -5
- package/esm2022/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +5 -5
- package/esm2022/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +6 -6
- package/esm2022/lib/components/i18n/entities/elder-localized-input-dialog.service.mjs +5 -5
- package/esm2022/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +5 -5
- package/esm2022/lib/components/i18n/entities/elder-localized-text-column.directive.mjs +5 -5
- package/esm2022/lib/components/i18n/entities/elder-localized-texts.directive.mjs +5 -5
- package/esm2022/lib/components/i18n/entities/picker/i18n-pick-async.pipe.mjs +5 -5
- package/esm2022/lib/components/i18n/entities/picker/i18n-pick.pipe.mjs +5 -5
- package/esm2022/lib/components/i18n/entities/picker/localisation-picker.service.mjs +5 -5
- package/esm2022/lib/components/i18n/language/elder-language-interceptor.mjs +5 -5
- package/esm2022/lib/components/i18n/language/elder-language.module.mjs +5 -5
- package/esm2022/lib/components/i18n/language/elder-language.service.mjs +5 -5
- package/esm2022/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +5 -5
- package/esm2022/lib/components/i18n/locales/elder-locales-de-ch.module.mjs +5 -5
- package/esm2022/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +6 -6
- package/esm2022/lib/components/iframes/data-view/data-view-iframe-adapter.directive.mjs +5 -5
- package/esm2022/lib/components/iframes/elder-iframe.module.mjs +5 -5
- package/esm2022/lib/components/iframes/iframe-close.directive.mjs +5 -5
- package/esm2022/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +6 -6
- package/esm2022/lib/components/iframes/iframe-host/iframe-host.component.mjs +5 -5
- package/esm2022/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +5 -5
- package/esm2022/lib/components/iframes/iframe.service.mjs +5 -5
- package/esm2022/lib/components/infinitescroll/elder-infinite-autocomplete.directive.mjs +6 -6
- package/esm2022/lib/components/infinitescroll/elder-infinite-scroll.directive.mjs +5 -5
- package/esm2022/lib/components/infinitescroll/elder-infinite-scroll.module.mjs +5 -5
- package/esm2022/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +5 -5
- package/esm2022/lib/components/input/autocomplete/elder-autocomplete-many.directive.mjs +5 -5
- package/esm2022/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +5 -5
- package/esm2022/lib/components/input/autocomplete/elder-autocomplete.module.mjs +5 -5
- package/esm2022/lib/components/labels/elder-labels.module.mjs +5 -5
- package/esm2022/lib/components/labels/labels-input/labels-input.component.mjs +5 -5
- package/esm2022/lib/components/measures/dimensions/dimensions-input/elder-dimensions-input.component.mjs +6 -6
- package/esm2022/lib/components/measures/dimensions/validation/elder-required-dimensions.validator.mjs +4 -4
- package/esm2022/lib/components/measures/directives/elder-unit-select.directive.mjs +5 -5
- package/esm2022/lib/components/measures/elder-measures.module.mjs +9 -9
- package/esm2022/lib/components/measures/elder-quantity-transform.pipe.mjs +5 -5
- package/esm2022/lib/components/measures/elder-quantity.pipe.mjs +5 -5
- package/esm2022/lib/components/measures/elder-unit.service.mjs +5 -5
- package/esm2022/lib/components/measures/quantity-input/quantity-form-field/elder-quantity-form-field.component.mjs +5 -5
- package/esm2022/lib/components/measures/quantity-input/quantity-input-control/elder-quantity-input-control.component.mjs +6 -6
- package/esm2022/lib/components/measures/quantity-input/validation/elder-quantity-range.validator.mjs +4 -4
- package/esm2022/lib/components/measures/quantity-input/validation/elder-required-quantity.validator.mjs +4 -4
- package/esm2022/lib/components/measures/util/elder-quantity.service.mjs +5 -5
- package/esm2022/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +5 -5
- package/esm2022/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +5 -5
- package/esm2022/lib/components/navigation/nav/elder-nav.module.mjs +5 -5
- package/esm2022/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +5 -5
- package/esm2022/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +5 -5
- package/esm2022/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +5 -5
- package/esm2022/lib/components/navigation/toolbar/elder-toolbar-column.directive.mjs +5 -5
- package/esm2022/lib/components/navigation/toolbar/elder-toolbar.module.mjs +5 -5
- package/esm2022/lib/components/navigation/toolbar/elder-toolbar.service.mjs +5 -5
- package/esm2022/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +5 -5
- package/esm2022/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.component.mjs +5 -5
- package/esm2022/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.service.mjs +5 -5
- package/esm2022/lib/components/overlays/elder-overlay-origin.directive.mjs +5 -5
- package/esm2022/lib/components/overlays/elder-overlay-trigger.directive.mjs +5 -5
- package/esm2022/lib/components/overlays/elder-overlay.component.mjs +5 -5
- package/esm2022/lib/components/overlays/elder-overlay.module.mjs +5 -5
- package/esm2022/lib/components/panels/card-panel/elder-card-panel.component.mjs +5 -5
- package/esm2022/lib/components/panels/elder-dialog-panel/elder-dialog-panel.component.mjs +5 -5
- package/esm2022/lib/components/panels/elder-panel.module.mjs +5 -5
- package/esm2022/lib/components/panels/flat/elder-panel.component.mjs +5 -5
- package/esm2022/lib/components/panels/toggle-panel/elder-toggle-panel-trigger.directive.mjs +5 -5
- package/esm2022/lib/components/panels/toggle-panel/elder-toggle-panel.component.mjs +12 -12
- package/esm2022/lib/components/scrollbar/elder-scrollbar.directive.mjs +5 -5
- package/esm2022/lib/components/scrollbar/elder-scrollbar.module.mjs +5 -5
- package/esm2022/lib/components/select/auto/elder-auto-select-first.directive.mjs +5 -5
- package/esm2022/lib/components/select/elder-select-base.mjs +5 -5
- package/esm2022/lib/components/select/elder-select-chip.directive.mjs +13 -13
- package/esm2022/lib/components/select/elder-select-on-tab.directive.mjs +6 -6
- package/esm2022/lib/components/select/elder-select-value.directive.mjs +5 -5
- package/esm2022/lib/components/select/elder-select.module.mjs +5 -5
- package/esm2022/lib/components/select/multi/elder-multi-select-base.mjs +5 -5
- package/esm2022/lib/components/select/multi/elder-multi-select-chip-options/elder-multi-select-chip-options.component.mjs +7 -7
- package/esm2022/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +7 -7
- package/esm2022/lib/components/select/multi/elder-multi-select-form-field.mjs +5 -5
- package/esm2022/lib/components/select/popup/selection-model-popup-trigger-adapter.directive.mjs +5 -5
- package/esm2022/lib/components/select/popup/selection-model-popup.directive.mjs +5 -5
- package/esm2022/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +6 -6
- package/esm2022/lib/components/select/single/elder-clear-select.directive.mjs +6 -6
- package/esm2022/lib/components/select/single/elder-select/elder-select.component.mjs +7 -7
- package/esm2022/lib/components/select/single/elder-select-form-field.mjs +5 -5
- package/esm2022/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +6 -6
- package/esm2022/lib/components/select-chip-list/elder-chip-list-select.module.mjs +5 -5
- package/esm2022/lib/components/shell/drawers/elder-route-outlet-drawer.service.mjs +5 -5
- package/esm2022/lib/components/shell/drawers/elder-router-outlet.service.mjs +5 -5
- package/esm2022/lib/components/shell/elder-shell-slot.directive.mjs +5 -5
- package/esm2022/lib/components/shell/elder-shell.module.mjs +5 -5
- package/esm2022/lib/components/shell/elder-shell.service.mjs +5 -5
- package/esm2022/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +5 -5
- package/esm2022/lib/components/shell/shell/elder-shell.component.mjs +17 -17
- package/esm2022/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.mjs +5 -5
- package/esm2022/lib/components/tabs/elder-tab/elder-tab.directive.mjs +5 -5
- package/esm2022/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.mjs +5 -5
- package/esm2022/lib/components/tabs/elder-tab.module.mjs +5 -5
- package/esm2022/lib/components/theme/elder-theme-applier.directive.mjs +5 -5
- package/esm2022/lib/components/theme/elder-theme-preference.service.mjs +5 -5
- package/esm2022/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.mjs +5 -5
- package/esm2022/lib/components/theme/elder-theme.directive.mjs +6 -6
- package/esm2022/lib/components/theme/elder-theme.module.mjs +5 -5
- package/esm2022/lib/components/theme/elder-theme.service.mjs +5 -5
- package/esm2022/lib/components/time/date-adapters/custom-date-adapter.mjs +6 -6
- package/esm2022/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +6 -6
- package/esm2022/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +5 -5
- package/esm2022/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +6 -6
- package/esm2022/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +6 -6
- package/esm2022/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +7 -7
- package/esm2022/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +6 -6
- package/esm2022/lib/components/time/elder-time.module.mjs +5 -5
- package/esm2022/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +6 -6
- package/esm2022/lib/components/time/pipes/to-iso-date-string.pipe.mjs +4 -4
- package/esm2022/lib/components/toasts/elder-toast.module.mjs +5 -5
- package/esm2022/lib/components/toasts/elder-toast.service.mjs +5 -5
- package/esm2022/lib/components/toasts/standard-toast/standard-toast.component.mjs +6 -6
- package/esm2022/lib/components/url-fragment/elder-url-fragment.module.mjs +5 -5
- package/esm2022/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +5 -5
- package/esm2022/lib/components/viewers/elder-svg-viewer/elder-svg-viewer.component.mjs +5 -5
- package/esm2022/lib/components/viewers/elder-viewers.module.mjs +5 -5
- package/esm2022/lib/features/event-source/elder-event-source.service.mjs +5 -5
- package/esm2022/lib/features/kafent/access-token-provider.mjs +5 -5
- package/esm2022/lib/features/kafent/kafent-config.mjs +4 -4
- package/esm2022/lib/features/kafent/kafent-event-stream.mjs +5 -5
- package/esm2022/lib/features/kafent/kafent-event.service.mjs +6 -6
- package/esm2022/lib/features/kafent/kafent.module.mjs +5 -5
- package/esm2022/lib/features/kafent/sse/kafent-event-stream-sse.service.mjs +5 -5
- package/esm2022/lib/pipes/bytes.pipe.mjs +4 -4
- package/esm2022/lib/pipes/elder-pipes.module.mjs +11 -11
- package/esm2022/lib/pipes/elder-repeat.pipe.mjs +4 -4
- package/esm2022/lib/pipes/elder-round.pipe.mjs +5 -5
- package/esm2022/lib/pipes/elder-safe-url.pipe.mjs +5 -5
- package/esm2022/lib/pipes/elder-truncate.pipe.mjs +4 -4
- package/esm2022/lib/pipes/iso-duration.pipe.mjs +5 -5
- package/esm2022/lib/pipes/iso-interval-parse.pipe.mjs +5 -5
- package/esm2022/lib/pipes/iso-interval.pipe.mjs +6 -6
- package/esm2022/lib/pipes/time-ago.pipe.mjs +5 -5
- package/esm2022/lib/pipes/time-duration.pipe.mjs +5 -5
- package/esm2022/lib/pipes/weight.pipe.mjs +4 -4
- package/fesm2022/elderbyte-ngx-starter.mjs +1208 -1208
- package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
- package/package.json +6 -6
package/esm2022/lib/components/data-view/common/selection/data-context-selection.directive.mjs
CHANGED
|
@@ -77,22 +77,22 @@ export class DataContextSelectionDirective {
|
|
|
77
77
|
return new MasterSelectionState(selection.length, selection.length >= currentData.length - unselectable.length, selection.length > 0 && selection.length < currentData.length - unselectable.length, selection.length > 0, model.isMultipleSelection);
|
|
78
78
|
}));
|
|
79
79
|
}
|
|
80
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
81
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
80
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: DataContextSelectionDirective, deps: [{ token: i1.SelectionModel, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
81
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.2", type: DataContextSelectionDirective, selector: "[elderDataContextSelection]", inputs: { selectionModel: ["elderDataContextSelectionModel", "selectionModel"], dataContext: ["elderDataContextSelection", "dataContext"] }, exportAs: ["elderDataContextSelection"], ngImport: i0 }); }
|
|
82
82
|
}
|
|
83
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
83
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: DataContextSelectionDirective, decorators: [{
|
|
84
84
|
type: Directive,
|
|
85
85
|
args: [{
|
|
86
86
|
selector: '[elderDataContextSelection]',
|
|
87
87
|
exportAs: 'elderDataContextSelection'
|
|
88
88
|
}]
|
|
89
|
-
}], ctorParameters:
|
|
89
|
+
}], ctorParameters: () => [{ type: i1.SelectionModel, decorators: [{
|
|
90
90
|
type: Optional
|
|
91
|
-
}] }]
|
|
91
|
+
}] }], propDecorators: { selectionModel: [{
|
|
92
92
|
type: Input,
|
|
93
93
|
args: ['elderDataContextSelectionModel']
|
|
94
94
|
}], dataContext: [{
|
|
95
95
|
type: Input,
|
|
96
96
|
args: ['elderDataContextSelection']
|
|
97
97
|
}] } });
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-selection.directive.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/common/selection/data-context-selection.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Input, Optional} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {SelectionModel} from '../../../../common/selection/selection-model';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {IDataContext} from '../../../../common/data/data-context/data-context';\nimport {MasterSelectionState} from './master-selection-state';\nimport {filter, map, switchMap} from 'rxjs/operators';\n\n@Directive({\n  selector: '[elderDataContextSelection]',\n  exportAs: 'elderDataContextSelection'\n})\nexport class DataContextSelectionDirective {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly selectionModel$ = new BehaviorSubject<SelectionModel<any>>(null);\n  private readonly dataContext$ = new BehaviorSubject<IDataContext<any>>(null);\n\n  public readonly selectionState$: Observable<MasterSelectionState>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    @Optional() selectionModel: SelectionModel<any>\n  ) {\n    this.selectionModel$.next(selectionModel);\n\n    this.selectionState$ = this.buildSelectionState$(\n      this.selectionModel$,\n      this.dataContext$\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input('elderDataContextSelectionModel')\n  public set selectionModel(model: SelectionModel<any>) {\n    this.selectionModel$.next(model);\n  }\n\n  public get selectionModel(): SelectionModel<any> {\n    return this.selectionModel$.getValue();\n  }\n\n  @Input('elderDataContextSelection')\n  public set dataContext(dataContext: IDataContext<any>) {\n    this.dataContext$.next(dataContext);\n  }\n\n  /** Whether the number of selected elements matches the totalSnapshot number of selectable rows. */\n  public get isAllSelectedSnapshot(): boolean {\n    const numSelected = this.selectionModel.selectionSnapshot.length;\n    const context = this.dataContext$.getValue();\n    const numRows = context ? context.snapshot.data.length : 0;\n    const numUnselectable = context ? context.snapshot.data.filter(i => !this.selectionModel.isSelectable(i)).length : 0;\n    return numSelected >= numRows - numUnselectable; // True if all selectable items are selected\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /** Selects all rows if they are not all selected; otherwise clear selection. */\n  public masterToggle(): void {\n    this.log.debug('masterToggle triggered, toggling all!');\n    if (this.isAllSelectedSnapshot) {\n      this.selectionModel.clear();\n    } else {\n      const context = this.dataContext$.getValue();\n      if (context) {\n        this.selectionModel.select(context.snapshot.data);\n      }\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private buildSelectionState$(\n    selectionModel$: Observable<SelectionModel<any>>,\n    dataContext$: Observable<IDataContext<any>>\n  ): Observable<MasterSelectionState> {\n    return combineLatest([selectionModel$, dataContext$]).pipe(\n        filter(([model, dc]) => !!model && !!dc),\n        switchMap(([model, dc]) => this.buildSelectionStateInner$(model, dc))\n    );\n  }\n\n  private buildSelectionStateInner$(\n    model: SelectionModel<any>,\n    dc: IDataContext<any>\n  ): Observable<MasterSelectionState> {\n    return  combineLatest([model.selection, dc.data]).pipe(\n      map(([selection, currentData]) => {\n        const unselectable = currentData.filter(i => !model.isSelectable(i));\n        return new MasterSelectionState(\n          selection.length,\n          selection.length >= currentData.length - unselectable.length,\n          selection.length > 0 && selection.length < currentData.length - unselectable.length,\n          selection.length > 0,\n          model.isMultipleSelection\n        );\n      })\n    );\n  }\n\n}\n"]}
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-selection.directive.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/common/selection/data-context-selection.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Input, Optional} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {SelectionModel} from '../../../../common/selection/selection-model';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {IDataContext} from '../../../../common/data/data-context/data-context';\nimport {MasterSelectionState} from './master-selection-state';\nimport {filter, map, switchMap} from 'rxjs/operators';\n\n@Directive({\n  selector: '[elderDataContextSelection]',\n  exportAs: 'elderDataContextSelection'\n})\nexport class DataContextSelectionDirective {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly selectionModel$ = new BehaviorSubject<SelectionModel<any>>(null);\n  private readonly dataContext$ = new BehaviorSubject<IDataContext<any>>(null);\n\n  public readonly selectionState$: Observable<MasterSelectionState>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    @Optional() selectionModel: SelectionModel<any>\n  ) {\n    this.selectionModel$.next(selectionModel);\n\n    this.selectionState$ = this.buildSelectionState$(\n      this.selectionModel$,\n      this.dataContext$\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input('elderDataContextSelectionModel')\n  public set selectionModel(model: SelectionModel<any>) {\n    this.selectionModel$.next(model);\n  }\n\n  public get selectionModel(): SelectionModel<any> {\n    return this.selectionModel$.getValue();\n  }\n\n  @Input('elderDataContextSelection')\n  public set dataContext(dataContext: IDataContext<any>) {\n    this.dataContext$.next(dataContext);\n  }\n\n  /** Whether the number of selected elements matches the totalSnapshot number of selectable rows. */\n  public get isAllSelectedSnapshot(): boolean {\n    const numSelected = this.selectionModel.selectionSnapshot.length;\n    const context = this.dataContext$.getValue();\n    const numRows = context ? context.snapshot.data.length : 0;\n    const numUnselectable = context ? context.snapshot.data.filter(i => !this.selectionModel.isSelectable(i)).length : 0;\n    return numSelected >= numRows - numUnselectable; // True if all selectable items are selected\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /** Selects all rows if they are not all selected; otherwise clear selection. */\n  public masterToggle(): void {\n    this.log.debug('masterToggle triggered, toggling all!');\n    if (this.isAllSelectedSnapshot) {\n      this.selectionModel.clear();\n    } else {\n      const context = this.dataContext$.getValue();\n      if (context) {\n        this.selectionModel.select(context.snapshot.data);\n      }\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private buildSelectionState$(\n    selectionModel$: Observable<SelectionModel<any>>,\n    dataContext$: Observable<IDataContext<any>>\n  ): Observable<MasterSelectionState> {\n    return combineLatest([selectionModel$, dataContext$]).pipe(\n        filter(([model, dc]) => !!model && !!dc),\n        switchMap(([model, dc]) => this.buildSelectionStateInner$(model, dc))\n    );\n  }\n\n  private buildSelectionStateInner$(\n    model: SelectionModel<any>,\n    dc: IDataContext<any>\n  ): Observable<MasterSelectionState> {\n    return  combineLatest([model.selection, dc.data]).pipe(\n      map(([selection, currentData]) => {\n        const unselectable = currentData.filter(i => !model.isSelectable(i));\n        return new MasterSelectionState(\n          selection.length,\n          selection.length >= currentData.length - unselectable.length,\n          selection.length > 0 && selection.length < currentData.length - unselectable.length,\n          selection.length > 0,\n          model.isMultipleSelection\n        );\n      })\n    );\n  }\n\n}\n"]}
|
|
@@ -28,11 +28,11 @@ export class ElderSelectionMasterCheckboxComponent {
|
|
|
28
28
|
**************************************************************************/
|
|
29
29
|
ngOnInit() {
|
|
30
30
|
}
|
|
31
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
32
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
31
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderSelectionMasterCheckboxComponent, deps: [{ token: i1.DataContextSelectionDirective }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
32
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: ElderSelectionMasterCheckboxComponent, selector: "elder-selection-master-checkbox", ngImport: i0, template: "<ng-container *ngIf=\"dataContextSelection?.selectionState$ | async as selectionState\">\n <div class=\"layout-row place-start-center\"\n *ngIf=\"selectionState.isMultiSelection\"\n [matBadgeHidden]=\"selectionState.count === 0\"\n [elderBadge]=\"selectionState.count + ''\"\n [matBadge]=\"selectionState.count + ''\"\n [matBadgePosition]=\"'above before'\"\n [matBadgeOverlap]=\"false\"\n [matBadgeSize]=\"'small'\"\n >\n <mat-checkbox (change)=\"$event ? dataContextSelection.masterToggle() : null\"\n [checked]=\"selectionState.allSelected\"\n [indeterminate]=\"selectionState.someSelected\"\n >\n </mat-checkbox>\n </div>\n</ng-container>\n", styles: [".mat-badge-small.mat-badge-above .mat-badge-content{top:-6px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i4.MatBadge, selector: "[matBadge]", inputs: ["matBadgeColor", "matBadgeOverlap", "matBadgeDisabled", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "directive", type: i5.ElderBadgeDirective, selector: "[elderBadge]", inputs: ["elderBadge"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
33
33
|
}
|
|
34
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderSelectionMasterCheckboxComponent, decorators: [{
|
|
35
35
|
type: Component,
|
|
36
36
|
args: [{ selector: 'elder-selection-master-checkbox', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"dataContextSelection?.selectionState$ | async as selectionState\">\n <div class=\"layout-row place-start-center\"\n *ngIf=\"selectionState.isMultiSelection\"\n [matBadgeHidden]=\"selectionState.count === 0\"\n [elderBadge]=\"selectionState.count + ''\"\n [matBadge]=\"selectionState.count + ''\"\n [matBadgePosition]=\"'above before'\"\n [matBadgeOverlap]=\"false\"\n [matBadgeSize]=\"'small'\"\n >\n <mat-checkbox (change)=\"$event ? dataContextSelection.masterToggle() : null\"\n [checked]=\"selectionState.allSelected\"\n [indeterminate]=\"selectionState.someSelected\"\n >\n </mat-checkbox>\n </div>\n</ng-container>\n", styles: [".mat-badge-small.mat-badge-above .mat-badge-content{top:-6px}\n"] }]
|
|
37
|
-
}], ctorParameters:
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
}], ctorParameters: () => [{ type: i1.DataContextSelectionDirective }] });
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItc2VsZWN0aW9uLW1hc3Rlci1jaGVja2JveC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy9jb21tb24vc2VsZWN0aW9uL2VsZGVyLXNlbGVjdGlvbi1tYXN0ZXItY2hlY2tib3gvZWxkZXItc2VsZWN0aW9uLW1hc3Rlci1jaGVja2JveC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy9jb21tb24vc2VsZWN0aW9uL2VsZGVyLXNlbGVjdGlvbi1tYXN0ZXItY2hlY2tib3gvZWxkZXItc2VsZWN0aW9uLW1hc3Rlci1jaGVja2JveC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFTLE1BQU0sZUFBZSxDQUFDO0FBQ3pFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7OztBQVNuRCxNQUFNLE9BQU8scUNBQXFDO0lBVWhEOzs7O2dGQUk0RTtJQUU1RSxZQUNrQixvQkFBbUQ7UUFBbkQseUJBQW9CLEdBQXBCLG9CQUFvQixDQUErQjtRQWZyRTs7OztvRkFJNEU7UUFFM0QsV0FBTSxHQUFHLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQVVyRSxDQUFDO0lBRUw7Ozs7Z0ZBSTRFO0lBRXJFLFFBQVE7SUFFZixDQUFDOzhHQTVCVSxxQ0FBcUM7a0dBQXJDLHFDQUFxQyx1RUNWbEQseXNCQWlCQTs7MkZEUGEscUNBQXFDO2tCQU5qRCxTQUFTOytCQUNFLGlDQUFpQyxtQkFHMUIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TG9nZ2VyRmFjdG9yeX0gZnJvbSAnQGVsZGVyYnl0ZS90cy1sb2dnZXInO1xuaW1wb3J0IHtEYXRhQ29udGV4dFNlbGVjdGlvbkRpcmVjdGl2ZX0gZnJvbSAnLi4vZGF0YS1jb250ZXh0LXNlbGVjdGlvbi5kaXJlY3RpdmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdlbGRlci1zZWxlY3Rpb24tbWFzdGVyLWNoZWNrYm94JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2VsZGVyLXNlbGVjdGlvbi1tYXN0ZXItY2hlY2tib3guY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9lbGRlci1zZWxlY3Rpb24tbWFzdGVyLWNoZWNrYm94LmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyU2VsZWN0aW9uTWFzdGVyQ2hlY2tib3hDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBGaWVsZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgbG9nZ2VyID0gTG9nZ2VyRmFjdG9yeS5nZXRMb2dnZXIodGhpcy5jb25zdHJ1Y3Rvci5uYW1lKTtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgcmVhZG9ubHkgZGF0YUNvbnRleHRTZWxlY3Rpb246IERhdGFDb250ZXh0U2VsZWN0aW9uRGlyZWN0aXZlXG4gICkgeyB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIExpZmUgQ3ljbGUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuXG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogUHJvcGVydGllcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogUHVibGljIEFQSSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxufVxuIiwiPG5nLWNvbnRhaW5lciAqbmdJZj1cImRhdGFDb250ZXh0U2VsZWN0aW9uPy5zZWxlY3Rpb25TdGF0ZSQgfCBhc3luYyBhcyBzZWxlY3Rpb25TdGF0ZVwiPlxuICA8ZGl2IGNsYXNzPVwibGF5b3V0LXJvdyBwbGFjZS1zdGFydC1jZW50ZXJcIlxuICAgICpuZ0lmPVwic2VsZWN0aW9uU3RhdGUuaXNNdWx0aVNlbGVjdGlvblwiXG4gICAgW21hdEJhZGdlSGlkZGVuXT1cInNlbGVjdGlvblN0YXRlLmNvdW50ID09PSAwXCJcbiAgICBbZWxkZXJCYWRnZV09XCJzZWxlY3Rpb25TdGF0ZS5jb3VudCArICcnXCJcbiAgICBbbWF0QmFkZ2VdPVwic2VsZWN0aW9uU3RhdGUuY291bnQgKyAnJ1wiXG4gICAgW21hdEJhZGdlUG9zaXRpb25dPVwiJ2Fib3ZlIGJlZm9yZSdcIlxuICAgIFttYXRCYWRnZU92ZXJsYXBdPVwiZmFsc2VcIlxuICAgIFttYXRCYWRnZVNpemVdPVwiJ3NtYWxsJ1wiXG4gID5cbiAgICA8bWF0LWNoZWNrYm94IChjaGFuZ2UpPVwiJGV2ZW50ID8gZGF0YUNvbnRleHRTZWxlY3Rpb24ubWFzdGVyVG9nZ2xlKCkgOiBudWxsXCJcbiAgICAgICAgICAgICAgICAgIFtjaGVja2VkXT1cInNlbGVjdGlvblN0YXRlLmFsbFNlbGVjdGVkXCJcbiAgICAgICAgICAgICAgICAgIFtpbmRldGVybWluYXRlXT1cInNlbGVjdGlvblN0YXRlLnNvbWVTZWxlY3RlZFwiXG4gICAgPlxuICAgIDwvbWF0LWNoZWNrYm94PlxuICA8L2Rpdj5cbjwvbmctY29udGFpbmVyPlxuIl19
|
|
@@ -31,13 +31,13 @@ export class ElderGridTileDirective {
|
|
|
31
31
|
this.templateRef = templateRef;
|
|
32
32
|
this.viewContainer = viewContainer;
|
|
33
33
|
}
|
|
34
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
35
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
34
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderGridTileDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
35
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.2", type: ElderGridTileDirective, selector: "[elderGridTile]", ngImport: i0 }); }
|
|
36
36
|
}
|
|
37
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderGridTileDirective, decorators: [{
|
|
38
38
|
type: Directive,
|
|
39
39
|
args: [{ selector: '[elderGridTile]' }]
|
|
40
|
-
}], ctorParameters:
|
|
40
|
+
}], ctorParameters: () => [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }] });
|
|
41
41
|
/**
|
|
42
42
|
* This directive projects marked content into a toolbar.
|
|
43
43
|
*/
|
|
@@ -46,13 +46,13 @@ export class ElderGridToolbarDirective {
|
|
|
46
46
|
this.templateRef = templateRef;
|
|
47
47
|
this.viewContainer = viewContainer;
|
|
48
48
|
}
|
|
49
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
50
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
49
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderGridToolbarDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
50
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.2", type: ElderGridToolbarDirective, selector: "[elderGridToolbar]", ngImport: i0 }); }
|
|
51
51
|
}
|
|
52
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
52
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderGridToolbarDirective, decorators: [{
|
|
53
53
|
type: Directive,
|
|
54
54
|
args: [{ selector: '[elderGridToolbar]' }]
|
|
55
|
-
}], ctorParameters:
|
|
55
|
+
}], ctorParameters: () => [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }] });
|
|
56
56
|
export class ElderGridComponent extends ElderDataViewBaseComponent {
|
|
57
57
|
/***************************************************************************
|
|
58
58
|
* *
|
|
@@ -241,15 +241,15 @@ export class ElderGridComponent extends ElderDataViewBaseComponent {
|
|
|
241
241
|
});
|
|
242
242
|
return columnCount;
|
|
243
243
|
}
|
|
244
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
245
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
244
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderGridComponent, deps: [{ token: i1.SelectionModel, optional: true }, { token: i2.ElderDataViewOptionsProvider, optional: true, skipSelf: true }, { token: i3.BreakpointObserver }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
245
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: ElderGridComponent, selector: "elder-grid", inputs: { toolbarVisible: "toolbarVisible", footerVisible: "footerVisible", itemHeight: "itemHeight", responsiveColumnCount: "responsiveColumnCount", availableSorts: "availableSorts", sortTranslationPrefix: "sortTranslationPrefix", hiddenField: "hiddenField", idField: "idField", selectionVisible: "selectionVisible", pageSizeOptions: "pageSizeOptions", tileTemplate: "tileTemplate", toolbarTemplate: "toolbarTemplate", data: "data", columnCount: "columnCount" }, providers: [
|
|
246
246
|
{
|
|
247
247
|
provide: ELDER_DATA_VIEW,
|
|
248
248
|
useExisting: forwardRef(() => ElderGridComponent)
|
|
249
249
|
}
|
|
250
|
-
], queries: [{ propertyName: "tileTemplateQuery", first: true, predicate: ElderGridTileDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "toolbarTemplateQuery", first: true, predicate: ElderGridToolbarDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "virtualScrollViewPort", first: true, predicate: ["virtualScrollViewPort"], descendants: true, static: true }, { propertyName: "matPaginator", first: true, predicate: MatPaginator, descendants: true }], usesInheritance: true, ngImport: i0, template: "<mat-card class=\"full\"\n [class.embedded]=\"embedded\"\n [appearance]=\"appearance\"\n style=\"overflow: hidden\"\n>\n <!-- Grid Browser -->\n <div class=\"layout-col full elder-grid-container\"\n *ngIf=\"dataContext$ | async as data\"\n [elderDataContextSelection]=\"data\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n <!-- Toolbar Row -->\n <div *ngIf=\"toolbarVisible\"\n class=\"layout-row place-start-center flex-none elder-grid-toolbar\">\n\n <div class=\"layout-col flex-none\" style=\"padding-left: 8px; padding-right: 8px\" *ngIf=\"selectionVisible\">\n <elder-selection-master-checkbox class=\"flex-none\" style=\"padding-left: 12px\"></elder-selection-master-checkbox>\n </div>\n\n <!-- Toolbar -->\n <ng-container *ngIf=\"toolbarTemplate\">\n <ng-template *ngTemplateOutlet=\"toolbarTemplate; context: {$implicit: this}\"></ng-template>\n </ng-container>\n\n <elder-single-sort *ngIf=\"availableSorts && availableSorts.length > 0 && data.sort.sorts | async as sorts\"\n class=\"flex-none\"\n [availableSorts]=\"availableSorts\"\n [translationPrefix]=\"sortTranslationPrefix\"\n [sort]=\"sorts[0]\"\n (sortChange)=\"updateSort($event)\">\n </elder-single-sort>\n </div>\n\n <mat-divider *ngIf=\"toolbarVisible\"></mat-divider>\n\n <elder-data-context-state-indicator class=\"flex-none\" [dataContext]=\"data\">\n </elder-data-context-state-indicator>\n\n <!-- [cdkDropListSortingDisabled]=\"true\" -->\n <!-- cdkDropList -->\n <cdk-virtual-scroll-viewport\n class=\"layout-col flex elder-grid-browser\"\n id=\"documents-container\"\n [itemSize]=\"itemHeight\"\n [minBufferPx]=\"itemHeight * 2\"\n [maxBufferPx]=\"itemHeight * 3\"\n #virtualScrollViewPort\n elderInfiniteScroll\n [eventThrottle]=\"200\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"data.loading | async\"\n [containerId]=\"'documents-container'\" [listenToHost]=\"false\"\n (closeToEnd)=\"requestMoreDataZoned($event)\">\n\n <!-- (scrolling)=\"onScrolling($event)\" -->\n\n <div\n *cdkVirtualFor=\"let row of dataRows$; trackBy: trackByIndex; templateCacheSize: 50\"\n class=\"elder-grid-tile-row\"\n [style.height]=\"itemHeight + 'px'\">\n\n <ng-container *ngFor=\"let tile of row; trackBy: trackByFn\">\n\n <!-- Tile Cell -->\n <mat-card appearance=\"outlined\" *ngIf=\"showTile(tile)\" class=\"elder-grid-tile\">\n <div class=\"elder-grid-tile-content\"\n (click)=\"onItemClick(tile)\"\n (dblclick)=\"onItemDoubleClick(tile)\">\n <ng-container\n *ngTemplateOutlet=\"tileTemplate || simpleTileTemplate; context: {$implicit: tile}\">\n </ng-container>\n\n <!-- Overlay (Selection) -->\n <ng-container *ngIf=\"selectionVisible\">\n <div *ngIf=\"selectionModel.selection | async as selection\"\n class=\"elder-grid-tile-overlay elder-click-through\"\n [class.elder-grid-tile-overlay-hidden]=\"!inSelectionMode(selection)\"\n [class.elder-grid-tile-overlay-visible]=\"inSelectionMode(selection)\"\n >\n <button mat-icon-button type=\"button\"\n (click)=\"selectionModel.toggle(tile)\" elderStopEventPropagation\n class=\"elder-grid-tile-check\">\n <mat-icon\n [class.elder-selected]=\"(selectionModel.observeSelection(tile) | async)\"\n >\n {{(selectionModel.observeSelection(tile) | async) ? 'check_circle' : 'radio_button_unchecked'}}\n </mat-icon>\n </button>\n </div>\n </ng-container>\n\n </div>\n </mat-card>\n\n <div *ngIf=\"!showTile(tile)\" class=\"elder-grid-tile-hidden\"></div>\n </ng-container>\n\n </div>\n\n </cdk-virtual-scroll-viewport>\n\n\n <mat-progress-bar class=\"flex-none\"\n [mode]=\"(data?.loading | async) ? 'indeterminate' : 'determinate'\"\n [color]=\"(data && (data.status | async)?.hasError) ? 'warn' : 'primary'\">\n </mat-progress-bar>\n\n <!-- Footer -->\n <div class=\"layout-row place-end-center gap-md flex-none elder-grid-footer\"\n *ngIf=\"footerVisible\"\n style=\"padding-right: 12px\">\n\n <!-- Continuable -->\n <ng-container *ngIf=\"isContinuable\">\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataSnapshot?.data | async)?.length}} / {{total$ | async}}\n </span>\n\n <button mat-icon-button type=\"button\"\n color=\"primary\"\n [disabled]=\"!(canLoadMore$ | async)\"\n (click)=\"dataSnapshot.loadMore()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n </button>\n </ng-container>\n\n <!-- Paged -->\n <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n class=\"flex-none\"\n [length]=\"dataContext?.total | async\"\n [pageIndex]=\"page?.index\"\n [pageSize]=\"page?.size\"\n [pageSizeOptions]=\"pageSizeOptions\">\n </mat-paginator>\n\n <!-- Local Source -->\n <ng-container *ngIf=\"!isActivePaged && !isContinuable\">\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataSnapshot?.data | async)?.length}}\n </span>\n </ng-container>\n\n </div>\n\n\n </div>\n</mat-card>\n\n<ng-template #simpleTileTemplate let-tile>\n <div *ngIf=\"tile\" class=\"layout-col place-center-center flex\" style=\"background-color: lightblue\">\n <p class=\"noselect\">Tile: {{tile}}</p>\n </div>\n</ng-template>\n", styles: [":host{min-width:0;min-height:0}.elder-grid-tile-row{display:flex;flex-direction:row;padding:8px}.elder-grid-tile-row:first-child{padding-top:16px}.elder-grid-tile-hidden{flex:0 1 100%;margin:8px;width:100%;height:100%}.elder-grid-tile-content{position:relative;width:100%;height:100%;overflow:hidden}.elder-grid-tile-overlay{position:absolute;inset:0;transition:background-color .1s ease-in,opacity .1s ease-in}.elder-click-through{pointer-events:none}.elder-grid-tile-overlay-visible{opacity:1}.elder-grid-tile-overlay-hidden{opacity:0}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i6.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i9.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i9.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i9.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "component", type: i10.ElderSingleSortComponent, selector: "elder-single-sort", inputs: ["availableSorts", "translationPrefix", "sort"], outputs: ["sortChange"] }, { kind: "component", type: i11.ElderSelectionMasterCheckboxComponent, selector: "elder-selection-master-checkbox" }, { kind: "directive", type: i12.DataContextSelectionDirective, selector: "[elderDataContextSelection]", inputs: ["elderDataContextSelectionModel", "elderDataContextSelection"], exportAs: ["elderDataContextSelection"] }, { kind: "component", type: i13.DataContextStateIndicatorComponent, selector: "elder-data-context-state-indicator", inputs: ["dataContext"] }, { kind: "directive", type: i14.ElderInfiniteScrollDirective, selector: "[elderInfiniteScroll]", inputs: ["listenToHost", "eventThrottle", "offsetFactor", "ignoreScrollEvent", "containerId", "scrollContainer"], outputs: ["closeToEnd", "scrolling"] }, { kind: "directive", type: i15.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "component", type: i16.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: i17.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
250
|
+
], queries: [{ propertyName: "tileTemplateQuery", first: true, predicate: ElderGridTileDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "toolbarTemplateQuery", first: true, predicate: ElderGridToolbarDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "virtualScrollViewPort", first: true, predicate: ["virtualScrollViewPort"], descendants: true, static: true }, { propertyName: "matPaginator", first: true, predicate: MatPaginator, descendants: true }], usesInheritance: true, ngImport: i0, template: "<mat-card class=\"full\"\n [class.embedded]=\"embedded\"\n [appearance]=\"appearance\"\n style=\"overflow: hidden\"\n>\n <!-- Grid Browser -->\n <div class=\"layout-col full elder-grid-container\"\n *ngIf=\"dataContext$ | async as data\"\n [elderDataContextSelection]=\"data\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n <!-- Toolbar Row -->\n <div *ngIf=\"toolbarVisible\"\n class=\"layout-row place-start-center flex-none elder-grid-toolbar\">\n\n <div class=\"layout-col flex-none\" style=\"padding-left: 8px; padding-right: 8px\" *ngIf=\"selectionVisible\">\n <elder-selection-master-checkbox class=\"flex-none\" style=\"padding-left: 12px\"></elder-selection-master-checkbox>\n </div>\n\n <!-- Toolbar -->\n <ng-container *ngIf=\"toolbarTemplate\">\n <ng-template *ngTemplateOutlet=\"toolbarTemplate; context: {$implicit: this}\"></ng-template>\n </ng-container>\n\n <elder-single-sort *ngIf=\"availableSorts && availableSorts.length > 0 && data.sort.sorts | async as sorts\"\n class=\"flex-none\"\n [availableSorts]=\"availableSorts\"\n [translationPrefix]=\"sortTranslationPrefix\"\n [sort]=\"sorts[0]\"\n (sortChange)=\"updateSort($event)\">\n </elder-single-sort>\n </div>\n\n <mat-divider *ngIf=\"toolbarVisible\"></mat-divider>\n\n <elder-data-context-state-indicator class=\"flex-none\" [dataContext]=\"data\">\n </elder-data-context-state-indicator>\n\n <!-- [cdkDropListSortingDisabled]=\"true\" -->\n <!-- cdkDropList -->\n <cdk-virtual-scroll-viewport\n class=\"layout-col flex elder-grid-browser\"\n id=\"documents-container\"\n [itemSize]=\"itemHeight\"\n [minBufferPx]=\"itemHeight * 2\"\n [maxBufferPx]=\"itemHeight * 3\"\n #virtualScrollViewPort\n elderInfiniteScroll\n [eventThrottle]=\"200\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"data.loading | async\"\n [containerId]=\"'documents-container'\" [listenToHost]=\"false\"\n (closeToEnd)=\"requestMoreDataZoned($event)\">\n\n <!-- (scrolling)=\"onScrolling($event)\" -->\n\n <div\n *cdkVirtualFor=\"let row of dataRows$; trackBy: trackByIndex; templateCacheSize: 50\"\n class=\"elder-grid-tile-row\"\n [style.height]=\"itemHeight + 'px'\">\n\n <ng-container *ngFor=\"let tile of row; trackBy: trackByFn\">\n\n <!-- Tile Cell -->\n <mat-card appearance=\"outlined\" *ngIf=\"showTile(tile)\" class=\"elder-grid-tile\">\n <div class=\"elder-grid-tile-content\"\n (click)=\"onItemClick(tile)\"\n (dblclick)=\"onItemDoubleClick(tile)\">\n <ng-container\n *ngTemplateOutlet=\"tileTemplate || simpleTileTemplate; context: {$implicit: tile}\">\n </ng-container>\n\n <!-- Overlay (Selection) -->\n <ng-container *ngIf=\"selectionVisible\">\n <div *ngIf=\"selectionModel.selection | async as selection\"\n class=\"elder-grid-tile-overlay elder-click-through\"\n [class.elder-grid-tile-overlay-hidden]=\"!inSelectionMode(selection)\"\n [class.elder-grid-tile-overlay-visible]=\"inSelectionMode(selection)\"\n >\n <button mat-icon-button type=\"button\"\n (click)=\"selectionModel.toggle(tile)\" elderStopEventPropagation\n class=\"elder-grid-tile-check\">\n <mat-icon\n [class.elder-selected]=\"(selectionModel.observeSelection(tile) | async)\"\n >\n {{(selectionModel.observeSelection(tile) | async) ? 'check_circle' : 'radio_button_unchecked'}}\n </mat-icon>\n </button>\n </div>\n </ng-container>\n\n </div>\n </mat-card>\n\n <div *ngIf=\"!showTile(tile)\" class=\"elder-grid-tile-hidden\"></div>\n </ng-container>\n\n </div>\n\n </cdk-virtual-scroll-viewport>\n\n\n <mat-progress-bar class=\"flex-none\"\n [mode]=\"(data?.loading | async) ? 'indeterminate' : 'determinate'\"\n [color]=\"(data && (data.status | async)?.hasError) ? 'warn' : 'primary'\">\n </mat-progress-bar>\n\n <!-- Footer -->\n <div class=\"layout-row place-end-center gap-md flex-none elder-grid-footer\"\n *ngIf=\"footerVisible\"\n style=\"padding-right: 12px\">\n\n <!-- Continuable -->\n <ng-container *ngIf=\"isContinuable\">\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataSnapshot?.data | async)?.length}} / {{total$ | async}}\n </span>\n\n <button mat-icon-button type=\"button\"\n color=\"primary\"\n [disabled]=\"!(canLoadMore$ | async)\"\n (click)=\"dataSnapshot.loadMore()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n </button>\n </ng-container>\n\n <!-- Paged -->\n <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n class=\"flex-none\"\n [length]=\"dataContext?.total | async\"\n [pageIndex]=\"page?.index\"\n [pageSize]=\"page?.size\"\n [pageSizeOptions]=\"pageSizeOptions\">\n </mat-paginator>\n\n <!-- Local Source -->\n <ng-container *ngIf=\"!isActivePaged && !isContinuable\">\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataSnapshot?.data | async)?.length}}\n </span>\n </ng-container>\n\n </div>\n\n\n </div>\n</mat-card>\n\n<ng-template #simpleTileTemplate let-tile>\n <div *ngIf=\"tile\" class=\"layout-col place-center-center flex\" style=\"background-color: lightblue\">\n <p class=\"noselect\">Tile: {{tile}}</p>\n </div>\n</ng-template>\n", styles: [":host{min-width:0;min-height:0}.elder-grid-tile-row{display:flex;flex-direction:row;padding:8px}.elder-grid-tile-row:first-child{padding-top:16px}.elder-grid-tile-hidden{flex:0 1 100%;margin:8px;width:100%;height:100%}.elder-grid-tile-content{position:relative;width:100%;height:100%;overflow:hidden}.elder-grid-tile-overlay{position:absolute;inset:0;transition:background-color .1s ease-in,opacity .1s ease-in}.elder-click-through{pointer-events:none}.elder-grid-tile-overlay-visible{opacity:1}.elder-grid-tile-overlay-hidden{opacity:0}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i6.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i9.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i9.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i9.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "component", type: i10.ElderSingleSortComponent, selector: "elder-single-sort", inputs: ["availableSorts", "translationPrefix", "sort"], outputs: ["sortChange"] }, { kind: "component", type: i11.ElderSelectionMasterCheckboxComponent, selector: "elder-selection-master-checkbox" }, { kind: "directive", type: i12.DataContextSelectionDirective, selector: "[elderDataContextSelection]", inputs: ["elderDataContextSelectionModel", "elderDataContextSelection"], exportAs: ["elderDataContextSelection"] }, { kind: "component", type: i13.DataContextStateIndicatorComponent, selector: "elder-data-context-state-indicator", inputs: ["dataContext"] }, { kind: "directive", type: i14.ElderInfiniteScrollDirective, selector: "[elderInfiniteScroll]", inputs: ["listenToHost", "eventThrottle", "offsetFactor", "ignoreScrollEvent", "containerId", "scrollContainer"], outputs: ["closeToEnd", "scrolling"] }, { kind: "directive", type: i15.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "component", type: i16.MatPaginator, selector: "mat-paginator", inputs: ["disabled", "color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig"], outputs: ["page"], exportAs: ["matPaginator"] }, { kind: "component", type: i17.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
251
251
|
}
|
|
252
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
252
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderGridComponent, decorators: [{
|
|
253
253
|
type: Component,
|
|
254
254
|
args: [{ selector: 'elder-grid', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
255
255
|
{
|
|
@@ -257,13 +257,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
257
257
|
useExisting: forwardRef(() => ElderGridComponent)
|
|
258
258
|
}
|
|
259
259
|
], template: "<mat-card class=\"full\"\n [class.embedded]=\"embedded\"\n [appearance]=\"appearance\"\n style=\"overflow: hidden\"\n>\n <!-- Grid Browser -->\n <div class=\"layout-col full elder-grid-container\"\n *ngIf=\"dataContext$ | async as data\"\n [elderDataContextSelection]=\"data\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n <!-- Toolbar Row -->\n <div *ngIf=\"toolbarVisible\"\n class=\"layout-row place-start-center flex-none elder-grid-toolbar\">\n\n <div class=\"layout-col flex-none\" style=\"padding-left: 8px; padding-right: 8px\" *ngIf=\"selectionVisible\">\n <elder-selection-master-checkbox class=\"flex-none\" style=\"padding-left: 12px\"></elder-selection-master-checkbox>\n </div>\n\n <!-- Toolbar -->\n <ng-container *ngIf=\"toolbarTemplate\">\n <ng-template *ngTemplateOutlet=\"toolbarTemplate; context: {$implicit: this}\"></ng-template>\n </ng-container>\n\n <elder-single-sort *ngIf=\"availableSorts && availableSorts.length > 0 && data.sort.sorts | async as sorts\"\n class=\"flex-none\"\n [availableSorts]=\"availableSorts\"\n [translationPrefix]=\"sortTranslationPrefix\"\n [sort]=\"sorts[0]\"\n (sortChange)=\"updateSort($event)\">\n </elder-single-sort>\n </div>\n\n <mat-divider *ngIf=\"toolbarVisible\"></mat-divider>\n\n <elder-data-context-state-indicator class=\"flex-none\" [dataContext]=\"data\">\n </elder-data-context-state-indicator>\n\n <!-- [cdkDropListSortingDisabled]=\"true\" -->\n <!-- cdkDropList -->\n <cdk-virtual-scroll-viewport\n class=\"layout-col flex elder-grid-browser\"\n id=\"documents-container\"\n [itemSize]=\"itemHeight\"\n [minBufferPx]=\"itemHeight * 2\"\n [maxBufferPx]=\"itemHeight * 3\"\n #virtualScrollViewPort\n elderInfiniteScroll\n [eventThrottle]=\"200\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"data.loading | async\"\n [containerId]=\"'documents-container'\" [listenToHost]=\"false\"\n (closeToEnd)=\"requestMoreDataZoned($event)\">\n\n <!-- (scrolling)=\"onScrolling($event)\" -->\n\n <div\n *cdkVirtualFor=\"let row of dataRows$; trackBy: trackByIndex; templateCacheSize: 50\"\n class=\"elder-grid-tile-row\"\n [style.height]=\"itemHeight + 'px'\">\n\n <ng-container *ngFor=\"let tile of row; trackBy: trackByFn\">\n\n <!-- Tile Cell -->\n <mat-card appearance=\"outlined\" *ngIf=\"showTile(tile)\" class=\"elder-grid-tile\">\n <div class=\"elder-grid-tile-content\"\n (click)=\"onItemClick(tile)\"\n (dblclick)=\"onItemDoubleClick(tile)\">\n <ng-container\n *ngTemplateOutlet=\"tileTemplate || simpleTileTemplate; context: {$implicit: tile}\">\n </ng-container>\n\n <!-- Overlay (Selection) -->\n <ng-container *ngIf=\"selectionVisible\">\n <div *ngIf=\"selectionModel.selection | async as selection\"\n class=\"elder-grid-tile-overlay elder-click-through\"\n [class.elder-grid-tile-overlay-hidden]=\"!inSelectionMode(selection)\"\n [class.elder-grid-tile-overlay-visible]=\"inSelectionMode(selection)\"\n >\n <button mat-icon-button type=\"button\"\n (click)=\"selectionModel.toggle(tile)\" elderStopEventPropagation\n class=\"elder-grid-tile-check\">\n <mat-icon\n [class.elder-selected]=\"(selectionModel.observeSelection(tile) | async)\"\n >\n {{(selectionModel.observeSelection(tile) | async) ? 'check_circle' : 'radio_button_unchecked'}}\n </mat-icon>\n </button>\n </div>\n </ng-container>\n\n </div>\n </mat-card>\n\n <div *ngIf=\"!showTile(tile)\" class=\"elder-grid-tile-hidden\"></div>\n </ng-container>\n\n </div>\n\n </cdk-virtual-scroll-viewport>\n\n\n <mat-progress-bar class=\"flex-none\"\n [mode]=\"(data?.loading | async) ? 'indeterminate' : 'determinate'\"\n [color]=\"(data && (data.status | async)?.hasError) ? 'warn' : 'primary'\">\n </mat-progress-bar>\n\n <!-- Footer -->\n <div class=\"layout-row place-end-center gap-md flex-none elder-grid-footer\"\n *ngIf=\"footerVisible\"\n style=\"padding-right: 12px\">\n\n <!-- Continuable -->\n <ng-container *ngIf=\"isContinuable\">\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataSnapshot?.data | async)?.length}} / {{total$ | async}}\n </span>\n\n <button mat-icon-button type=\"button\"\n color=\"primary\"\n [disabled]=\"!(canLoadMore$ | async)\"\n (click)=\"dataSnapshot.loadMore()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n </button>\n </ng-container>\n\n <!-- Paged -->\n <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n class=\"flex-none\"\n [length]=\"dataContext?.total | async\"\n [pageIndex]=\"page?.index\"\n [pageSize]=\"page?.size\"\n [pageSizeOptions]=\"pageSizeOptions\">\n </mat-paginator>\n\n <!-- Local Source -->\n <ng-container *ngIf=\"!isActivePaged && !isContinuable\">\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataSnapshot?.data | async)?.length}}\n </span>\n </ng-container>\n\n </div>\n\n\n </div>\n</mat-card>\n\n<ng-template #simpleTileTemplate let-tile>\n <div *ngIf=\"tile\" class=\"layout-col place-center-center flex\" style=\"background-color: lightblue\">\n <p class=\"noselect\">Tile: {{tile}}</p>\n </div>\n</ng-template>\n", styles: [":host{min-width:0;min-height:0}.elder-grid-tile-row{display:flex;flex-direction:row;padding:8px}.elder-grid-tile-row:first-child{padding-top:16px}.elder-grid-tile-hidden{flex:0 1 100%;margin:8px;width:100%;height:100%}.elder-grid-tile-content{position:relative;width:100%;height:100%;overflow:hidden}.elder-grid-tile-overlay{position:absolute;inset:0;transition:background-color .1s ease-in,opacity .1s ease-in}.elder-click-through{pointer-events:none}.elder-grid-tile-overlay-visible{opacity:1}.elder-grid-tile-overlay-hidden{opacity:0}\n"] }]
|
|
260
|
-
}], ctorParameters:
|
|
260
|
+
}], ctorParameters: () => [{ type: i1.SelectionModel, decorators: [{
|
|
261
261
|
type: Optional
|
|
262
262
|
}] }, { type: i2.ElderDataViewOptionsProvider, decorators: [{
|
|
263
263
|
type: Optional
|
|
264
264
|
}, {
|
|
265
265
|
type: SkipSelf
|
|
266
|
-
}] }, { type: i3.BreakpointObserver }]
|
|
266
|
+
}] }, { type: i3.BreakpointObserver }], propDecorators: { tileTemplateQuery: [{
|
|
267
267
|
type: ContentChild,
|
|
268
268
|
args: [ElderGridTileDirective, { read: TemplateRef, static: true }]
|
|
269
269
|
}], toolbarVisible: [{
|
|
@@ -304,4 +304,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
304
304
|
}], columnCount: [{
|
|
305
305
|
type: Input
|
|
306
306
|
}] } });
|
|
307
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-grid.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/grid/elder-grid/elder-grid.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/grid/elder-grid/elder-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  Directive,\n  forwardRef,\n  Input, OnDestroy,\n  OnInit,\n  Optional,\n  SkipSelf,\n  TemplateRef,\n  TrackByFunction,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, combineLatest, Observable, of} from 'rxjs';\nimport {IDataContext, IDataContextContinuable, isContinuableDataContext} from '../../../../common/data/data-context/data-context';\nimport {CdkVirtualScrollViewport} from '@angular/cdk/scrolling';\nimport {SelectionModel} from '../../../../common/selection/selection-model';\nimport {debounceTime, filter, map, startWith, switchMap, takeUntil} from 'rxjs/operators';\nimport {Sort} from '../../../../common/data/sort';\nimport {ELDER_DATA_VIEW} from '../../base/elder-data-view';\nimport {ElderDataViewBaseComponent} from '../../base/elder-data-view-base';\nimport {MatPaginator} from '@angular/material/paginator';\nimport {MatTableDataContextBindingBuilder} from '../../../../common/data/data-context/mat-table-data-context-binding';\nimport {ElderDataViewOptionsProvider} from '../../base/elder-data-view-options-provider';\nimport {BreakpointObserver, Breakpoints} from '@angular/cdk/layout';\n\n@Directive({selector: '[elderGridTile]'})\nexport class ElderGridTileDirective {\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef) {\n  }\n}\n\n/**\n * This directive projects marked content into a toolbar.\n */\n@Directive({selector: '[elderGridToolbar]'})\nexport class ElderGridToolbarDirective {\n\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef\n  ) {\n  }\n}\n\n@Component({\n  selector: 'elder-grid',\n  templateUrl: './elder-grid.component.html',\n  styleUrls: ['./elder-grid.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ELDER_DATA_VIEW,\n      useExisting: forwardRef(() => ElderGridComponent)\n    }\n  ]\n})\nexport class ElderGridComponent extends ElderDataViewBaseComponent implements OnInit, AfterViewInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private _columnCount = new BehaviorSubject<number>(4);\n\n  private readonly sizeToColumns = new Map([\n    [Breakpoints.XSmall, 1],\n    [Breakpoints.Small, 2],\n    [Breakpoints.Medium, 3],\n    [Breakpoints.Large, 4],\n    [Breakpoints.XLarge, 5]\n  ]);\n\n  /**\n   * Load next chunk after current is done\n   */\n  private loadNextQueued = false;\n\n  public dataRows$: Observable<any[][]>;\n\n  public canLoadMore$: Observable<boolean>;\n  public total$: Observable<string>;\n\n  @ContentChild(ElderGridTileDirective, {read: TemplateRef, static: true})\n  public tileTemplateQuery: TemplateRef<any>;\n  private _tileTemplate: TemplateRef<any>;\n\n  @Input()\n  public toolbarVisible = true;\n\n  @Input()\n  public footerVisible = true;\n\n  @Input()\n  public itemHeight = 250;\n\n  @Input()\n  public responsiveColumnCount = true;\n\n  @ViewChild('virtualScrollViewPort', {static: true})\n  public virtualScrollViewPort: CdkVirtualScrollViewport;\n\n  @Input()\n  public availableSorts: string[] = [];\n\n  @Input()\n  public sortTranslationPrefix = 'documents.sorts.';\n\n  @Input()\n  public hiddenField: string = null;\n\n  /**\n   * @deprecated No longer required. Id is automatically picked from the DataSource.\n   */\n  @Input()\n  public idField = 'id';\n\n  @Input()\n  public selectionVisible = true;\n\n  @Input()\n  public pageSizeOptions = [30, 50, 100, 150, 200];\n  @ViewChild(MatPaginator)\n  public matPaginator: MatPaginator;\n\n  @ContentChild(ElderGridToolbarDirective, {read: TemplateRef, static: true})\n  public toolbarTemplateQuery: TemplateRef<any>;\n  private _toolbarTemplate: TemplateRef<any>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    @Optional() selectionModel: SelectionModel<any>,\n    @Optional() @SkipSelf() dataViewOptionsProvider: ElderDataViewOptionsProvider,\n    private breakpointObserver: BreakpointObserver\n  ) {\n    super(selectionModel, dataViewOptionsProvider);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Lifecycle                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n\n    const columnCount$ = (\n      this.responsiveColumnCount\n        ? this.responsiveColumn()\n        : this._columnCount);\n\n    this.dataRows$ = combineLatest(\n      [\n        this.dataContext$.pipe(\n          filter(dc => !!dc),\n          switchMap(dc => dc.data)\n        ),\n        columnCount$\n      ]).pipe(\n      debounceTime(50),\n      map(\n        ([data, columns]) => this.groupForColumns(data, columns)\n      )\n    );\n  }\n\n  public ngAfterViewInit(): void {\n\n    MatTableDataContextBindingBuilder\n      .start(this.dataContext$)\n      .withPaginator(of(this.matPaginator))\n      .bindUntil(this.destroy$);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set tileTemplate(template: TemplateRef<any>) {\n    this._tileTemplate = template;\n  }\n\n  public get tileTemplate(): TemplateRef<any> {\n    return this._tileTemplate || this.tileTemplateQuery;\n  }\n\n  @Input()\n  public set toolbarTemplate(template: TemplateRef<any>) {\n    this._toolbarTemplate = template;\n  }\n\n  public get toolbarTemplate(): TemplateRef<any> {\n    return this._toolbarTemplate || this.toolbarTemplateQuery;\n  }\n\n  @Input()\n  public set data(data: IDataContext<any>) {\n    this.dataContext$.next(data);\n\n    this.total$ = data.total.pipe(\n      map(total => total ? total + '' : '∞')\n    );\n\n    if (isContinuableDataContext(data)) {\n      this.canLoadMore$ = combineLatest([data.loading, data.hasMoreData]).pipe(\n        map(([loading, hasMoreData]) => !loading && hasMoreData)\n      );\n    } else {\n      this.canLoadMore$ = of(false);\n    }\n  }\n\n  public get dataSnapshot(): IDataContextContinuable<any> {\n    return this.dataContinuable;\n  }\n\n  @Input()\n  public set columnCount(count: number) {\n    this._columnCount.next(count);\n  }\n\n  public get columnCount(): number {\n    return this._columnCount.getValue();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public inSelectionMode(currentSelection: any[]): boolean {\n\n    if (this.interactionMode === 'selection') {\n      return true;\n    }\n\n    if (currentSelection && currentSelection.length > 0) {\n      return true;\n    }\n  }\n\n  public requestMoreDataZoned(event: any): void {\n    if (this.dataSnapshot.hasMoreDataSnapshot) {\n\n      if (this.dataSnapshot.snapshot.isLoading) {\n        this.loadNextQueued = true;\n      } else {\n        this.dataSnapshot.loadMore()\n          .subscribe(\n            loaded => {\n              if (this.loadNextQueued) {\n                this.loadNextQueued = false;\n                this.requestMoreDataZoned(event);\n              }\n            }\n          );\n      }\n    } else {\n      this.loadNextQueued = false;\n    }\n  }\n\n  public get trackByFn(): TrackByFunction<any> {\n    return (index: number, entity: any) => index;\n  }\n\n  public trackByIndex(index: number, items: any[]): any {\n    return index;\n  }\n\n  public updateSort(sort: Sort): void {\n    const dc = this.dataContext$.getValue();\n    if (dc) {\n      dc.sort.replaceSorts([sort]);\n    }\n  }\n\n  public showTile(tile: any): boolean {\n    return tile && (this.hiddenField ? !tile[this.hiddenField] : true);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private scrollTop() {\n    this.virtualScrollViewPort.scrollToIndex(0, 'smooth');\n  }\n\n  private groupForColumns(nodes: any[], columns: number): any[][] {\n\n    const rows: any[][] = [];\n\n    const rowCount = nodes.length / columns;\n\n    for (let rowIndex = 0; rowIndex < rowCount; rowIndex++) {\n      const rowStartIndex = rowIndex * columns;\n      const row = nodes.slice(rowStartIndex, rowStartIndex + columns);\n\n      while (row.length < columns) {\n        row.push(null); // Fill up remaining\n      }\n      rows.push(row);\n    }\n\n    return rows;\n  }\n\n  private responsiveColumn(): Observable<number> {\n    const breakpoints = Array.from(this.sizeToColumns.keys());\n    return this.breakpointObserver.observe(breakpoints).pipe(\n      takeUntil(this.destroy$),\n      map(result => {\n        let activeSize = Breakpoints.Medium;\n        for (const query of Object.keys(result.breakpoints)) {\n          if (result.breakpoints[query]) {\n            activeSize = query;\n            break;\n          }\n        }\n        return this.sizeToColumns.get(activeSize);\n      }),\n      debounceTime(100),\n      startWith(this.activeColumnCount())\n    )\n  }\n\n  private activeColumnCount(): number {\n    let columnCount = 1;\n    this.sizeToColumns.forEach((cols, mqAlias) => {\n      if (this.breakpointObserver.isMatched(mqAlias)) {\n        columnCount = cols;\n      }\n    });\n    return columnCount;\n  }\n}\n","<mat-card class=\"full\"\n          [class.embedded]=\"embedded\"\n          [appearance]=\"appearance\"\n          style=\"overflow: hidden\"\n>\n  <!-- Grid Browser -->\n  <div class=\"layout-col full elder-grid-container\"\n       *ngIf=\"dataContext$ | async as data\"\n       [elderDataContextSelection]=\"data\" #dataSelection=\"elderDataContextSelection\"\n       [elderDataContextSelectionModel]=\"selectionModel\"\n  >\n    <!-- Toolbar Row -->\n    <div *ngIf=\"toolbarVisible\"\n         class=\"layout-row place-start-center flex-none elder-grid-toolbar\">\n\n      <div class=\"layout-col flex-none\" style=\"padding-left: 8px; padding-right: 8px\" *ngIf=\"selectionVisible\">\n        <elder-selection-master-checkbox class=\"flex-none\" style=\"padding-left: 12px\"></elder-selection-master-checkbox>\n      </div>\n\n      <!-- Toolbar -->\n      <ng-container *ngIf=\"toolbarTemplate\">\n        <ng-template *ngTemplateOutlet=\"toolbarTemplate; context: {$implicit: this}\"></ng-template>\n      </ng-container>\n\n      <elder-single-sort *ngIf=\"availableSorts && availableSorts.length > 0 && data.sort.sorts | async as sorts\"\n                         class=\"flex-none\"\n                         [availableSorts]=\"availableSorts\"\n                         [translationPrefix]=\"sortTranslationPrefix\"\n                         [sort]=\"sorts[0]\"\n                         (sortChange)=\"updateSort($event)\">\n      </elder-single-sort>\n    </div>\n\n    <mat-divider *ngIf=\"toolbarVisible\"></mat-divider>\n\n    <elder-data-context-state-indicator class=\"flex-none\" [dataContext]=\"data\">\n    </elder-data-context-state-indicator>\n\n    <!-- [cdkDropListSortingDisabled]=\"true\" -->\n    <!-- cdkDropList -->\n    <cdk-virtual-scroll-viewport\n      class=\"layout-col flex elder-grid-browser\"\n      id=\"documents-container\"\n      [itemSize]=\"itemHeight\"\n      [minBufferPx]=\"itemHeight * 2\"\n      [maxBufferPx]=\"itemHeight * 3\"\n      #virtualScrollViewPort\n      elderInfiniteScroll\n      [eventThrottle]=\"200\"\n      [offsetFactor]=\"2\"\n      [ignoreScrollEvent]=\"data.loading | async\"\n      [containerId]=\"'documents-container'\" [listenToHost]=\"false\"\n      (closeToEnd)=\"requestMoreDataZoned($event)\">\n\n      <!-- (scrolling)=\"onScrolling($event)\" -->\n\n      <div\n        *cdkVirtualFor=\"let row of dataRows$; trackBy: trackByIndex; templateCacheSize: 50\"\n        class=\"elder-grid-tile-row\"\n        [style.height]=\"itemHeight + 'px'\">\n\n        <ng-container *ngFor=\"let tile of row; trackBy: trackByFn\">\n\n          <!-- Tile Cell -->\n          <mat-card appearance=\"outlined\" *ngIf=\"showTile(tile)\" class=\"elder-grid-tile\">\n            <div class=\"elder-grid-tile-content\"\n                 (click)=\"onItemClick(tile)\"\n                 (dblclick)=\"onItemDoubleClick(tile)\">\n              <ng-container\n                *ngTemplateOutlet=\"tileTemplate || simpleTileTemplate; context: {$implicit: tile}\">\n              </ng-container>\n\n              <!-- Overlay (Selection) -->\n              <ng-container *ngIf=\"selectionVisible\">\n                <div *ngIf=\"selectionModel.selection | async as selection\"\n                     class=\"elder-grid-tile-overlay elder-click-through\"\n                     [class.elder-grid-tile-overlay-hidden]=\"!inSelectionMode(selection)\"\n                     [class.elder-grid-tile-overlay-visible]=\"inSelectionMode(selection)\"\n                >\n                  <button mat-icon-button type=\"button\"\n                          (click)=\"selectionModel.toggle(tile)\" elderStopEventPropagation\n                          class=\"elder-grid-tile-check\">\n                    <mat-icon\n                      [class.elder-selected]=\"(selectionModel.observeSelection(tile) | async)\"\n                    >\n                      {{(selectionModel.observeSelection(tile) | async) ? 'check_circle' : 'radio_button_unchecked'}}\n                    </mat-icon>\n                  </button>\n                </div>\n              </ng-container>\n\n            </div>\n          </mat-card>\n\n          <div *ngIf=\"!showTile(tile)\" class=\"elder-grid-tile-hidden\"></div>\n        </ng-container>\n\n      </div>\n\n    </cdk-virtual-scroll-viewport>\n\n\n    <mat-progress-bar class=\"flex-none\"\n                      [mode]=\"(data?.loading | async) ? 'indeterminate' : 'determinate'\"\n                      [color]=\"(data && (data.status | async)?.hasError) ? 'warn' : 'primary'\">\n    </mat-progress-bar>\n\n    <!-- Footer -->\n    <div class=\"layout-row place-end-center gap-md flex-none elder-grid-footer\"\n         *ngIf=\"footerVisible\"\n         style=\"padding-right: 12px\">\n\n      <!-- Continuable -->\n      <ng-container *ngIf=\"isContinuable\">\n         <span class=\"mat-caption noselect\" style=\"color: gray\">\n            {{(dataSnapshot?.data | async)?.length}} / {{total$ | async}}\n          </span>\n\n        <button mat-icon-button type=\"button\"\n                color=\"primary\"\n                [disabled]=\"!(canLoadMore$ | async)\"\n                (click)=\"dataSnapshot.loadMore()\">\n          <mat-icon>keyboard_arrow_down</mat-icon>\n        </button>\n      </ng-container>\n\n      <!-- Paged -->\n      <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n                     class=\"flex-none\"\n                     [length]=\"dataContext?.total | async\"\n                     [pageIndex]=\"page?.index\"\n                     [pageSize]=\"page?.size\"\n                     [pageSizeOptions]=\"pageSizeOptions\">\n      </mat-paginator>\n\n      <!-- Local Source -->\n      <ng-container *ngIf=\"!isActivePaged && !isContinuable\">\n         <span class=\"mat-caption noselect\" style=\"color: gray\">\n            {{(dataSnapshot?.data | async)?.length}}\n          </span>\n      </ng-container>\n\n    </div>\n\n\n  </div>\n</mat-card>\n\n<ng-template #simpleTileTemplate let-tile>\n  <div *ngIf=\"tile\" class=\"layout-col place-center-center flex\" style=\"background-color: lightblue\">\n    <p class=\"noselect\">Tile: {{tile}}</p>\n  </div>\n</ng-template>\n"]}
|
|
307
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-grid.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/grid/elder-grid/elder-grid.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/grid/elder-grid/elder-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  Directive,\n  forwardRef,\n  Input, OnDestroy,\n  OnInit,\n  Optional,\n  SkipSelf,\n  TemplateRef,\n  TrackByFunction,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, combineLatest, Observable, of} from 'rxjs';\nimport {IDataContext, IDataContextContinuable, isContinuableDataContext} from '../../../../common/data/data-context/data-context';\nimport {CdkVirtualScrollViewport} from '@angular/cdk/scrolling';\nimport {SelectionModel} from '../../../../common/selection/selection-model';\nimport {debounceTime, filter, map, startWith, switchMap, takeUntil} from 'rxjs/operators';\nimport {Sort} from '../../../../common/data/sort';\nimport {ELDER_DATA_VIEW} from '../../base/elder-data-view';\nimport {ElderDataViewBaseComponent} from '../../base/elder-data-view-base';\nimport {MatPaginator} from '@angular/material/paginator';\nimport {MatTableDataContextBindingBuilder} from '../../../../common/data/data-context/mat-table-data-context-binding';\nimport {ElderDataViewOptionsProvider} from '../../base/elder-data-view-options-provider';\nimport {BreakpointObserver, Breakpoints} from '@angular/cdk/layout';\n\n@Directive({selector: '[elderGridTile]'})\nexport class ElderGridTileDirective {\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef) {\n  }\n}\n\n/**\n * This directive projects marked content into a toolbar.\n */\n@Directive({selector: '[elderGridToolbar]'})\nexport class ElderGridToolbarDirective {\n\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef\n  ) {\n  }\n}\n\n@Component({\n  selector: 'elder-grid',\n  templateUrl: './elder-grid.component.html',\n  styleUrls: ['./elder-grid.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ELDER_DATA_VIEW,\n      useExisting: forwardRef(() => ElderGridComponent)\n    }\n  ]\n})\nexport class ElderGridComponent extends ElderDataViewBaseComponent implements OnInit, AfterViewInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private _columnCount = new BehaviorSubject<number>(4);\n\n  private readonly sizeToColumns = new Map([\n    [Breakpoints.XSmall, 1],\n    [Breakpoints.Small, 2],\n    [Breakpoints.Medium, 3],\n    [Breakpoints.Large, 4],\n    [Breakpoints.XLarge, 5]\n  ]);\n\n  /**\n   * Load next chunk after current is done\n   */\n  private loadNextQueued = false;\n\n  public dataRows$: Observable<any[][]>;\n\n  public canLoadMore$: Observable<boolean>;\n  public total$: Observable<string>;\n\n  @ContentChild(ElderGridTileDirective, {read: TemplateRef, static: true})\n  public tileTemplateQuery: TemplateRef<any>;\n  private _tileTemplate: TemplateRef<any>;\n\n  @Input()\n  public toolbarVisible = true;\n\n  @Input()\n  public footerVisible = true;\n\n  @Input()\n  public itemHeight = 250;\n\n  @Input()\n  public responsiveColumnCount = true;\n\n  @ViewChild('virtualScrollViewPort', {static: true})\n  public virtualScrollViewPort: CdkVirtualScrollViewport;\n\n  @Input()\n  public availableSorts: string[] = [];\n\n  @Input()\n  public sortTranslationPrefix = 'documents.sorts.';\n\n  @Input()\n  public hiddenField: string = null;\n\n  /**\n   * @deprecated No longer required. Id is automatically picked from the DataSource.\n   */\n  @Input()\n  public idField = 'id';\n\n  @Input()\n  public selectionVisible = true;\n\n  @Input()\n  public pageSizeOptions = [30, 50, 100, 150, 200];\n  @ViewChild(MatPaginator)\n  public matPaginator: MatPaginator;\n\n  @ContentChild(ElderGridToolbarDirective, {read: TemplateRef, static: true})\n  public toolbarTemplateQuery: TemplateRef<any>;\n  private _toolbarTemplate: TemplateRef<any>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    @Optional() selectionModel: SelectionModel<any>,\n    @Optional() @SkipSelf() dataViewOptionsProvider: ElderDataViewOptionsProvider,\n    private breakpointObserver: BreakpointObserver\n  ) {\n    super(selectionModel, dataViewOptionsProvider);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Lifecycle                                                               *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n\n    const columnCount$ = (\n      this.responsiveColumnCount\n        ? this.responsiveColumn()\n        : this._columnCount);\n\n    this.dataRows$ = combineLatest(\n      [\n        this.dataContext$.pipe(\n          filter(dc => !!dc),\n          switchMap(dc => dc.data)\n        ),\n        columnCount$\n      ]).pipe(\n      debounceTime(50),\n      map(\n        ([data, columns]) => this.groupForColumns(data, columns)\n      )\n    );\n  }\n\n  public ngAfterViewInit(): void {\n\n    MatTableDataContextBindingBuilder\n      .start(this.dataContext$)\n      .withPaginator(of(this.matPaginator))\n      .bindUntil(this.destroy$);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set tileTemplate(template: TemplateRef<any>) {\n    this._tileTemplate = template;\n  }\n\n  public get tileTemplate(): TemplateRef<any> {\n    return this._tileTemplate || this.tileTemplateQuery;\n  }\n\n  @Input()\n  public set toolbarTemplate(template: TemplateRef<any>) {\n    this._toolbarTemplate = template;\n  }\n\n  public get toolbarTemplate(): TemplateRef<any> {\n    return this._toolbarTemplate || this.toolbarTemplateQuery;\n  }\n\n  @Input()\n  public set data(data: IDataContext<any>) {\n    this.dataContext$.next(data);\n\n    this.total$ = data.total.pipe(\n      map(total => total ? total + '' : '∞')\n    );\n\n    if (isContinuableDataContext(data)) {\n      this.canLoadMore$ = combineLatest([data.loading, data.hasMoreData]).pipe(\n        map(([loading, hasMoreData]) => !loading && hasMoreData)\n      );\n    } else {\n      this.canLoadMore$ = of(false);\n    }\n  }\n\n  public get dataSnapshot(): IDataContextContinuable<any> {\n    return this.dataContinuable;\n  }\n\n  @Input()\n  public set columnCount(count: number) {\n    this._columnCount.next(count);\n  }\n\n  public get columnCount(): number {\n    return this._columnCount.getValue();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public inSelectionMode(currentSelection: any[]): boolean {\n\n    if (this.interactionMode === 'selection') {\n      return true;\n    }\n\n    if (currentSelection && currentSelection.length > 0) {\n      return true;\n    }\n  }\n\n  public requestMoreDataZoned(event: any): void {\n    if (this.dataSnapshot.hasMoreDataSnapshot) {\n\n      if (this.dataSnapshot.snapshot.isLoading) {\n        this.loadNextQueued = true;\n      } else {\n        this.dataSnapshot.loadMore()\n          .subscribe(\n            loaded => {\n              if (this.loadNextQueued) {\n                this.loadNextQueued = false;\n                this.requestMoreDataZoned(event);\n              }\n            }\n          );\n      }\n    } else {\n      this.loadNextQueued = false;\n    }\n  }\n\n  public get trackByFn(): TrackByFunction<any> {\n    return (index: number, entity: any) => index;\n  }\n\n  public trackByIndex(index: number, items: any[]): any {\n    return index;\n  }\n\n  public updateSort(sort: Sort): void {\n    const dc = this.dataContext$.getValue();\n    if (dc) {\n      dc.sort.replaceSorts([sort]);\n    }\n  }\n\n  public showTile(tile: any): boolean {\n    return tile && (this.hiddenField ? !tile[this.hiddenField] : true);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private scrollTop() {\n    this.virtualScrollViewPort.scrollToIndex(0, 'smooth');\n  }\n\n  private groupForColumns(nodes: any[], columns: number): any[][] {\n\n    const rows: any[][] = [];\n\n    const rowCount = nodes.length / columns;\n\n    for (let rowIndex = 0; rowIndex < rowCount; rowIndex++) {\n      const rowStartIndex = rowIndex * columns;\n      const row = nodes.slice(rowStartIndex, rowStartIndex + columns);\n\n      while (row.length < columns) {\n        row.push(null); // Fill up remaining\n      }\n      rows.push(row);\n    }\n\n    return rows;\n  }\n\n  private responsiveColumn(): Observable<number> {\n    const breakpoints = Array.from(this.sizeToColumns.keys());\n    return this.breakpointObserver.observe(breakpoints).pipe(\n      takeUntil(this.destroy$),\n      map(result => {\n        let activeSize = Breakpoints.Medium;\n        for (const query of Object.keys(result.breakpoints)) {\n          if (result.breakpoints[query]) {\n            activeSize = query;\n            break;\n          }\n        }\n        return this.sizeToColumns.get(activeSize);\n      }),\n      debounceTime(100),\n      startWith(this.activeColumnCount())\n    )\n  }\n\n  private activeColumnCount(): number {\n    let columnCount = 1;\n    this.sizeToColumns.forEach((cols, mqAlias) => {\n      if (this.breakpointObserver.isMatched(mqAlias)) {\n        columnCount = cols;\n      }\n    });\n    return columnCount;\n  }\n}\n","<mat-card class=\"full\"\n          [class.embedded]=\"embedded\"\n          [appearance]=\"appearance\"\n          style=\"overflow: hidden\"\n>\n  <!-- Grid Browser -->\n  <div class=\"layout-col full elder-grid-container\"\n       *ngIf=\"dataContext$ | async as data\"\n       [elderDataContextSelection]=\"data\" #dataSelection=\"elderDataContextSelection\"\n       [elderDataContextSelectionModel]=\"selectionModel\"\n  >\n    <!-- Toolbar Row -->\n    <div *ngIf=\"toolbarVisible\"\n         class=\"layout-row place-start-center flex-none elder-grid-toolbar\">\n\n      <div class=\"layout-col flex-none\" style=\"padding-left: 8px; padding-right: 8px\" *ngIf=\"selectionVisible\">\n        <elder-selection-master-checkbox class=\"flex-none\" style=\"padding-left: 12px\"></elder-selection-master-checkbox>\n      </div>\n\n      <!-- Toolbar -->\n      <ng-container *ngIf=\"toolbarTemplate\">\n        <ng-template *ngTemplateOutlet=\"toolbarTemplate; context: {$implicit: this}\"></ng-template>\n      </ng-container>\n\n      <elder-single-sort *ngIf=\"availableSorts && availableSorts.length > 0 && data.sort.sorts | async as sorts\"\n                         class=\"flex-none\"\n                         [availableSorts]=\"availableSorts\"\n                         [translationPrefix]=\"sortTranslationPrefix\"\n                         [sort]=\"sorts[0]\"\n                         (sortChange)=\"updateSort($event)\">\n      </elder-single-sort>\n    </div>\n\n    <mat-divider *ngIf=\"toolbarVisible\"></mat-divider>\n\n    <elder-data-context-state-indicator class=\"flex-none\" [dataContext]=\"data\">\n    </elder-data-context-state-indicator>\n\n    <!-- [cdkDropListSortingDisabled]=\"true\" -->\n    <!-- cdkDropList -->\n    <cdk-virtual-scroll-viewport\n      class=\"layout-col flex elder-grid-browser\"\n      id=\"documents-container\"\n      [itemSize]=\"itemHeight\"\n      [minBufferPx]=\"itemHeight * 2\"\n      [maxBufferPx]=\"itemHeight * 3\"\n      #virtualScrollViewPort\n      elderInfiniteScroll\n      [eventThrottle]=\"200\"\n      [offsetFactor]=\"2\"\n      [ignoreScrollEvent]=\"data.loading | async\"\n      [containerId]=\"'documents-container'\" [listenToHost]=\"false\"\n      (closeToEnd)=\"requestMoreDataZoned($event)\">\n\n      <!-- (scrolling)=\"onScrolling($event)\" -->\n\n      <div\n        *cdkVirtualFor=\"let row of dataRows$; trackBy: trackByIndex; templateCacheSize: 50\"\n        class=\"elder-grid-tile-row\"\n        [style.height]=\"itemHeight + 'px'\">\n\n        <ng-container *ngFor=\"let tile of row; trackBy: trackByFn\">\n\n          <!-- Tile Cell -->\n          <mat-card appearance=\"outlined\" *ngIf=\"showTile(tile)\" class=\"elder-grid-tile\">\n            <div class=\"elder-grid-tile-content\"\n                 (click)=\"onItemClick(tile)\"\n                 (dblclick)=\"onItemDoubleClick(tile)\">\n              <ng-container\n                *ngTemplateOutlet=\"tileTemplate || simpleTileTemplate; context: {$implicit: tile}\">\n              </ng-container>\n\n              <!-- Overlay (Selection) -->\n              <ng-container *ngIf=\"selectionVisible\">\n                <div *ngIf=\"selectionModel.selection | async as selection\"\n                     class=\"elder-grid-tile-overlay elder-click-through\"\n                     [class.elder-grid-tile-overlay-hidden]=\"!inSelectionMode(selection)\"\n                     [class.elder-grid-tile-overlay-visible]=\"inSelectionMode(selection)\"\n                >\n                  <button mat-icon-button type=\"button\"\n                          (click)=\"selectionModel.toggle(tile)\" elderStopEventPropagation\n                          class=\"elder-grid-tile-check\">\n                    <mat-icon\n                      [class.elder-selected]=\"(selectionModel.observeSelection(tile) | async)\"\n                    >\n                      {{(selectionModel.observeSelection(tile) | async) ? 'check_circle' : 'radio_button_unchecked'}}\n                    </mat-icon>\n                  </button>\n                </div>\n              </ng-container>\n\n            </div>\n          </mat-card>\n\n          <div *ngIf=\"!showTile(tile)\" class=\"elder-grid-tile-hidden\"></div>\n        </ng-container>\n\n      </div>\n\n    </cdk-virtual-scroll-viewport>\n\n\n    <mat-progress-bar class=\"flex-none\"\n                      [mode]=\"(data?.loading | async) ? 'indeterminate' : 'determinate'\"\n                      [color]=\"(data && (data.status | async)?.hasError) ? 'warn' : 'primary'\">\n    </mat-progress-bar>\n\n    <!-- Footer -->\n    <div class=\"layout-row place-end-center gap-md flex-none elder-grid-footer\"\n         *ngIf=\"footerVisible\"\n         style=\"padding-right: 12px\">\n\n      <!-- Continuable -->\n      <ng-container *ngIf=\"isContinuable\">\n         <span class=\"mat-caption noselect\" style=\"color: gray\">\n            {{(dataSnapshot?.data | async)?.length}} / {{total$ | async}}\n          </span>\n\n        <button mat-icon-button type=\"button\"\n                color=\"primary\"\n                [disabled]=\"!(canLoadMore$ | async)\"\n                (click)=\"dataSnapshot.loadMore()\">\n          <mat-icon>keyboard_arrow_down</mat-icon>\n        </button>\n      </ng-container>\n\n      <!-- Paged -->\n      <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n                     class=\"flex-none\"\n                     [length]=\"dataContext?.total | async\"\n                     [pageIndex]=\"page?.index\"\n                     [pageSize]=\"page?.size\"\n                     [pageSizeOptions]=\"pageSizeOptions\">\n      </mat-paginator>\n\n      <!-- Local Source -->\n      <ng-container *ngIf=\"!isActivePaged && !isContinuable\">\n         <span class=\"mat-caption noselect\" style=\"color: gray\">\n            {{(dataSnapshot?.data | async)?.length}}\n          </span>\n      </ng-container>\n\n    </div>\n\n\n  </div>\n</mat-card>\n\n<ng-template #simpleTileTemplate let-tile>\n  <div *ngIf=\"tile\" class=\"layout-col place-center-center flex\" style=\"background-color: lightblue\">\n    <p class=\"noselect\">Tile: {{tile}}</p>\n  </div>\n</ng-template>\n"]}
|
|
@@ -20,8 +20,8 @@ import { MatCardModule } from '@angular/material/card';
|
|
|
20
20
|
import * as i0 from "@angular/core";
|
|
21
21
|
export { ElderGridTileDirective, ElderGridToolbarDirective, ElderGridComponent } from './elder-grid/elder-grid.component';
|
|
22
22
|
export class ElderGridModule {
|
|
23
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
24
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "
|
|
23
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderGridModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
24
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.2", ngImport: i0, type: ElderGridModule, declarations: [ElderGridComponent,
|
|
25
25
|
ElderGridTileDirective,
|
|
26
26
|
ElderGridToolbarDirective], imports: [CommonModule,
|
|
27
27
|
MatCommonModule,
|
|
@@ -37,7 +37,7 @@ export class ElderGridModule {
|
|
|
37
37
|
ElderFormsDirectivesModule, MatPaginatorModule, MatCardModule], exports: [ElderGridComponent,
|
|
38
38
|
ElderGridTileDirective,
|
|
39
39
|
ElderGridToolbarDirective] }); }
|
|
40
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
40
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderGridModule, imports: [CommonModule,
|
|
41
41
|
MatCommonModule,
|
|
42
42
|
MatProgressBarModule,
|
|
43
43
|
MatMenuModule,
|
|
@@ -50,7 +50,7 @@ export class ElderGridModule {
|
|
|
50
50
|
ElderInfiniteScrollModule,
|
|
51
51
|
ElderFormsDirectivesModule, MatPaginatorModule, MatCardModule] }); }
|
|
52
52
|
}
|
|
53
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
53
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderGridModule, decorators: [{
|
|
54
54
|
type: NgModule,
|
|
55
55
|
args: [{
|
|
56
56
|
imports: [
|
|
@@ -79,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
79
79
|
]
|
|
80
80
|
}]
|
|
81
81
|
}] });
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItZ3JpZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy9ncmlkL2VsZGVyLWdyaWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxrQkFBa0IsRUFBRSxzQkFBc0IsRUFBRSx5QkFBeUIsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQ3hILE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDM0QsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRSxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUN0RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBQ3BELE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLG1EQUFtRCxDQUFDO0FBQzVGLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLHNEQUFzRCxDQUFDO0FBQ2hHLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQ3pFLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQy9ELE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQzs7QUFFckQsT0FBTyxFQUFDLHNCQUFzQixFQUFFLHlCQUF5QixFQUFFLGtCQUFrQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFpQ3hILE1BQU0sT0FBTyxlQUFlOzhHQUFmLGVBQWU7K0dBQWYsZUFBZSxpQkFWeEIsa0JBQWtCO1lBQ2xCLHNCQUFzQjtZQUN0Qix5QkFBeUIsYUFyQnpCLFlBQVk7WUFFWixlQUFlO1lBQ2Ysb0JBQW9CO1lBQ3BCLGFBQWE7WUFDYixVQUFVO1lBRVYsZ0JBQWdCLEVBQUUsYUFBYSxFQUFFLGVBQWU7WUFDaEQsZUFBZSxFQUFFLGNBQWM7WUFFL0IsZUFBZTtZQUVmLGVBQWU7WUFFZixxQkFBcUI7WUFDckIseUJBQXlCO1lBQ3pCLDBCQUEwQixFQUFFLGtCQUFrQixFQUFFLGFBQWEsYUFRN0Qsa0JBQWtCO1lBQ2xCLHNCQUFzQjtZQUN0Qix5QkFBeUI7K0dBR2hCLGVBQWUsWUE3QnhCLFlBQVk7WUFFWixlQUFlO1lBQ2Ysb0JBQW9CO1lBQ3BCLGFBQWE7WUFDYixVQUFVO1lBRVYsZ0JBQWdCLEVBQUUsYUFBYSxFQUFFLGVBQWU7WUFDaEQsZUFBZSxFQUFFLGNBQWM7WUFFL0IsZUFBZTtZQUVmLGVBQWU7WUFFZixxQkFBcUI7WUFDckIseUJBQXlCO1lBQ3pCLDBCQUEwQixFQUFFLGtCQUFrQixFQUFFLGFBQWE7OzJGQWFwRCxlQUFlO2tCQS9CM0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFFWixlQUFlO3dCQUNmLG9CQUFvQjt3QkFDcEIsYUFBYTt3QkFDYixVQUFVO3dCQUVWLGdCQUFnQixFQUFFLGFBQWEsRUFBRSxlQUFlO3dCQUNoRCxlQUFlLEVBQUUsY0FBYzt3QkFFL0IsZUFBZTt3QkFFZixlQUFlO3dCQUVmLHFCQUFxQjt3QkFDckIseUJBQXlCO3dCQUN6QiwwQkFBMEIsRUFBRSxrQkFBa0IsRUFBRSxhQUFhO3FCQUM5RDtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osa0JBQWtCO3dCQUNsQixzQkFBc0I7d0JBQ3RCLHlCQUF5QjtxQkFDMUI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGtCQUFrQjt3QkFDbEIsc0JBQXNCO3dCQUN0Qix5QkFBeUI7cUJBQzFCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7RWxkZXJHcmlkQ29tcG9uZW50LCBFbGRlckdyaWRUaWxlRGlyZWN0aXZlLCBFbGRlckdyaWRUb29sYmFyRGlyZWN0aXZlfSBmcm9tICcuL2VsZGVyLWdyaWQvZWxkZXItZ3JpZC5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQge01hdENvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5pbXBvcnQge01hdERpdmlkZXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpdmlkZXInO1xuaW1wb3J0IHtNYXRJY29uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7TWF0TWVudU1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbWVudSc7XG5pbXBvcnQge01hdFByb2dyZXNzQmFyTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wcm9ncmVzcy1iYXInO1xuaW1wb3J0IHtNYXRTZWxlY3RNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NlbGVjdCc7XG5pbXBvcnQge0ExMXlNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7RHJhZ0Ryb3BNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kcmFnLWRyb3AnO1xuaW1wb3J0IHtTY3JvbGxpbmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Nkay9zY3JvbGxpbmcnO1xuaW1wb3J0IHtUcmFuc2xhdGVNb2R1bGV9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHtFbGRlckluZmluaXRlU2Nyb2xsTW9kdWxlfSBmcm9tICcuLi8uLi9pbmZpbml0ZXNjcm9sbC9lbGRlci1pbmZpbml0ZS1zY3JvbGwubW9kdWxlJztcbmltcG9ydCB7RWxkZXJGb3Jtc0RpcmVjdGl2ZXNNb2R1bGV9IGZyb20gJy4uLy4uL2Zvcm1zL2RpcmVjdGl2ZXMvZWxkZXItZm9ybXMtZGlyZWN0aXZlcy5tb2R1bGUnO1xuaW1wb3J0IHtFbGRlckRhdGFDb21tb25Nb2R1bGV9IGZyb20gJy4uL2NvbW1vbi9lbGRlci1kYXRhLWNvbW1vbi5tb2R1bGUnO1xuaW1wb3J0IHtNYXRQYWdpbmF0b3JNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3BhZ2luYXRvcic7XG5pbXBvcnQge01hdENhcmRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NhcmQnO1xuXG5leHBvcnQge0VsZGVyR3JpZFRpbGVEaXJlY3RpdmUsIEVsZGVyR3JpZFRvb2xiYXJEaXJlY3RpdmUsIEVsZGVyR3JpZENvbXBvbmVudH0gZnJvbSAnLi9lbGRlci1ncmlkL2VsZGVyLWdyaWQuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcblxuICAgIE1hdENvbW1vbk1vZHVsZSxcbiAgICBNYXRQcm9ncmVzc0Jhck1vZHVsZSxcbiAgICBNYXRNZW51TW9kdWxlLFxuICAgIEExMXlNb2R1bGUsXG5cbiAgICBNYXREaXZpZGVyTW9kdWxlLCBNYXRJY29uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0U2VsZWN0TW9kdWxlLCBEcmFnRHJvcE1vZHVsZSxcblxuICAgIFNjcm9sbGluZ01vZHVsZSxcblxuICAgIFRyYW5zbGF0ZU1vZHVsZSxcblxuICAgIEVsZGVyRGF0YUNvbW1vbk1vZHVsZSxcbiAgICBFbGRlckluZmluaXRlU2Nyb2xsTW9kdWxlLFxuICAgIEVsZGVyRm9ybXNEaXJlY3RpdmVzTW9kdWxlLCBNYXRQYWdpbmF0b3JNb2R1bGUsIE1hdENhcmRNb2R1bGVcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgRWxkZXJHcmlkQ29tcG9uZW50LFxuICAgIEVsZGVyR3JpZFRpbGVEaXJlY3RpdmUsXG4gICAgRWxkZXJHcmlkVG9vbGJhckRpcmVjdGl2ZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgRWxkZXJHcmlkQ29tcG9uZW50LFxuICAgIEVsZGVyR3JpZFRpbGVEaXJlY3RpdmUsXG4gICAgRWxkZXJHcmlkVG9vbGJhckRpcmVjdGl2ZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyR3JpZE1vZHVsZSB7XG59XG4iXX0=
|
|
@@ -52,18 +52,18 @@ export class ElderDetailDialogComponent {
|
|
|
52
52
|
close() {
|
|
53
53
|
this.dialogRef.close(this.entity$.getValue());
|
|
54
54
|
}
|
|
55
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
56
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
55
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderDetailDialogComponent, deps: [{ token: i1.MatDialogRef, optional: true }, { token: MAT_DIALOG_DATA, optional: true }, { token: i2.ElderMasterDetailService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
56
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: ElderDetailDialogComponent, selector: "elder-detail-dialog", ngImport: i0, template: "<div class=\"layout-col full\" *ngIf=\"entity$ | async as entity\">\n\n <span style=\"width: 100vw;\"></span>\n\n <!-- Header Section -->\n <elder-toolbar class=\"gap-md\" >\n <button (click)=\"close()\" mat-icon-button *elderToolbarColumn=\"'left.begin'\">\n <mat-icon>close</mat-icon>\n </button>\n </elder-toolbar>\n\n <div class=\"layout-row flex gap-md\">\n <ng-container *ngTemplateOutlet=\"data.detailTemplateRef; context: {$implicit: entity}\"></ng-container>\n </div>\n\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i6.ElderToolbarComponent, selector: "elder-toolbar", inputs: ["color"] }, { kind: "directive", type: i7.ElderToolbarColumnDirective, selector: "[elderToolbarColumn]", inputs: ["elderToolbarColumn", "elderToolbarDefault"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
57
57
|
}
|
|
58
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ElderDetailDialogComponent, decorators: [{
|
|
59
59
|
type: Component,
|
|
60
60
|
args: [{ selector: 'elder-detail-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"layout-col full\" *ngIf=\"entity$ | async as entity\">\n\n <span style=\"width: 100vw;\"></span>\n\n <!-- Header Section -->\n <elder-toolbar class=\"gap-md\" >\n <button (click)=\"close()\" mat-icon-button *elderToolbarColumn=\"'left.begin'\">\n <mat-icon>close</mat-icon>\n </button>\n </elder-toolbar>\n\n <div class=\"layout-row flex gap-md\">\n <ng-container *ngTemplateOutlet=\"data.detailTemplateRef; context: {$implicit: entity}\"></ng-container>\n </div>\n\n</div>\n" }]
|
|
61
|
-
}], ctorParameters:
|
|
61
|
+
}], ctorParameters: () => [{ type: i1.MatDialogRef, decorators: [{
|
|
62
62
|
type: Optional
|
|
63
63
|
}] }, { type: undefined, decorators: [{
|
|
64
64
|
type: Optional
|
|
65
65
|
}, {
|
|
66
66
|
type: Inject,
|
|
67
67
|
args: [MAT_DIALOG_DATA]
|
|
68
|
-
}] }, { type: i2.ElderMasterDetailService }]
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
}] }, { type: i2.ElderMasterDetailService }] });
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItZGV0YWlsLWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy9tYXN0ZXItZGV0YWlsL2VsZGVyLWRldGFpbC1kaWFsb2cvZWxkZXItZGV0YWlsLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy9tYXN0ZXItZGV0YWlsL2VsZGVyLWRldGFpbC1kaWFsb2cvZWxkZXItZGV0YWlsLWRpYWxvZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBYSxRQUFRLEVBQWMsTUFBTSxlQUFlLENBQUM7QUFDM0csT0FBTyxFQUFDLGVBQWUsRUFBZSxNQUFNLDBCQUEwQixDQUFDO0FBQ3ZFLE9BQU8sRUFBQyxlQUFlLEVBQUUsT0FBTyxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBRTlDLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7Ozs7O0FBY3pDLE1BQU0sT0FBTywwQkFBMEI7SUFXckM7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ3FCLFNBQW1ELEVBQzFCLElBQStCLEVBQ25FLG1CQUFnRDtRQUZyQyxjQUFTLEdBQVQsU0FBUyxDQUEwQztRQUMxQixTQUFJLEdBQUosSUFBSSxDQUEyQjtRQUNuRSx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQTZCO1FBbEIxRDs7OztvRkFJNEU7UUFFM0QsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDaEMsWUFBTyxHQUFHLElBQUksZUFBZSxDQUFJLElBQUksQ0FBQyxDQUFDO1FBYXJELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxZQUFZO2FBQ2xDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO2FBQzlCLFNBQVMsQ0FBQztZQUNULElBQUksRUFBRSxJQUFJLENBQUMsRUFBRTtnQkFDWCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUMxQixDQUFDO1NBQ0YsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVEOzs7O2dGQUk0RTtJQUVyRSxXQUFXO1FBQ2hCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDckIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRXJFLEtBQUs7UUFDVixJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7SUFDaEQsQ0FBQzs4R0FsRFUsMEJBQTBCLDhEQW1CZixlQUFlO2tHQW5CMUIsMEJBQTBCLDJEQ2xCdkMsOGZBZ0JBOzsyRkRFYSwwQkFBMEI7a0JBTnRDLFNBQVM7K0JBQ0UscUJBQXFCLG1CQUdkLHVCQUF1QixDQUFDLE1BQU07OzBCQW9CNUMsUUFBUTs7MEJBQ1IsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbmplY3QsIE9uRGVzdHJveSwgT3B0aW9uYWwsIFRlbXBsYXRlUmVmfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dSZWZ9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdCwgU3ViamVjdH0gZnJvbSAncnhqcyc7XG5pbXBvcnQge0VsZGVyTWFzdGVyRGV0YWlsU2VydmljZX0gZnJvbSAnLi4vZWxkZXItbWFzdGVyLWRldGFpbC5zZXJ2aWNlJztcbmltcG9ydCB7dGFrZVVudGlsfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUVsZGVyRGV0YWlsRGlhbG9nT3B0aW9uczxUID0gYW55PiB7XG4gIGVudGl0eTogVCxcbiAgZGV0YWlsVGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPGFueT5cbn1cblxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdlbGRlci1kZXRhaWwtZGlhbG9nJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2VsZGVyLWRldGFpbC1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9lbGRlci1kZXRhaWwtZGlhbG9nLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyRGV0YWlsRGlhbG9nQ29tcG9uZW50PFQgPSBhbnk+IGltcGxlbWVudHMgT25EZXN0cm95IHtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogRmllbGRzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIHJlYWRvbmx5IGRlc3Ryb3kkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcbiAgcHVibGljIHJlYWRvbmx5IGVudGl0eSQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFQ+KG51bGwpO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvciAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBPcHRpb25hbCgpIHB1YmxpYyBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxFbGRlckRldGFpbERpYWxvZ0NvbXBvbmVudD4sXG4gICAgQE9wdGlvbmFsKCkgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBkYXRhOiBJRWxkZXJEZXRhaWxEaWFsb2dPcHRpb25zLFxuICAgIHByaXZhdGUgbWFzdGVyRGV0YWlsU2VydmljZTogRWxkZXJNYXN0ZXJEZXRhaWxTZXJ2aWNlPFQ+XG4gICkge1xuICAgIHRoaXMubWFzdGVyRGV0YWlsU2VydmljZS5jdXJyZW50SXRlbSRcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLmRlc3Ryb3kkKSlcbiAgICAgIC5zdWJzY3JpYmUoe1xuICAgICAgICBuZXh0OiBpdGVtID0+IHtcbiAgICAgICAgICB0aGlzLmVudGl0eSQubmV4dChpdGVtKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogTGlmZSBDeWNsZSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5kZXN0cm95JC5uZXh0KCk7XG4gICAgdGhpcy5kZXN0cm95JC5jb21wbGV0ZSgpO1xuICB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIFB1YmxpYyBBUEkgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIGNsb3NlKCkge1xuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKHRoaXMuZW50aXR5JC5nZXRWYWx1ZSgpKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImxheW91dC1jb2wgZnVsbFwiICpuZ0lmPVwiZW50aXR5JCB8IGFzeW5jIGFzIGVudGl0eVwiPlxuXG4gIDxzcGFuIHN0eWxlPVwid2lkdGg6IDEwMHZ3O1wiPjwvc3Bhbj5cblxuICA8IS0tIEhlYWRlciBTZWN0aW9uIC0tPlxuICA8ZWxkZXItdG9vbGJhciBjbGFzcz1cImdhcC1tZFwiID5cbiAgICA8YnV0dG9uIChjbGljayk9XCJjbG9zZSgpXCIgbWF0LWljb24tYnV0dG9uICplbGRlclRvb2xiYXJDb2x1bW49XCInbGVmdC5iZWdpbidcIj5cbiAgICAgIDxtYXQtaWNvbj5jbG9zZTwvbWF0LWljb24+XG4gICAgPC9idXR0b24+XG4gIDwvZWxkZXItdG9vbGJhcj5cblxuICA8ZGl2IGNsYXNzPVwibGF5b3V0LXJvdyBmbGV4IGdhcC1tZFwiPlxuICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJkYXRhLmRldGFpbFRlbXBsYXRlUmVmOyBjb250ZXh0OiB7JGltcGxpY2l0OiBlbnRpdHl9XCI+PC9uZy1jb250YWluZXI+XG4gIDwvZGl2PlxuXG48L2Rpdj5cbiJdfQ==
|