@theseam/ui-common 0.4.0-beta.6 → 0.4.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/breadcrumbs/breadcrumbs/breadcrumbs.component.d.ts +1 -3
- package/card/card-body/card-body.component.d.ts +2 -4
- package/card/card-footer/card-footer.component.d.ts +1 -4
- package/card/card-header/card-header.component.d.ts +1 -4
- package/card/card.component.d.ts +1 -4
- package/carousel/carousel-slide.directive.d.ts +8 -0
- package/carousel/carousel.component.d.ts +85 -0
- package/carousel/carousel.module.d.ts +11 -0
- package/carousel/index.d.ts +5 -0
- package/carousel/public-api.d.ts +3 -0
- package/checkbox/checkbox.component.d.ts +2 -4
- package/core/common-behaviors/active.d.ts +1 -1
- package/core/common-behaviors/disabled.d.ts +1 -1
- package/core/common-behaviors/initialized.d.ts +1 -1
- package/data-filters/data-filter.d.ts +1 -1
- package/datatable/datatable-column/datatable-column.component.d.ts +2 -3
- package/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.d.ts +1 -3
- package/datatable/datatable-export-button/datatable-export-button.component.d.ts +1 -3
- package/datatable/datatable-menu-bar/datatable-menu-bar.component.d.ts +2 -5
- package/datatable/datatable-menu-bar-column-center/datatable-menu-bar-column-center.component.d.ts +1 -4
- package/datatable/datatable-menu-bar-column-left/datatable-menu-bar-column-left.component.d.ts +1 -4
- package/datatable/datatable-menu-bar-column-right/datatable-menu-bar-column-right.component.d.ts +1 -4
- package/datatable/datatable-menu-bar-row/datatable-menu-bar-row.component.d.ts +1 -4
- package/datatable/datatable-menu-bar-text/datatable-menu-bar-text.component.d.ts +1 -3
- package/datatable/directives/datatable-action-menu-item.directive.d.ts +2 -4
- package/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.d.ts +1 -3
- package/datatable-dynamic/datatable-dynamic-menu-bar-content/datatable-dynamic-menu-bar-content.component.d.ts +3 -4
- package/datatable-dynamic/datatable-dynamic-menu-bar-item-manifest.d.ts +1 -1
- package/datatable-dynamic/datatable-dynamic.component.d.ts +1 -4
- package/datatable-dynamic/directives/datatable-dynamic-action-menu-item.directive.d.ts +3 -4
- package/dynamic/action/modal/dynamic-action-modal-def.d.ts +1 -1
- package/esm2020/asset-reader/asset-reader-helper.service.mjs +7 -5
- package/esm2020/asset-reader/asset-reader.module.mjs +4 -4
- package/esm2020/asset-reader/encrypted-asset-link.directive.mjs +3 -3
- package/esm2020/breadcrumbs/breadcrumb.mjs +1 -1
- package/esm2020/breadcrumbs/breadcrumbs/breadcrumbs.component.mjs +4 -5
- package/esm2020/breadcrumbs/breadcrumbs-resolver.mjs +1 -1
- package/esm2020/breadcrumbs/breadcrumbs.module.mjs +5 -5
- package/esm2020/breadcrumbs/breadcrumbs.service.mjs +7 -7
- package/esm2020/buttons/badge-button/badge-button.component.mjs +9 -7
- package/esm2020/buttons/button/button.component.mjs +12 -10
- package/esm2020/buttons/buttons.module.mjs +4 -4
- package/esm2020/buttons/progress-circle-button/progress-circle-button.component.mjs +4 -4
- package/esm2020/buttons/toggle-button/toggle-button.component.mjs +6 -6
- package/esm2020/card/card-action/card-action.component.mjs +4 -4
- package/esm2020/card/card-body/card-body.component.mjs +5 -6
- package/esm2020/card/card-footer/card-footer.component.mjs +5 -8
- package/esm2020/card/card-header/card-header.component.mjs +5 -7
- package/esm2020/card/card.component.mjs +5 -7
- package/esm2020/card/card.module.mjs +4 -4
- package/esm2020/carousel/carousel-slide.directive.mjs +16 -0
- package/esm2020/carousel/carousel.component.mjs +211 -0
- package/esm2020/carousel/carousel.module.mjs +38 -0
- package/esm2020/carousel/public-api.mjs +4 -0
- package/esm2020/carousel/theseam-ui-common-carousel.mjs +5 -0
- package/esm2020/checkbox/checkbox.component.mjs +5 -6
- package/esm2020/checkbox/checkbox.module.mjs +4 -4
- package/esm2020/checkbox/testing/checkbox.harness.mjs +1 -1
- package/esm2020/checkbox/testing/index.mjs +1 -1
- package/esm2020/confirm-dialog/confirm-click.directive.mjs +6 -6
- package/esm2020/confirm-dialog/confirm-dialog.component.mjs +3 -3
- package/esm2020/confirm-dialog/confirm-dialog.module.mjs +4 -4
- package/esm2020/confirm-dialog/confirm-dialog.service.mjs +3 -3
- package/esm2020/core/common-behaviors/active.mjs +2 -1
- package/esm2020/core/common-behaviors/disabled.mjs +2 -1
- package/esm2020/core/common-behaviors/initialized.mjs +2 -1
- package/esm2020/core/common-behaviors/tabindex.mjs +2 -1
- package/esm2020/core/input-decorators/input-boolean.decorator.mjs +4 -5
- package/esm2020/core/input-decorators/input-number.decorator.mjs +4 -5
- package/esm2020/data-exporter/data-exporter.module.mjs +4 -4
- package/esm2020/data-exporter/exporters/csv-exporter.mjs +3 -3
- package/esm2020/data-exporter/exporters/xlsx-exporter.mjs +3 -3
- package/esm2020/data-filters/data-filter.mjs +1 -1
- package/esm2020/data-filters/data-filters.module.mjs +4 -4
- package/esm2020/data-filters/filters/data-filter-search/data-filter-search.component.mjs +5 -5
- package/esm2020/data-filters/filters/data-filter-text/data-filter-text.component.mjs +6 -6
- package/esm2020/data-filters/filters/data-filter-toggle-buttons/data-filter-toggle-buttons.component.mjs +11 -8
- package/esm2020/datatable/datatable/datatable.component.mjs +11 -6
- package/esm2020/datatable/datatable-action-menu/datatable-action-menu.component.mjs +3 -3
- package/esm2020/datatable/datatable-action-menu-item/datatable-action-menu-item.component.mjs +5 -4
- package/esm2020/datatable/datatable-column/datatable-column.component.mjs +4 -5
- package/esm2020/datatable/datatable-column-preferences/datatable-column-preferences.component.mjs +3 -3
- package/esm2020/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.mjs +4 -5
- package/esm2020/datatable/datatable-export-button/datatable-export-button.component.mjs +5 -5
- package/esm2020/datatable/datatable-footer/datatable-footer-tpl.directive.mjs +3 -3
- package/esm2020/datatable/datatable-footer/datatable-footer.directive.mjs +5 -5
- package/esm2020/datatable/datatable-menu-bar/datatable-menu-bar.component.mjs +9 -13
- package/esm2020/datatable/datatable-menu-bar-column-center/datatable-menu-bar-column-center.component.mjs +5 -8
- package/esm2020/datatable/datatable-menu-bar-column-left/datatable-menu-bar-column-left.component.mjs +5 -8
- package/esm2020/datatable/datatable-menu-bar-column-right/datatable-menu-bar-column-right.component.mjs +5 -8
- package/esm2020/datatable/datatable-menu-bar-row/datatable-menu-bar-row.component.mjs +5 -8
- package/esm2020/datatable/datatable-menu-bar-text/datatable-menu-bar-text.component.mjs +4 -5
- package/esm2020/datatable/datatable-row-detail/datatable-row-detail-tpl.directive.mjs +3 -3
- package/esm2020/datatable/datatable-row-detail/datatable-row-detail.directive.mjs +5 -5
- package/esm2020/datatable/datatable.module.mjs +4 -4
- package/esm2020/datatable/directives/datatable-action-menu-item.directive.mjs +5 -6
- package/esm2020/datatable/directives/datatable-action-menu-toggle.directive.mjs +3 -3
- package/esm2020/datatable/directives/datatable-cell-tpl.directive.mjs +3 -3
- package/esm2020/datatable/directives/datatable-filter.directive.mjs +3 -3
- package/esm2020/datatable/directives/datatable-row-action-item.directive.mjs +3 -3
- package/esm2020/datatable/models/columns-alteration.mjs +1 -1
- package/esm2020/datatable/models/columns-alterations/order.columns-alteration.mjs +3 -1
- package/esm2020/datatable/models/datatable-gql-data-source.mjs +1 -1
- package/esm2020/datatable/models/internal-column-props.mjs +1 -1
- package/esm2020/datatable/models/sort-item.mjs +1 -1
- package/esm2020/datatable/services/columns-alterations-manager.service.mjs +4 -4
- package/esm2020/datatable/services/columns-manager.service.mjs +5 -5
- package/esm2020/datatable/services/datatable-column-changes.service.mjs +3 -3
- package/esm2020/datatable/services/datatable-preferences.service.mjs +5 -4
- package/esm2020/datatable/services/datatable-scrollbar-helper.service.mjs +5 -5
- package/esm2020/datatable/utils/map-columns-alterations-states.mjs +4 -1
- package/esm2020/datatable/utils/set-column-defaults.mjs +2 -2
- package/esm2020/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.mjs +5 -6
- package/esm2020/datatable-dynamic/datatable-dynamic-filter-container/datatable-dynamic-filter-container.component.mjs +4 -4
- package/esm2020/datatable-dynamic/datatable-dynamic-menu-bar-content/datatable-dynamic-menu-bar-content.component.mjs +6 -7
- package/esm2020/datatable-dynamic/datatable-dynamic-menu-bar-item-manifest.mjs +1 -1
- package/esm2020/datatable-dynamic/datatable-dynamic.component.mjs +4 -6
- package/esm2020/datatable-dynamic/datatable-dynamic.module.mjs +4 -4
- package/esm2020/datatable-dynamic/directives/datatable-dynamic-action-menu-item.directive.mjs +6 -6
- package/esm2020/datatable-dynamic/dynamic-datatable-def.service.mjs +7 -7
- package/esm2020/datatable-dynamic/dynamic-datatable-row-actions.service.mjs +6 -6
- package/esm2020/dynamic/action/api/dynamic-action-api.service.mjs +11 -8
- package/esm2020/dynamic/action/dynamic-action-helper.service.mjs +6 -5
- package/esm2020/dynamic/action/link/dynamic-action-link.service.mjs +4 -4
- package/esm2020/dynamic/action/modal/dynamic-action-modal-def.mjs +1 -1
- package/esm2020/dynamic/action/modal/dynamic-action-modal.service.mjs +4 -4
- package/esm2020/dynamic/dynamic-value-helper.service.mjs +5 -4
- package/esm2020/dynamic/evaluators/exporters-data-evaluator/exporters-data-evaluator.mjs +4 -4
- package/esm2020/dynamic/evaluators/jexl-evaluator/jexl-evaluator.mjs +5 -5
- package/esm2020/dynamic-component-loader/dynamic-component-loader.module.mjs +4 -4
- package/esm2020/dynamic-component-loader/dynamic-component-loader.service.mjs +9 -9
- package/esm2020/footer-bar/footer-bar/footer-bar.component.mjs +5 -8
- package/esm2020/footer-bar/footer-bar.module.mjs +5 -5
- package/esm2020/form-field/form-field-error.directive.mjs +4 -4
- package/esm2020/form-field/form-field-help-text.directive.mjs +3 -3
- package/esm2020/form-field/form-field-label-tpl.directive.mjs +3 -3
- package/esm2020/form-field/form-field-required-indicator.component.mjs +4 -4
- package/esm2020/form-field/form-field.component.mjs +5 -5
- package/esm2020/form-field/form-field.module.mjs +4 -4
- package/esm2020/form-field/input.directive.mjs +10 -9
- package/esm2020/form-field/testing/form-field-required-indicator.harness.mjs +1 -1
- package/esm2020/form-field/testing/index.mjs +1 -1
- package/esm2020/form-field-error/form-field-error/form-field-error.component.mjs +5 -7
- package/esm2020/form-field-error/form-field-error-list/form-field-error-list-item-tpl.directive.mjs +4 -4
- package/esm2020/form-field-error/form-field-error-list/form-field-error-list-item.directive.mjs +3 -3
- package/esm2020/form-field-error/form-field-error-list/form-field-error-list.component.mjs +8 -8
- package/esm2020/form-field-error/form-field-error.module.mjs +4 -4
- package/esm2020/framework/base-layout/base-layout.component.mjs +5 -4
- package/esm2020/framework/base-layout/base-layout.module.mjs +5 -5
- package/esm2020/framework/base-layout/directives/base-layout-content-footer.directive.mjs +3 -3
- package/esm2020/framework/base-layout/directives/base-layout-content-header.directive.mjs +3 -3
- package/esm2020/framework/base-layout/directives/base-layout-content.directive.mjs +3 -3
- package/esm2020/framework/base-layout/directives/base-layout-nav-toggle.directive.mjs +3 -3
- package/esm2020/framework/base-layout/directives/base-layout-side-bar-footer.directive.mjs +3 -3
- package/esm2020/framework/base-layout/directives/base-layout-side-bar.directive.mjs +3 -3
- package/esm2020/framework/base-layout/directives/base-layout-top-bar.directive.mjs +3 -3
- package/esm2020/framework/dashboard/dashboard-widget-container/dashboard-widget-container.component.mjs +5 -7
- package/esm2020/framework/dashboard/dashboard-widget-template-container/dashboard-widget-template-container.component.mjs +4 -5
- package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widget-portal-outlet.directive.mjs +7 -7
- package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets-preferences.service.mjs +6 -5
- package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets.component.mjs +4 -4
- package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets.service.mjs +7 -5
- package/esm2020/framework/dashboard/dashboard.component.mjs +5 -5
- package/esm2020/framework/dashboard/dashboard.module.mjs +4 -4
- package/esm2020/framework/dynamic-router/dynamic-route-def.mjs +1 -1
- package/esm2020/framework/dynamic-router/dynamic-router.module.mjs +5 -5
- package/esm2020/framework/dynamic-router/hierarchy-router-outlet/hierarchy-route-animations.mjs +1 -1
- package/esm2020/framework/dynamic-router/hierarchy-router-outlet/hierarchy-router-outlet.component.mjs +5 -6
- package/esm2020/framework/dynamic-router/resolvers/hierarchy-level.resolver.mjs +5 -6
- package/esm2020/framework/schema-form/schema-form-framework.component.mjs +3 -3
- package/esm2020/framework/schema-form/schema-form-framework.mjs +3 -3
- package/esm2020/framework/schema-form/schema-form.module.mjs +4 -4
- package/esm2020/framework/schema-form-controls/schema-form-checkbox/schema-form-checkbox.component.mjs +3 -3
- package/esm2020/framework/schema-form-controls/schema-form-controls.module.mjs +4 -4
- package/esm2020/framework/schema-form-controls/schema-form-input/schema-form-input.component.mjs +3 -3
- package/esm2020/framework/schema-form-controls/schema-form-number/schema-form-number.component.mjs +3 -3
- package/esm2020/framework/schema-form-controls/schema-form-select/schema-form-select.component.mjs +3 -3
- package/esm2020/framework/schema-form-controls/schema-form-submit/schema-form-submit.component.mjs +3 -3
- package/esm2020/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.mjs +5 -4
- package/esm2020/framework/side-nav/side-nav-item/side-nav-item.component.mjs +5 -5
- package/esm2020/framework/side-nav/side-nav-toggle/side-nav-toggle.component.mjs +5 -6
- package/esm2020/framework/side-nav/side-nav-utils.mjs +2 -1
- package/esm2020/framework/side-nav/side-nav.component.mjs +6 -7
- package/esm2020/framework/side-nav/side-nav.module.mjs +4 -4
- package/esm2020/framework/side-nav/side-nav.service.mjs +3 -3
- package/esm2020/framework/top-bar/top-bar-item.directive.mjs +3 -3
- package/esm2020/framework/top-bar/top-bar-menu-btn-detail.directive.mjs +3 -3
- package/esm2020/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.mjs +4 -6
- package/esm2020/framework/top-bar/top-bar-menu.directive.mjs +3 -3
- package/esm2020/framework/top-bar/top-bar-title/top-bar-title.component.mjs +5 -7
- package/esm2020/framework/top-bar/top-bar.component.mjs +4 -6
- package/esm2020/framework/top-bar/top-bar.module.mjs +4 -4
- package/esm2020/google-maps/google-maps/google-maps.component.mjs +23 -26
- package/esm2020/google-maps/google-maps-api-loader/lazy-google-maps-api-loader.mjs +3 -3
- package/esm2020/google-maps/google-maps-api-loader/noop-google-maps-api-loader.mjs +3 -3
- package/esm2020/google-maps/google-maps-contextmenu.mjs +9 -8
- package/esm2020/google-maps/google-maps-controls.service.mjs +3 -3
- package/esm2020/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.mjs +9 -10
- package/esm2020/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.directive.mjs +9 -9
- package/esm2020/google-maps/google-maps-recenter-button-control/google-maps-recenter-button-control.component.mjs +6 -6
- package/esm2020/google-maps/google-maps-upload-button-control/google-maps-upload-button-control.component.mjs +6 -6
- package/esm2020/google-maps/google-maps.module.mjs +4 -4
- package/esm2020/google-maps/google-maps.service.mjs +8 -8
- package/esm2020/google-maps/map-control.component.mjs +3 -3
- package/esm2020/google-maps/map-file-drop/map-file-drop.component.mjs +4 -4
- package/esm2020/google-maps/map-value-manager.service.mjs +3 -3
- package/esm2020/graphql/datatable/datatable-graphql-query-ref.mjs +1 -27
- package/esm2020/graphql/datatable/datatable-graphql.service.mjs +4 -4
- package/esm2020/graphql/datatable/datatable-helpers.mjs +2 -2
- package/esm2020/graphql/datatable/map-filter-states.mjs +2 -1
- package/esm2020/graphql/utils/inline-variables.mjs +2 -1
- package/esm2020/graphql/utils/parse-hints.mjs +3 -3
- package/esm2020/graphql/utils/to-gql.mjs +3 -3
- package/esm2020/icon/icon/icon.component.mjs +5 -5
- package/esm2020/icon/icon-btn/icon-btn.component.mjs +4 -5
- package/esm2020/icon/icon-notification/icon-notification.component.mjs +3 -3
- package/esm2020/icon/icon.module.mjs +4 -4
- package/esm2020/icon/utils/get-known-icon.mjs +71 -71
- package/esm2020/layout/breakpoint-aliases.mjs +1 -1
- package/esm2020/layout/layout.module.mjs +4 -4
- package/esm2020/layout/layout.service.mjs +3 -3
- package/esm2020/layout/observe-media-query.mjs +1 -1
- package/esm2020/loading/loading/loading.component.mjs +8 -9
- package/esm2020/loading/loading-overlay.service.mjs +3 -3
- package/esm2020/loading/loading.module.mjs +4 -4
- package/esm2020/menu/menu-divider.component.mjs +3 -3
- package/esm2020/menu/menu-footer/menu-footer.component.mjs +3 -3
- package/esm2020/menu/menu-footer-action/menu-footer-action.component.mjs +4 -4
- package/esm2020/menu/menu-header/menu-header.component.mjs +3 -3
- package/esm2020/menu/menu-item.component.mjs +4 -5
- package/esm2020/menu/menu-toggle.directive.mjs +4 -4
- package/esm2020/menu/menu.component.mjs +4 -4
- package/esm2020/menu/menu.module.mjs +4 -4
- package/esm2020/modal/directives/modal-close.directive.mjs +3 -3
- package/esm2020/modal/directives/modal-footer-tpl.directive.mjs +3 -3
- package/esm2020/modal/directives/modal-header-icon-tpl.directive.mjs +3 -3
- package/esm2020/modal/directives/modal-header-title-tpl.directive.mjs +3 -3
- package/esm2020/modal/directives/modal-title.directive.mjs +3 -3
- package/esm2020/modal/directives/modal.directive.mjs +5 -5
- package/esm2020/modal/modal/modal.component.mjs +6 -7
- package/esm2020/modal/modal-body/modal-body.component.mjs +5 -7
- package/esm2020/modal/modal-config.mjs +1 -1
- package/esm2020/modal/modal-container/modal-container.component.mjs +4 -4
- package/esm2020/modal/modal-footer/modal-footer.component.mjs +5 -7
- package/esm2020/modal/modal-header/modal-header.component.mjs +5 -7
- package/esm2020/modal/modal-ref.mjs +1 -1
- package/esm2020/modal/modal.module.mjs +4 -4
- package/esm2020/modal/modal.service.mjs +26 -23
- package/esm2020/modal/route-modal/route-modal.component.mjs +4 -5
- package/esm2020/popover/popover/popover.component.mjs +3 -3
- package/esm2020/popover/popover.directive.mjs +4 -4
- package/esm2020/popover/popover.module.mjs +5 -5
- package/esm2020/progress/progress-circle/progress-circle.component.mjs +10 -10
- package/esm2020/progress/progress.module.mjs +4 -4
- package/esm2020/scrollbar/overlay-scrollbar.directive.mjs +4 -5
- package/esm2020/scrollbar/overlay-scrollbars.service.mjs +4 -4
- package/esm2020/scrollbar/scrollbar.module.mjs +4 -4
- package/esm2020/services/asset-loader.service.mjs +5 -6
- package/esm2020/services/font-loader.service.mjs +5 -6
- package/esm2020/services/router-helpers.service.mjs +3 -3
- package/esm2020/shared/components/password-input-reveal/password-input-reveal.component.mjs +3 -3
- package/esm2020/shared/directives/auto-focus.directive.mjs +3 -3
- package/esm2020/shared/directives/click-outside.directive.mjs +3 -3
- package/esm2020/shared/directives/disable-control.directive.mjs +3 -3
- package/esm2020/shared/directives/elem-resized.directive.mjs +5 -5
- package/esm2020/shared/directives/hover-class-toggle.directive.mjs +4 -4
- package/esm2020/shared/directives/hover-class.directive.mjs +3 -3
- package/esm2020/shared/directives/ng-select-extra.directive.mjs +7 -7
- package/esm2020/shared/directives/ngx-quill-extra.directive.mjs +5 -5
- package/esm2020/shared/pipes/mask-chars.pipe.mjs +3 -3
- package/esm2020/shared/pipes/truncate.pipe.mjs +3 -3
- package/esm2020/shared/shared.module.mjs +4 -4
- package/esm2020/storage/local-storage.service.mjs +8 -8
- package/esm2020/storage/localstorage-memory.mjs +4 -4
- package/esm2020/story-helpers/arg-type-helpers.mjs +1 -1
- package/esm2020/story-helpers/initial-route.service.mjs +3 -3
- package/esm2020/story-helpers/on-story-bootstrapped-trigger.mjs +2 -1
- package/esm2020/story-helpers/public-api.mjs +2 -2
- package/esm2020/story-helpers/story-empty-with-route.component.mjs +3 -3
- package/esm2020/story-helpers/story-empty.component.mjs +3 -3
- package/esm2020/story-helpers/story-helper-components.module.mjs +4 -4
- package/esm2020/story-helpers/story-initial-route.mjs +4 -4
- package/esm2020/story-helpers/story-modal-container.component.mjs +4 -4
- package/esm2020/story-helpers/story-toastr.service.mjs +3 -3
- package/esm2020/tabbed/directives/tabbed-tab-content.directive.mjs +5 -5
- package/esm2020/tabbed/directives/tabbed-tab.directive.mjs +5 -4
- package/esm2020/tabbed/tabbed-content/tabbed-content.component.mjs +5 -7
- package/esm2020/tabbed/tabbed-item/tabbed-item.component.mjs +5 -6
- package/esm2020/tabbed/tabbed.component.mjs +4 -4
- package/esm2020/tabbed/tabbed.module.mjs +4 -4
- package/esm2020/tabbed/tabbed.service.mjs +5 -5
- package/esm2020/table/table/table.component.mjs +5 -6
- package/esm2020/table/table.module.mjs +4 -4
- package/esm2020/table-cell-type/services/table-cell-types-helpers.service.mjs +5 -5
- package/esm2020/table-cell-type/table-cell-type-export-props.mjs +1 -1
- package/esm2020/table-cell-type/table-cell-type-models.mjs +1 -1
- package/esm2020/table-cell-type/table-cell-type-selector.component.mjs +5 -6
- package/esm2020/table-cell-type/table-cell-type.module.mjs +4 -4
- package/esm2020/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.mjs +12 -12
- package/esm2020/table-cell-types/table-cell-type-date/table-cell-type-date.component.mjs +8 -12
- package/esm2020/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.mjs +14 -14
- package/esm2020/table-cell-types/table-cell-type-icon/table-cell-type-icon.component.mjs +10 -10
- package/esm2020/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.mjs +14 -14
- package/esm2020/table-cell-types/table-cell-type-phone/table-cell-type-phone.component.mjs +6 -7
- package/esm2020/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle.component.mjs +11 -10
- package/esm2020/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon.component.mjs +7 -8
- package/esm2020/table-cell-types/table-cell-type-string/table-cell-type-string.component.mjs +11 -8
- package/esm2020/table-cell-types/table-cell-types.module.mjs +4 -4
- package/esm2020/tel-input/intl-tel-input.mjs +2 -2
- package/esm2020/tel-input/phone-number.pipe.mjs +3 -3
- package/esm2020/tel-input/tel-input/tel-input.component.mjs +5 -6
- package/esm2020/tel-input/tel-input.directive.mjs +4 -4
- package/esm2020/tel-input/tel-input.module.mjs +4 -4
- package/esm2020/tel-input/utils/add-country-code.mjs +4 -4
- package/esm2020/tel-input/utils/process-country-codes.mjs +4 -7
- package/esm2020/testing/story-expect.mjs +2 -1
- package/esm2020/tiled-select/components/tiled-select/tiled-select.component.mjs +5 -6
- package/esm2020/tiled-select/components/tiled-select-tile/tiled-select-tile.component.mjs +4 -5
- package/esm2020/tiled-select/components/tiled-select-tile-icon/tiled-select-tile-icon.component.mjs +12 -13
- package/esm2020/tiled-select/directives/tiled-select-tile-icon-tpl.directive.mjs +3 -3
- package/esm2020/tiled-select/directives/tiled-select-tile-label-tpl.directive.mjs +3 -3
- package/esm2020/tiled-select/directives/tiled-select-tile-overlay.directive.mjs +3 -3
- package/esm2020/tiled-select/testing/index.mjs +1 -1
- package/esm2020/tiled-select/tiled-select.module.mjs +4 -4
- package/esm2020/toggle-edit/toggle-edit-actions-container/toggle-edit-actions-container.component.mjs +5 -8
- package/esm2020/toggle-edit/toggle-edit-display-tpl.directive.mjs +3 -3
- package/esm2020/toggle-edit/toggle-edit-keyboard-listener.service.mjs +3 -3
- package/esm2020/toggle-edit/toggle-edit.component.mjs +7 -7
- package/esm2020/toggle-edit/toggle-edit.module.mjs +4 -4
- package/esm2020/toggle-group/toggle-group-option.directive.mjs +3 -3
- package/esm2020/toggle-group/toggle-group.directive.mjs +6 -6
- package/esm2020/toggle-group/toggle-group.module.mjs +4 -4
- package/esm2020/unsaved-changes-dialog/unsaved-changes-can-deactivate.mjs +5 -5
- package/esm2020/unsaved-changes-dialog/unsaved-changes-dialog.component.mjs +5 -8
- package/esm2020/unsaved-changes-dialog/unsaved-changes-dialog.guard.mjs +5 -4
- package/esm2020/unsaved-changes-dialog/unsaved-changes-dialog.module.mjs +4 -4
- package/esm2020/utils/array-move.mjs +1 -1
- package/esm2020/utils/cdk/get-closest-widget-cdk-drag.mjs +3 -3
- package/esm2020/utils/file-utils.mjs +2 -2
- package/esm2020/utils/form/get-control-path.mjs +6 -5
- package/esm2020/utils/geo-json/geo-json-to-area.mjs +3 -3
- package/esm2020/utils/geo-json/is-only-geometry-types.validator.mjs +1 -1
- package/esm2020/utils/geo-json/min-max-points.validator.mjs +5 -5
- package/esm2020/utils/geo-json/read-geo-file.mjs +3 -2
- package/esm2020/utils/has-property.mjs +2 -2
- package/esm2020/utils/load-style-sheet.mjs +2 -2
- package/esm2020/utils/load-style.mjs +2 -2
- package/esm2020/utils/obj-utils.mjs +2 -2
- package/esm2020/utils/polling-ticker.mjs +2 -2
- package/esm2020/utils/router/operators/activated-routes-with-data-property.mjs +2 -2
- package/esm2020/utils/router/route-snapshot-path-full.mjs +2 -2
- package/esm2020/utils/router/route-snapshot-path-relative.mjs +2 -2
- package/esm2020/utils/router/will-have-data-prop.mjs +3 -3
- package/esm2020/utils/subscriber-count.mjs +2 -1
- package/esm2020/utils/toggle-attribute.mjs +6 -5
- package/esm2020/utils/wait-on-condition-async.mjs +5 -5
- package/esm2020/vertical-list-filter/public-api.mjs +3 -0
- package/esm2020/vertical-list-filter/testing/index.mjs +2 -0
- package/esm2020/vertical-list-filter/testing/vertical-list-filter.harness.mjs +28 -0
- package/esm2020/vertical-list-filter/theseam-ui-common-vertical-list-filter.mjs +5 -0
- package/esm2020/vertical-list-filter/vertical-list-filter.component.mjs +52 -0
- package/esm2020/viewers/html-template-viewer/html-template-viewer.component.mjs +4 -4
- package/esm2020/viewers/html-template-viewer/html-template-viewer.module.mjs +4 -4
- package/esm2020/viewers/pdf-viewer/pdf-page/pdf-page.component.mjs +5 -4
- package/esm2020/viewers/pdf-viewer/pdf-renderer.service.mjs +4 -4
- package/esm2020/viewers/pdf-viewer/pdf-viewer.component.mjs +5 -4
- package/esm2020/viewers/pdf-viewer/pdf-viewer.module.mjs +4 -4
- package/esm2020/widget/directives/widget-drag-handle.directive.mjs +7 -7
- package/esm2020/widget/directives/widget-icon-tpl.directive.mjs +3 -3
- package/esm2020/widget/directives/widget-title-tpl.directive.mjs +3 -3
- package/esm2020/widget/widget/widget.component.mjs +3 -3
- package/esm2020/widget/widget-content-components/widget-button-group/widget-button-group.component.mjs +5 -8
- package/esm2020/widget/widget-content-components/widget-button-group/widget-button-group.module.mjs +4 -4
- package/esm2020/widget/widget-content-components/widget-content-header/widget-content-header.component.mjs +5 -8
- package/esm2020/widget/widget-content-components/widget-content-header/widget-content-header.module.mjs +4 -4
- package/esm2020/widget/widget-content-components/widget-description/widget-description.component.mjs +3 -3
- package/esm2020/widget/widget-content-components/widget-description/widget-description.module.mjs +4 -4
- package/esm2020/widget/widget-content-components/widget-empty-label/widget-empty-label.component.mjs +6 -7
- package/esm2020/widget/widget-content-components/widget-empty-label/widget-empty-label.module.mjs +4 -4
- package/esm2020/widget/widget-content-components/widget-footer-link/widget-footer-link.component.mjs +5 -7
- package/esm2020/widget/widget-content-components/widget-footer-link/widget-footer-link.module.mjs +4 -4
- package/esm2020/widget/widget-content-components/widget-footer-text/widget-footer-text.component.mjs +5 -8
- package/esm2020/widget/widget-content-components/widget-footer-text/widget-footer-text.module.mjs +4 -4
- package/esm2020/widget/widget-content-components/widget-header-badge/widget-header-badge.component.mjs +5 -5
- package/esm2020/widget/widget-content-components/widget-header-badge/widget-header-badge.module.mjs +4 -4
- package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item-icon-tpl.directive.mjs +3 -3
- package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item.component.mjs +16 -19
- package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group.component.mjs +5 -7
- package/esm2020/widget/widget-content-components/widget-list-group/widget-list-group.module.mjs +4 -4
- package/esm2020/widget/widget-content-components/widget-table/widget-table.component.mjs +5 -5
- package/esm2020/widget/widget-content-components/widget-table/widget-table.module.mjs +4 -4
- package/esm2020/widget/widget-content-components/widget-tile/widget-tile-footer/widget-tile-footer.component.mjs +6 -9
- package/esm2020/widget/widget-content-components/widget-tile/widget-tile-footer-item/widget-tile-footer-item.component.mjs +5 -6
- package/esm2020/widget/widget-content-components/widget-tile/widget-tile-group/widget-tile-group.component.mjs +5 -8
- package/esm2020/widget/widget-content-components/widget-tile/widget-tile-secondary-icon.directive.mjs +5 -5
- package/esm2020/widget/widget-content-components/widget-tile/widget-tile.component.mjs +9 -8
- package/esm2020/widget/widget-content-components/widget-tile/widget-tile.module.mjs +10 -10
- package/esm2020/widget/widget-content-components/widget-tile-list/widget-tile-list.component.mjs +5 -8
- package/esm2020/widget/widget-content-components/widget-tile-list/widget-tile-list.module.mjs +4 -4
- package/esm2020/widget/widget-footer/widget-footer.component.mjs +5 -7
- package/esm2020/widget/widget-registry.service.mjs +6 -5
- package/esm2020/widget/widget.module.mjs +7 -7
- package/fesm2015/theseam-ui-common-asset-reader.mjs +13 -11
- package/fesm2015/theseam-ui-common-asset-reader.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-breadcrumbs.mjs +13 -14
- package/fesm2015/theseam-ui-common-breadcrumbs.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-buttons.mjs +31 -27
- package/fesm2015/theseam-ui-common-buttons.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-card.mjs +23 -31
- package/fesm2015/theseam-ui-common-card.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-carousel.mjs +265 -0
- package/fesm2015/theseam-ui-common-carousel.mjs.map +1 -0
- package/fesm2015/theseam-ui-common-checkbox.mjs +8 -9
- package/fesm2015/theseam-ui-common-checkbox.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-confirm-dialog.mjs +15 -15
- package/fesm2015/theseam-ui-common-confirm-dialog.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-core.mjs +10 -8
- package/fesm2015/theseam-ui-common-core.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-data-exporter.mjs +10 -10
- package/fesm2015/theseam-ui-common-data-filters.mjs +23 -20
- package/fesm2015/theseam-ui-common-data-filters.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-datatable-dynamic.mjs +34 -38
- package/fesm2015/theseam-ui-common-datatable-dynamic.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-datatable.mjs +115 -123
- package/fesm2015/theseam-ui-common-datatable.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-dynamic-component-loader.mjs +12 -12
- package/fesm2015/theseam-ui-common-dynamic-component-loader.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-dynamic.mjs +36 -26
- package/fesm2015/theseam-ui-common-dynamic.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-footer-bar.mjs +8 -11
- package/fesm2015/theseam-ui-common-footer-bar.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-form-field-error.mjs +21 -23
- package/fesm2015/theseam-ui-common-form-field-error.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-form-field.mjs +29 -28
- package/fesm2015/theseam-ui-common-form-field.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-framework.mjs +153 -160
- package/fesm2015/theseam-ui-common-framework.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-google-maps.mjs +84 -86
- package/fesm2015/theseam-ui-common-google-maps.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-graphql.mjs +10 -34
- package/fesm2015/theseam-ui-common-graphql.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-icon.mjs +84 -85
- package/fesm2015/theseam-ui-common-icon.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-layout.mjs +7 -7
- package/fesm2015/theseam-ui-common-layout.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-loading.mjs +14 -15
- package/fesm2015/theseam-ui-common-loading.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-menu.mjs +25 -26
- package/fesm2015/theseam-ui-common-menu.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-modal.mjs +71 -76
- package/fesm2015/theseam-ui-common-modal.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-popover.mjs +10 -10
- package/fesm2015/theseam-ui-common-popover.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-progress.mjs +13 -13
- package/fesm2015/theseam-ui-common-progress.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-scrollbar.mjs +10 -11
- package/fesm2015/theseam-ui-common-scrollbar.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-services.mjs +11 -13
- package/fesm2015/theseam-ui-common-services.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-shared.mjs +42 -42
- package/fesm2015/theseam-ui-common-shared.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-storage.mjs +10 -10
- package/fesm2015/theseam-ui-common-storage.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-story-helpers.mjs +25 -100
- package/fesm2015/theseam-ui-common-story-helpers.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-tabbed.mjs +27 -29
- package/fesm2015/theseam-ui-common-tabbed.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-table-cell-type.mjs +12 -13
- package/fesm2015/theseam-ui-common-table-cell-type.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-table-cell-types.mjs +87 -89
- package/fesm2015/theseam-ui-common-table-cell-types.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-table.mjs +8 -9
- package/fesm2015/theseam-ui-common-table.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-tel-input.mjs +21 -25
- package/fesm2015/theseam-ui-common-tel-input.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-testing.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-tiled-select.mjs +31 -34
- package/fesm2015/theseam-ui-common-tiled-select.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-toggle-edit.mjs +20 -23
- package/fesm2015/theseam-ui-common-toggle-edit.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-toggle-group.mjs +12 -12
- package/fesm2015/theseam-ui-common-toggle-group.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-unsaved-changes-dialog.mjs +16 -18
- package/fesm2015/theseam-ui-common-unsaved-changes-dialog.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-utils.mjs +36 -32
- package/fesm2015/theseam-ui-common-utils.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-vertical-list-filter.mjs +96 -0
- package/fesm2015/theseam-ui-common-vertical-list-filter.mjs.map +1 -0
- package/fesm2015/theseam-ui-common-viewers.mjs +22 -20
- package/fesm2015/theseam-ui-common-viewers.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-widget.mjs +159 -186
- package/fesm2015/theseam-ui-common-widget.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-asset-reader.mjs +13 -11
- package/fesm2020/theseam-ui-common-asset-reader.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-breadcrumbs.mjs +13 -14
- package/fesm2020/theseam-ui-common-breadcrumbs.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-buttons.mjs +31 -27
- package/fesm2020/theseam-ui-common-buttons.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-card.mjs +23 -31
- package/fesm2020/theseam-ui-common-card.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-carousel.mjs +265 -0
- package/fesm2020/theseam-ui-common-carousel.mjs.map +1 -0
- package/fesm2020/theseam-ui-common-checkbox.mjs +8 -9
- package/fesm2020/theseam-ui-common-checkbox.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-confirm-dialog.mjs +15 -15
- package/fesm2020/theseam-ui-common-confirm-dialog.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-core.mjs +10 -8
- package/fesm2020/theseam-ui-common-core.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-data-exporter.mjs +10 -10
- package/fesm2020/theseam-ui-common-data-filters.mjs +23 -20
- package/fesm2020/theseam-ui-common-data-filters.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-datatable-dynamic.mjs +34 -38
- package/fesm2020/theseam-ui-common-datatable-dynamic.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-datatable.mjs +115 -123
- package/fesm2020/theseam-ui-common-datatable.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-dynamic-component-loader.mjs +12 -12
- package/fesm2020/theseam-ui-common-dynamic-component-loader.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-dynamic.mjs +36 -26
- package/fesm2020/theseam-ui-common-dynamic.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-footer-bar.mjs +8 -11
- package/fesm2020/theseam-ui-common-footer-bar.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-form-field-error.mjs +21 -23
- package/fesm2020/theseam-ui-common-form-field-error.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-form-field.mjs +29 -28
- package/fesm2020/theseam-ui-common-form-field.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-framework.mjs +153 -160
- package/fesm2020/theseam-ui-common-framework.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-google-maps.mjs +83 -86
- package/fesm2020/theseam-ui-common-google-maps.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-graphql.mjs +10 -34
- package/fesm2020/theseam-ui-common-graphql.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-icon.mjs +84 -85
- package/fesm2020/theseam-ui-common-icon.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-layout.mjs +16 -8
- package/fesm2020/theseam-ui-common-layout.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-loading.mjs +14 -15
- package/fesm2020/theseam-ui-common-loading.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-menu.mjs +25 -26
- package/fesm2020/theseam-ui-common-menu.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-modal.mjs +71 -76
- package/fesm2020/theseam-ui-common-modal.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-models.mjs +2 -1
- package/fesm2020/theseam-ui-common-models.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-popover.mjs +10 -10
- package/fesm2020/theseam-ui-common-popover.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-progress.mjs +13 -13
- package/fesm2020/theseam-ui-common-progress.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-scrollbar.mjs +10 -11
- package/fesm2020/theseam-ui-common-scrollbar.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-services.mjs +11 -13
- package/fesm2020/theseam-ui-common-services.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-shared.mjs +42 -42
- package/fesm2020/theseam-ui-common-shared.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-storage.mjs +10 -10
- package/fesm2020/theseam-ui-common-storage.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-story-helpers.mjs +25 -96
- package/fesm2020/theseam-ui-common-story-helpers.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-tabbed.mjs +27 -29
- package/fesm2020/theseam-ui-common-tabbed.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-table-cell-type.mjs +12 -13
- package/fesm2020/theseam-ui-common-table-cell-type.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-table-cell-types.mjs +87 -89
- package/fesm2020/theseam-ui-common-table-cell-types.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-table.mjs +8 -9
- package/fesm2020/theseam-ui-common-table.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-tel-input.mjs +21 -25
- package/fesm2020/theseam-ui-common-tel-input.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-testing.mjs +1 -0
- package/fesm2020/theseam-ui-common-testing.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-tiled-select.mjs +31 -34
- package/fesm2020/theseam-ui-common-tiled-select.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-toggle-edit.mjs +20 -23
- package/fesm2020/theseam-ui-common-toggle-edit.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-toggle-group.mjs +12 -12
- package/fesm2020/theseam-ui-common-toggle-group.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-unsaved-changes-dialog.mjs +16 -18
- package/fesm2020/theseam-ui-common-unsaved-changes-dialog.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-utils.mjs +36 -32
- package/fesm2020/theseam-ui-common-utils.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-vertical-list-filter.mjs +87 -0
- package/fesm2020/theseam-ui-common-vertical-list-filter.mjs.map +1 -0
- package/fesm2020/theseam-ui-common-viewers.mjs +22 -20
- package/fesm2020/theseam-ui-common-viewers.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-widget.mjs +159 -186
- package/fesm2020/theseam-ui-common-widget.mjs.map +1 -1
- package/footer-bar/footer-bar/footer-bar.component.d.ts +1 -4
- package/form-field-error/form-field-error/form-field-error.component.d.ts +1 -4
- package/form-field-error/form-field-error-list/form-field-error-list.component.d.ts +2 -3
- package/framework/dashboard/dashboard-widget-container/dashboard-widget-container.component.d.ts +2 -4
- package/framework/dashboard/dashboard-widget-template-container/dashboard-widget-template-container.component.d.ts +2 -3
- package/framework/dashboard/dashboard.component.d.ts +0 -1
- package/framework/dynamic-router/hierarchy-router-outlet/hierarchy-router-outlet.component.d.ts +2 -3
- package/framework/dynamic-router/resolvers/hierarchy-level.resolver.d.ts +0 -1
- package/framework/side-nav/side-nav-toggle/side-nav-toggle.component.d.ts +2 -4
- package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.d.ts +3 -5
- package/framework/top-bar/top-bar-title/top-bar-title.component.d.ts +1 -4
- package/framework/top-bar/top-bar.component.d.ts +2 -4
- package/google-maps/google-maps/google-maps.component.d.ts +3 -6
- package/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.d.ts +2 -3
- package/graphql/datatable/datatable-graphql-query-ref.d.ts +0 -1
- package/icon/icon-btn/icon-btn.component.d.ts +2 -3
- package/loading/loading/loading.component.d.ts +1 -4
- package/menu/menu-item.component.d.ts +2 -3
- package/modal/modal/modal.component.d.ts +3 -4
- package/modal/modal-body/modal-body.component.d.ts +1 -4
- package/modal/modal-footer/modal-footer.component.d.ts +1 -4
- package/modal/modal-header/modal-header.component.d.ts +1 -4
- package/modal/route-modal/route-modal.component.d.ts +2 -3
- package/package.json +17 -1
- package/progress/progress-circle/progress-circle.component.d.ts +0 -1
- package/scrollbar/overlay-scrollbar.directive.d.ts +2 -3
- package/services/asset-loader.service.d.ts +0 -1
- package/services/font-loader.service.d.ts +0 -1
- package/story-helpers/public-api.d.ts +0 -1
- package/tabbed/directives/tabbed-tab-content.directive.d.ts +0 -1
- package/tabbed/tabbed-content/tabbed-content.component.d.ts +1 -4
- package/tabbed/tabbed-item/tabbed-item.component.d.ts +2 -4
- package/tabbed/tabbed.service.d.ts +0 -1
- package/table/table/table.component.d.ts +2 -3
- package/table-cell-type/table-cell-type-models.d.ts +1 -1
- package/table-cell-type/table-cell-type-selector.component.d.ts +3 -4
- package/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.d.ts +2 -3
- package/table-cell-types/table-cell-type-date/table-cell-type-date.component.d.ts +2 -3
- package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.d.ts +2 -3
- package/table-cell-types/table-cell-type-icon/table-cell-type-icon.component.d.ts +2 -3
- package/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.d.ts +2 -3
- package/table-cell-types/table-cell-type-phone/table-cell-type-phone.component.d.ts +2 -3
- package/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle.component.d.ts +2 -3
- package/table-cell-types/table-cell-type-progress-circle-icon/table-cell-type-progress-circle-icon.component.d.ts +2 -3
- package/tiled-select/components/tiled-select/tiled-select.component.d.ts +2 -3
- package/tiled-select/components/tiled-select-tile-icon/tiled-select-tile-icon.component.d.ts +1 -4
- package/toggle-edit/toggle-edit-actions-container/toggle-edit-actions-container.component.d.ts +1 -4
- package/toggle-group/toggle-group.directive.d.ts +0 -1
- package/unsaved-changes-dialog/unsaved-changes-dialog.component.d.ts +1 -4
- package/utils/obj-utils.d.ts +2 -2
- package/vertical-list-filter/index.d.ts +5 -0
- package/vertical-list-filter/public-api.d.ts +2 -0
- package/vertical-list-filter/testing/index.d.ts +1 -0
- package/vertical-list-filter/testing/vertical-list-filter.harness.d.ts +9 -0
- package/vertical-list-filter/vertical-list-filter.component.d.ts +17 -0
- package/widget/widget-content-components/widget-button-group/widget-button-group.component.d.ts +1 -4
- package/widget/widget-content-components/widget-content-header/widget-content-header.component.d.ts +1 -4
- package/widget/widget-content-components/widget-empty-label/widget-empty-label.component.d.ts +2 -3
- package/widget/widget-content-components/widget-footer-link/widget-footer-link.component.d.ts +1 -4
- package/widget/widget-content-components/widget-footer-text/widget-footer-text.component.d.ts +1 -4
- package/widget/widget-content-components/widget-header-badge/widget-header-badge.component.d.ts +2 -3
- package/widget/widget-content-components/widget-list-group/widget-list-group-item/widget-list-group-item.component.d.ts +4 -7
- package/widget/widget-content-components/widget-list-group/widget-list-group.component.d.ts +1 -4
- package/widget/widget-content-components/widget-table/widget-table.component.d.ts +0 -1
- package/widget/widget-content-components/widget-tile/widget-tile-footer/widget-tile-footer.component.d.ts +1 -4
- package/widget/widget-content-components/widget-tile/widget-tile-footer-item/widget-tile-footer-item.component.d.ts +2 -3
- package/widget/widget-content-components/widget-tile/widget-tile-group/widget-tile-group.component.d.ts +1 -4
- package/widget/widget-content-components/widget-tile-list/widget-tile-list.component.d.ts +1 -4
- package/widget/widget-footer/widget-footer.component.d.ts +1 -4
- package/esm2020/story-helpers/args-to-tpl.mjs +0 -72
- package/story-helpers/args-to-tpl.d.ts +0 -24
|
@@ -160,7 +160,7 @@ function _createDatatableResultsObservable(datatable$, mappers, context$) {
|
|
|
160
160
|
pageInfo,
|
|
161
161
|
sorts,
|
|
162
162
|
filter: filterInfo,
|
|
163
|
-
context
|
|
163
|
+
context
|
|
164
164
|
})));
|
|
165
165
|
})).subscribe(subscriber);
|
|
166
166
|
return () => {
|
|
@@ -172,4 +172,4 @@ function _createDatatableResultsObservable(datatable$, mappers, context$) {
|
|
|
172
172
|
// function _isPagingDisabled<TData, TVariables, TRow>(queryRef: DatatableGraphQLQueryRef<TData, TVariables, TRow>): boolean {
|
|
173
173
|
// return queryRef.getQueryProcessingConfig()?.disablePaging ?? false
|
|
174
174
|
// }
|
|
175
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datatable-helpers.js","sourceRoot":"","sources":["../../../../../projects/ui-common/graphql/datatable/datatable-helpers.ts"],"names":[],"mappings":"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","sourcesContent":["import { isDevMode } from '@angular/core'\nimport { combineLatest, defer, Observable, of, ReplaySubject, Subject, Subscriber } from 'rxjs'\nimport { catchError, distinctUntilChanged, finalize, map, shareReplay, startWith, switchMap, take, tap } from 'rxjs/operators'\n\nimport { notNullOrUndefined, subscriberCount, wrapIntoObservable } from '@theseam/ui-common/utils'\nimport { EmptyObject } from 'apollo-angular/types'\nimport { SortItem } from '@theseam/ui-common/datatable'\n\nimport { GqlDatatableAccessor } from '../models'\nimport { createPageInfoObservable } from './create-page-info-observable'\nimport { DatatableGraphQLQueryRef } from './datatable-graphql-query-ref'\nimport { FilterStateMapperResult, FilterStateMappers, mapFilterStates } from './map-filter-states'\nimport { mapPageInfo, PageInfoMapper, PageInfoMapperResult } from './map-page-info'\nimport { MapperContext } from './mapper-context'\n\nexport type SortsMapperResult = { [name: string]: any }[]\nexport type SortsMapper = (sorts: SortItem[], context: MapperContext)\n  => (SortsMapperResult | Promise<SortsMapperResult> | Observable<SortsMapperResult>)\n\ninterface DatatableResults {\n  pageInfo: PageInfoMapperResult\n  sorts: SortsMapperResult\n  filter: FilterStateMapperResult\n  context: MapperContext\n}\n\ninterface DatatableMappers {\n  pageInfo: PageInfoMapper\n  sorts: SortsMapper\n  filters: FilterStateMappers\n}\n\nexport function observeRowsWithGqlInputsHandling<TData, TRow, GqlVariables extends EmptyObject>(\n  queryRef: DatatableGraphQLQueryRef<TData, GqlVariables, TRow>,\n  rows: Observable<TRow[]>,\n  datatable: Observable<GqlDatatableAccessor | undefined> | Promise<GqlDatatableAccessor | undefined> | GqlDatatableAccessor,\n  extraVariables: Observable<Partial<GqlVariables>> | Promise<Partial<GqlVariables>> | Partial<GqlVariables>,\n  sortsMapper: SortsMapper,\n  filterStateMappers: FilterStateMappers\n): Observable<TRow[]> {\n  return new Observable<TRow[]>((subscriber: Subscriber<TRow[]>) => {\n    const datatable$ = wrapIntoObservable(datatable)\n    const extraVariables$ = wrapIntoObservable<Partial<GqlVariables>>(extraVariables)\n\n    const context$ = extraVariables$.pipe(\n      map(_extraVariables => {\n        const context: MapperContext = {\n          extraVariables: _extraVariables\n        }\n\n        return context\n      }),\n      shareReplay({ bufferSize: 1, refCount: true })\n    )\n\n    const datatableMappers: DatatableMappers = {\n      pageInfo: mapPageInfo,\n      sorts: sortsMapper,\n      filters: filterStateMappers,\n    }\n\n    const datatableResults$ = _createDatatableResultsObservable(\n      datatable$,\n      datatableMappers,\n      context$,\n    )\n\n    const queryVariablesChanged$ = datatableResults$.pipe(\n      tap(results => {\n        queryRef.setVariables({\n          ...(results.context || {}),\n          ...results.pageInfo,\n          ...(results.sorts.length > 0 ? { order: results.sorts } : {}),\n          ...(results.filter?.variables || {}),\n          ...(results.filter?.filter ? { where: results.filter.filter } : {})\n        } as any)\n      })\n    )\n\n    // const _emitSubject = new Subject<void>()\n\n    // const queryVarsChangedSub = queryVariablesChanged$.pipe(\n    //   switchMap(() => subscriberCount(rows, 'rows'))\n    // ).subscribe(subscriber)\n    const queryVarsChangedSub = queryVariablesChanged$.subscribe()\n\n    const _sub = subscriberCount(rows, 'rows').subscribe(subscriber)\n\n    return () => {\n      queryVarsChangedSub.unsubscribe()\n      _sub.unsubscribe()\n    }\n  })\n\n\n\n\n  // const context$ = extraVariables$.pipe(\n  //   map(_extraVariables => {\n  //     const context: MapperContext = {\n  //       extraVariables: _extraVariables\n  //     }\n\n  //     return context\n  //   })\n  // )\n\n  // const datatableMappers: DatatableMappers = {\n  //   pageInfo: mapPageInfo,\n  //   sorts: sortsMapper,\n  //   filters: filterStateMappers,\n  // }\n\n  // const datatableResults$ = _createDatatableResultsObservable(\n  //   datatable$,\n  //   datatableMappers,\n  //   context$,\n  // )\n\n  // const queryVariablesChanged$ = datatableResults$.pipe(\n  //   tap(results => {\n  //     queryRef.setVariables({\n  //       ...(results.extraVariables || {}),\n  //       ...results.pageInfo,\n  //       ...(results.sorts.length > 0 ? { order: results.sorts } : {}),\n  //       ...(results.filterInfo?.variables || {}),\n  //       ...(results.filterInfo?.filter ? { where: results.filterInfo.filter } : {})\n  //     } as any)\n  //   })\n  // )\n\n\n\n  // const handleQueryInputs =  combineLatest([ extraVariables$, pageInfo$ ]).pipe(\n  //   switchMap(([ _extraVariables, pageInfo ]) => {\n  //     // console.log('_extraVariables, pageInfo', _extraVariables, pageInfo)\n  //     const context: MapperContext = {\n  //       extraVariables: _extraVariables\n  //     }\n\n\n  //     return combineLatest([ sorts$, filterInfo$ ]).pipe(\n  //       // map(([ sorts, filterInfo ]) => ({ extraVariables: _extraVariables, pageInfo, sorts, filterInfo }))\n  //       map(([ sorts, filterInfo ]) => {\n  //         // console.log('sorts, filterInfo', sorts, filterInfo)\n  //         return { extraVariables: _extraVariables, pageInfo, sorts, filterInfo }\n  //       })\n  //     )\n  //   }),\n  //   tap(v => {\n  //     // console.log('~~~', v)\n  //     queryRef.setVariables({\n  //       ...(v.extraVariables || {}),\n  //       ...v.pageInfo,\n  //       ...(v.sorts.length > 0 ? { order: v.sorts } : {}),\n  //       ...(v.filterInfo?.variables || {}),\n  //       ...(v.filterInfo?.filter ? { where: v.filterInfo.filter } : {})\n  //     } as any)\n  //   })\n  // )\n\n  // return defer(() => {\n  //   const _emitted = new Subject<void>()\n  //   const handlerSub = handleQueryInputs.pipe(\n  //     // skip(1)\n  //   // ).subscribe(() => _emitted.next())\n  //   ).subscribe(() => {\n  //     _emitted.next()\n  //   })\n  //   return _emitted.pipe(\n  //     // tap(v => {\n  //     //   console.log('emitted', v)\n  //     // }),\n  //     distinctUntilChanged(),\n  //     switchMap(() => subscriberCount(rows, 'rows')),\n  //     // tap(v => {\n  //     //   console.log('emitting rows', v)\n  //     // }),\n  //     finalize(() => handlerSub.unsubscribe())\n  //   )\n  // }).pipe(\n  //   // tap(v => {\n  //   //   console.log('rows', v)\n  //   // }),\n  //   catchError(err => {\n  //     console.error(err)\n  //     return of([] as TRow[])\n  //   }),\n  //   shareReplay({ bufferSize: 1, refCount: true })\n  // )\n}\n\nfunction _createSortsObservable(datatable$: Observable<GqlDatatableAccessor | undefined>) {\n  return datatable$.pipe(\n    // tap(v => console.log('sorts got dt', v)),\n    switchMap(dt => dt\n      ? dt.sort.pipe(map(v => v.sorts), startWith(dt.sorts)) // .pipe(tap(v => console.log('sorts 1', v)))\n      : of([]) // .pipe(tap(v => console.log('sorts 2', v)))\n    ),\n    shareReplay({ bufferSize: 1, refCount: true })\n  )\n}\n\nfunction _createFilterStatesObservable(datatable$: Observable<GqlDatatableAccessor | undefined>) {\n  return datatable$.pipe(\n    // tap(v => console.log('filters got dt', v)),\n    switchMap(dt => dt\n      ? dt.filterStates // .pipe(tap(v => console.log('filterStates 1', v)))\n      : of([]) // .pipe(tap(v => console.log('filterStates 2', v)))\n    ),\n    // TODO: Remove when the datatable fixes the bug causing it to emit more than it should.\n    distinctUntilChanged((x, y) => JSON.stringify(x) === JSON.stringify(y)),\n  )\n}\n\nfunction _createDatatableResultsObservable(\n  datatable$: Observable<GqlDatatableAccessor | undefined>,\n  mappers: DatatableMappers,\n  context$: Observable<MapperContext>,\n): Observable<DatatableResults> {\n  return new Observable<DatatableResults>((subscriber: Subscriber<DatatableResults>) => {\n    const datatableSubject = new ReplaySubject<GqlDatatableAccessor | undefined>()\n\n    const dtSub = datatable$.subscribe(\n      dt => datatableSubject.next(dt),\n      err => datatableSubject.error(err),\n      () => datatableSubject.complete()\n    )\n\n    const ctxSub = context$.pipe(\n      switchMap(context => {\n\n        // TODO: Decide if the disabled paging feature will be reimplemented in a way\n        // that it should be considered here. `_isPagingDisabled(queryRef)`\n        const pageInfo$ = createPageInfoObservable(datatable$).pipe(\n          map(info => mappers.pageInfo(info))\n        )\n\n        const sorts$ = _createSortsObservable(datatable$).pipe(\n          switchMap(m => wrapIntoObservable(mappers.sorts(m, context)))\n        )\n\n        const filterInfo$ = _createFilterStatesObservable(datatable$).pipe(\n          switchMap(x => mapFilterStates(x, mappers.filters, context)),\n        )\n\n        return combineLatest([\n          pageInfo$,\n          sorts$,\n          filterInfo$,\n        ]).pipe(\n          map(([ pageInfo, sorts, filterInfo ]) => ({\n            pageInfo,\n            sorts,\n            filter: filterInfo,\n            context: context\n          }))\n        )\n\n      })\n    ).subscribe(subscriber)\n\n    return () => {\n      dtSub.unsubscribe()\n      ctxSub.unsubscribe()\n    }\n  })\n}\n\n// function _isPagingDisabled<TData, TVariables, TRow>(queryRef: DatatableGraphQLQueryRef<TData, TVariables, TRow>): boolean {\n//   return queryRef.getQueryProcessingConfig()?.disablePaging ?? false\n// }\n"]}
|
|
175
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datatable-helpers.js","sourceRoot":"","sources":["../../../../../projects/ui-common/graphql/datatable/datatable-helpers.ts"],"names":[],"mappings":"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","sourcesContent":["import { isDevMode } from '@angular/core'\nimport { combineLatest, defer, Observable, of, ReplaySubject, Subject, Subscriber } from 'rxjs'\nimport { catchError, distinctUntilChanged, finalize, map, shareReplay, startWith, switchMap, take, tap } from 'rxjs/operators'\n\nimport { notNullOrUndefined, subscriberCount, wrapIntoObservable } from '@theseam/ui-common/utils'\nimport { EmptyObject } from 'apollo-angular/types'\nimport { SortItem } from '@theseam/ui-common/datatable'\n\nimport { GqlDatatableAccessor } from '../models'\nimport { createPageInfoObservable } from './create-page-info-observable'\nimport { DatatableGraphQLQueryRef } from './datatable-graphql-query-ref'\nimport { FilterStateMapperResult, FilterStateMappers, mapFilterStates } from './map-filter-states'\nimport { mapPageInfo, PageInfoMapper, PageInfoMapperResult } from './map-page-info'\nimport { MapperContext } from './mapper-context'\n\nexport type SortsMapperResult = { [name: string]: any }[]\nexport type SortsMapper = (sorts: SortItem[], context: MapperContext)\n  => (SortsMapperResult | Promise<SortsMapperResult> | Observable<SortsMapperResult>)\n\ninterface DatatableResults {\n  pageInfo: PageInfoMapperResult\n  sorts: SortsMapperResult\n  filter: FilterStateMapperResult\n  context: MapperContext\n}\n\ninterface DatatableMappers {\n  pageInfo: PageInfoMapper\n  sorts: SortsMapper\n  filters: FilterStateMappers\n}\n\nexport function observeRowsWithGqlInputsHandling<TData, TRow, GqlVariables extends EmptyObject>(\n  queryRef: DatatableGraphQLQueryRef<TData, GqlVariables, TRow>,\n  rows: Observable<TRow[]>,\n  datatable: Observable<GqlDatatableAccessor | undefined> | Promise<GqlDatatableAccessor | undefined> | GqlDatatableAccessor,\n  extraVariables: Observable<Partial<GqlVariables>> | Promise<Partial<GqlVariables>> | Partial<GqlVariables>,\n  sortsMapper: SortsMapper,\n  filterStateMappers: FilterStateMappers\n): Observable<TRow[]> {\n  return new Observable<TRow[]>((subscriber: Subscriber<TRow[]>) => {\n    const datatable$ = wrapIntoObservable(datatable)\n    const extraVariables$ = wrapIntoObservable<Partial<GqlVariables>>(extraVariables)\n\n    const context$ = extraVariables$.pipe(\n      map(_extraVariables => {\n        const context: MapperContext = {\n          extraVariables: _extraVariables\n        }\n\n        return context\n      }),\n      shareReplay({ bufferSize: 1, refCount: true })\n    )\n\n    const datatableMappers: DatatableMappers = {\n      pageInfo: mapPageInfo,\n      sorts: sortsMapper,\n      filters: filterStateMappers,\n    }\n\n    const datatableResults$ = _createDatatableResultsObservable(\n      datatable$,\n      datatableMappers,\n      context$,\n    )\n\n    const queryVariablesChanged$ = datatableResults$.pipe(\n      tap(results => {\n        queryRef.setVariables({\n          ...(results.context || {}),\n          ...results.pageInfo,\n          ...(results.sorts.length > 0 ? { order: results.sorts } : {}),\n          ...(results.filter?.variables || {}),\n          ...(results.filter?.filter ? { where: results.filter.filter } : {})\n        } as any)\n      })\n    )\n\n    // const _emitSubject = new Subject<void>()\n\n    // const queryVarsChangedSub = queryVariablesChanged$.pipe(\n    //   switchMap(() => subscriberCount(rows, 'rows'))\n    // ).subscribe(subscriber)\n    const queryVarsChangedSub = queryVariablesChanged$.subscribe()\n\n    const _sub = subscriberCount(rows, 'rows').subscribe(subscriber)\n\n    return () => {\n      queryVarsChangedSub.unsubscribe()\n      _sub.unsubscribe()\n    }\n  })\n\n  // const context$ = extraVariables$.pipe(\n  //   map(_extraVariables => {\n  //     const context: MapperContext = {\n  //       extraVariables: _extraVariables\n  //     }\n\n  //     return context\n  //   })\n  // )\n\n  // const datatableMappers: DatatableMappers = {\n  //   pageInfo: mapPageInfo,\n  //   sorts: sortsMapper,\n  //   filters: filterStateMappers,\n  // }\n\n  // const datatableResults$ = _createDatatableResultsObservable(\n  //   datatable$,\n  //   datatableMappers,\n  //   context$,\n  // )\n\n  // const queryVariablesChanged$ = datatableResults$.pipe(\n  //   tap(results => {\n  //     queryRef.setVariables({\n  //       ...(results.extraVariables || {}),\n  //       ...results.pageInfo,\n  //       ...(results.sorts.length > 0 ? { order: results.sorts } : {}),\n  //       ...(results.filterInfo?.variables || {}),\n  //       ...(results.filterInfo?.filter ? { where: results.filterInfo.filter } : {})\n  //     } as any)\n  //   })\n  // )\n\n  // const handleQueryInputs =  combineLatest([ extraVariables$, pageInfo$ ]).pipe(\n  //   switchMap(([ _extraVariables, pageInfo ]) => {\n  //     // console.log('_extraVariables, pageInfo', _extraVariables, pageInfo)\n  //     const context: MapperContext = {\n  //       extraVariables: _extraVariables\n  //     }\n\n  //     return combineLatest([ sorts$, filterInfo$ ]).pipe(\n  //       // map(([ sorts, filterInfo ]) => ({ extraVariables: _extraVariables, pageInfo, sorts, filterInfo }))\n  //       map(([ sorts, filterInfo ]) => {\n  //         // console.log('sorts, filterInfo', sorts, filterInfo)\n  //         return { extraVariables: _extraVariables, pageInfo, sorts, filterInfo }\n  //       })\n  //     )\n  //   }),\n  //   tap(v => {\n  //     // console.log('~~~', v)\n  //     queryRef.setVariables({\n  //       ...(v.extraVariables || {}),\n  //       ...v.pageInfo,\n  //       ...(v.sorts.length > 0 ? { order: v.sorts } : {}),\n  //       ...(v.filterInfo?.variables || {}),\n  //       ...(v.filterInfo?.filter ? { where: v.filterInfo.filter } : {})\n  //     } as any)\n  //   })\n  // )\n\n  // return defer(() => {\n  //   const _emitted = new Subject<void>()\n  //   const handlerSub = handleQueryInputs.pipe(\n  //     // skip(1)\n  //   // ).subscribe(() => _emitted.next())\n  //   ).subscribe(() => {\n  //     _emitted.next()\n  //   })\n  //   return _emitted.pipe(\n  //     // tap(v => {\n  //     //   console.log('emitted', v)\n  //     // }),\n  //     distinctUntilChanged(),\n  //     switchMap(() => subscriberCount(rows, 'rows')),\n  //     // tap(v => {\n  //     //   console.log('emitting rows', v)\n  //     // }),\n  //     finalize(() => handlerSub.unsubscribe())\n  //   )\n  // }).pipe(\n  //   // tap(v => {\n  //   //   console.log('rows', v)\n  //   // }),\n  //   catchError(err => {\n  //     console.error(err)\n  //     return of([] as TRow[])\n  //   }),\n  //   shareReplay({ bufferSize: 1, refCount: true })\n  // )\n}\n\nfunction _createSortsObservable(datatable$: Observable<GqlDatatableAccessor | undefined>) {\n  return datatable$.pipe(\n    // tap(v => console.log('sorts got dt', v)),\n    switchMap(dt => dt\n      ? dt.sort.pipe(map(v => v.sorts), startWith(dt.sorts)) // .pipe(tap(v => console.log('sorts 1', v)))\n      : of([]) // .pipe(tap(v => console.log('sorts 2', v)))\n    ),\n    shareReplay({ bufferSize: 1, refCount: true })\n  )\n}\n\nfunction _createFilterStatesObservable(datatable$: Observable<GqlDatatableAccessor | undefined>) {\n  return datatable$.pipe(\n    // tap(v => console.log('filters got dt', v)),\n    switchMap(dt => dt\n      ? dt.filterStates // .pipe(tap(v => console.log('filterStates 1', v)))\n      : of([]) // .pipe(tap(v => console.log('filterStates 2', v)))\n    ),\n    // TODO: Remove when the datatable fixes the bug causing it to emit more than it should.\n    distinctUntilChanged((x, y) => JSON.stringify(x) === JSON.stringify(y)),\n  )\n}\n\nfunction _createDatatableResultsObservable(\n  datatable$: Observable<GqlDatatableAccessor | undefined>,\n  mappers: DatatableMappers,\n  context$: Observable<MapperContext>,\n): Observable<DatatableResults> {\n  return new Observable<DatatableResults>((subscriber: Subscriber<DatatableResults>) => {\n    const datatableSubject = new ReplaySubject<GqlDatatableAccessor | undefined>()\n\n    const dtSub = datatable$.subscribe(\n      dt => datatableSubject.next(dt),\n      err => datatableSubject.error(err),\n      () => datatableSubject.complete()\n    )\n\n    const ctxSub = context$.pipe(\n      switchMap(context => {\n        // TODO: Decide if the disabled paging feature will be reimplemented in a way\n        // that it should be considered here. `_isPagingDisabled(queryRef)`\n        const pageInfo$ = createPageInfoObservable(datatable$).pipe(\n          map(info => mappers.pageInfo(info))\n        )\n\n        const sorts$ = _createSortsObservable(datatable$).pipe(\n          switchMap(m => wrapIntoObservable(mappers.sorts(m, context)))\n        )\n\n        const filterInfo$ = _createFilterStatesObservable(datatable$).pipe(\n          switchMap(x => mapFilterStates(x, mappers.filters, context)),\n        )\n\n        return combineLatest([\n          pageInfo$,\n          sorts$,\n          filterInfo$,\n        ]).pipe(\n          map(([ pageInfo, sorts, filterInfo ]) => ({\n            pageInfo,\n            sorts,\n            filter: filterInfo,\n            context\n          }))\n        )\n      })\n    ).subscribe(subscriber)\n\n    return () => {\n      dtSub.unsubscribe()\n      ctxSub.unsubscribe()\n    }\n  })\n}\n\n// function _isPagingDisabled<TData, TVariables, TRow>(queryRef: DatatableGraphQLQueryRef<TData, TVariables, TRow>): boolean {\n//   return queryRef.getQueryProcessingConfig()?.disablePaging ?? false\n// }\n"]}
|
|
@@ -31,6 +31,7 @@ function mergeVariables(variableObjects) {
|
|
|
31
31
|
if (isDevMode()) {
|
|
32
32
|
for (const p of props) {
|
|
33
33
|
if (notNullOrUndefined(variables[p]) && variables[p] !== v[p]) {
|
|
34
|
+
// eslint-disable-next-line no-console
|
|
34
35
|
console.warn(`Multiple filters adding the same variable with a different result. This could cause unexpected results.`);
|
|
35
36
|
break;
|
|
36
37
|
}
|
|
@@ -59,4 +60,4 @@ export async function mapFilterStates(filterStates, filterStateMappers, context)
|
|
|
59
60
|
variables: mergeVariables(variableObjs)
|
|
60
61
|
};
|
|
61
62
|
}
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwLWZpbHRlci1zdGF0ZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vZ3JhcGhxbC9kYXRhdGFibGUvbWFwLWZpbHRlci1zdGF0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN6QyxPQUFPLEVBQUUsSUFBSSxFQUFjLE1BQU0sTUFBTSxDQUFBO0FBQ3ZDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUdqRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQTtBQXFCakYsU0FBUyxhQUFhLENBQ3BCLFdBQTRCLEVBQzVCLGtCQUFzQyxFQUN0QyxPQUFzQjtJQUV0QixNQUFNLE1BQU0sR0FBRyxrQkFBa0IsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDbkQsSUFBSSxDQUFDLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxFQUFFO1FBQy9CLE1BQU0sS0FBSyxDQUFDLHNCQUFzQixXQUFXLENBQUMsSUFBSSxjQUFjLENBQUMsQ0FBQTtLQUNsRTtJQUVELE9BQU8sa0JBQWtCLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUk7SUFDMUQsbUNBQW1DO0lBQ25DLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FDUixDQUFBO0FBQ0gsQ0FBQztBQUVELFNBQVMsY0FBYyxDQUNyQixZQUErQixFQUMvQixrQkFBc0MsRUFDdEMsT0FBc0I7SUFFdEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUM1QixTQUFTLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsV0FBVyxFQUFFLGtCQUFrQixFQUFFLE9BQU8sQ0FBQyxDQUFDLEVBQ2pGLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxFQUMxQixPQUFPLEVBQUUsQ0FDVixDQUFBO0FBQ0gsQ0FBQztBQUVELFNBQVMsWUFBWSxDQUFDLE9BQWtDO0lBQ3RELE9BQU8sRUFBRSxFQUFFLEVBQUUsT0FBTyxFQUFFLENBQUE7QUFDeEIsQ0FBQztBQUVEOzs7Ozs7R0FNRztBQUNILFNBQVMsY0FBYyxDQUFDLGVBQTZDO0lBQ25FLE1BQU0sU0FBUyxHQUErQixFQUFFLENBQUE7SUFFaEQsS0FBSyxNQUFNLENBQUMsSUFBSSxlQUFlLEVBQUU7UUFDL0IsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQTtRQUU1QixJQUFJLFNBQVMsRUFBRSxFQUFFO1lBQ2YsS0FBSyxNQUFNLENBQUMsSUFBSSxLQUFLLEVBQUU7Z0JBQ3JCLElBQUksa0JBQWtCLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksU0FBUyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRTtvQkFDN0Qsc0NBQXNDO29CQUN0QyxPQUFPLENBQUMsSUFBSSxDQUFDLHlHQUF5RyxDQUFDLENBQUE7b0JBQ3ZILE1BQUs7aUJBQ047YUFDRjtTQUNGO1FBRUQsS0FBSyxNQUFNLENBQUMsSUFBSSxLQUFLLEVBQUU7WUFDckIsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQTtTQUNwQjtLQUNGO0lBRUQsT0FBTyxTQUFTLENBQUE7QUFDbEIsQ0FBQztBQUVELE1BQU0sQ0FBQyxLQUFLLFVBQVUsZUFBZSxDQUNuQyxZQUErQixFQUMvQixrQkFBc0MsRUFDdEMsT0FBc0I7SUFFdEIsa0JBQWtCO0lBQ2xCLE1BQU0sT0FBTyxHQUFRLE1BQU0sY0FBYyxDQUFDLFlBQVksRUFBRSxrQkFBa0IsRUFBRSxPQUFPLENBQUMsQ0FBQyxTQUFTLEVBQUUsQ0FBQTtJQUVoRyxJQUFJLE9BQU8sQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQ3hCLE9BQU8sSUFBSSxDQUFBO0tBQ1o7SUFFRCxNQUFNLE9BQU8sR0FBRyxPQUFPO1NBQ3BCLEdBQUcsQ0FBQyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQztTQUN6QixNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQTtJQUU3QixNQUFNLFlBQVksR0FBRyxPQUFPO1NBQ3pCLEdBQUcsQ0FBQyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztTQUM1QixNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQTtJQUU3QixPQUFPO1FBQ0wsTUFBTSxFQUFFLFlBQVksQ0FBQyxPQUFPLENBQUM7UUFDN0IsU0FBUyxFQUFFLGNBQWMsQ0FBQyxZQUFZLENBQUM7S0FDeEMsQ0FBQTtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc0Rldk1vZGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgZnJvbSwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnXG5pbXBvcnQgeyBjb25jYXRNYXAsIGZpbHRlciwgdGFrZSwgdG9BcnJheSB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJ1xuXG5pbXBvcnQgeyBEYXRhRmlsdGVyU3RhdGUgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vZGF0YS1maWx0ZXJzJ1xuaW1wb3J0IHsgbm90TnVsbE9yVW5kZWZpbmVkLCB3cmFwSW50b09ic2VydmFibGUgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vdXRpbHMnXG5cbmltcG9ydCB7IE1hcHBlckNvbnRleHQgfSBmcm9tICcuL21hcHBlci1jb250ZXh0J1xuXG5leHBvcnQgaW50ZXJmYWNlIEZpbHRlclN0YXRlTWFwcGVyVmFyaWFibGVzIHtcbiAgW25hbWU6IHN0cmluZ106IGFueVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZpbHRlclN0YXRlTWFwcGVyRmlsdGVyIHtcbiAgW25hbWU6IHN0cmluZ106IGFueVxufVxuXG5leHBvcnQgdHlwZSBGaWx0ZXJTdGF0ZU1hcHBlclJlc3VsdCA9IHtcbiAgZmlsdGVyPzogRmlsdGVyU3RhdGVNYXBwZXJGaWx0ZXIgfCB1bmRlZmluZWQgfCBudWxsLFxuICB2YXJpYWJsZXM/OiBGaWx0ZXJTdGF0ZU1hcHBlclZhcmlhYmxlcyB8IHVuZGVmaW5lZCB8IG51bGxcbn0gfCBudWxsXG5cbmV4cG9ydCB0eXBlIEZpbHRlclN0YXRlTWFwcGVyID0gKGZpbHRlclN0YXRlOiBEYXRhRmlsdGVyU3RhdGUsIGNvbnRleHQ6IE1hcHBlckNvbnRleHQpXG4gID0+IChGaWx0ZXJTdGF0ZU1hcHBlclJlc3VsdCB8IFByb21pc2U8RmlsdGVyU3RhdGVNYXBwZXJSZXN1bHQ+IHwgT2JzZXJ2YWJsZTxGaWx0ZXJTdGF0ZU1hcHBlclJlc3VsdD4pXG5leHBvcnQgaW50ZXJmYWNlIEZpbHRlclN0YXRlTWFwcGVycyB7IFtmaWx0ZXJOYW1lOiBzdHJpbmddOiBGaWx0ZXJTdGF0ZU1hcHBlciB9XG5cbmZ1bmN0aW9uIHJlc29sdmVNYXBwZXIoXG4gIGZpbHRlclN0YXRlOiBEYXRhRmlsdGVyU3RhdGUsXG4gIGZpbHRlclN0YXRlTWFwcGVyczogRmlsdGVyU3RhdGVNYXBwZXJzLFxuICBjb250ZXh0OiBNYXBwZXJDb250ZXh0XG4pOiBPYnNlcnZhYmxlPEZpbHRlclN0YXRlTWFwcGVyUmVzdWx0PiB7XG4gIGNvbnN0IG1hcHBlciA9IGZpbHRlclN0YXRlTWFwcGVyc1tmaWx0ZXJTdGF0ZS5uYW1lXVxuICBpZiAoIW5vdE51bGxPclVuZGVmaW5lZChtYXBwZXIpKSB7XG4gICAgdGhyb3cgRXJyb3IoYE1hcHBlciBmb3IgZmlsdGVyICcke2ZpbHRlclN0YXRlLm5hbWV9JyBub3QgZm91bmQuYClcbiAgfVxuXG4gIHJldHVybiB3cmFwSW50b09ic2VydmFibGUobWFwcGVyKGZpbHRlclN0YXRlLCBjb250ZXh0KSkucGlwZShcbiAgICAvLyBSZXF1aXJlIGVhY2ggbWFwcGVyIHRvIGNvbXBsZXRlLlxuICAgIHRha2UoMSlcbiAgKVxufVxuXG5mdW5jdGlvbiByZXNvbHZlTWFwcGVycyhcbiAgZmlsdGVyU3RhdGVzOiBEYXRhRmlsdGVyU3RhdGVbXSxcbiAgZmlsdGVyU3RhdGVNYXBwZXJzOiBGaWx0ZXJTdGF0ZU1hcHBlcnMsXG4gIGNvbnRleHQ6IE1hcHBlckNvbnRleHRcbik6IE9ic2VydmFibGU8KEV4Y2x1ZGU8RmlsdGVyU3RhdGVNYXBwZXJSZXN1bHQsIG51bGw+KVtdPiB7XG4gIHJldHVybiBmcm9tKGZpbHRlclN0YXRlcykucGlwZShcbiAgICBjb25jYXRNYXAoZmlsdGVyU3RhdGUgPT4gcmVzb2x2ZU1hcHBlcihmaWx0ZXJTdGF0ZSwgZmlsdGVyU3RhdGVNYXBwZXJzLCBjb250ZXh0KSksXG4gICAgZmlsdGVyKG5vdE51bGxPclVuZGVmaW5lZCksXG4gICAgdG9BcnJheSgpXG4gIClcbn1cblxuZnVuY3Rpb24gbWVyZ2VGaWx0ZXJzKGZpbHRlcnM6IEZpbHRlclN0YXRlTWFwcGVyRmlsdGVyW10pOiB7IG9yOiBGaWx0ZXJTdGF0ZU1hcHBlckZpbHRlcltdIH0ge1xuICByZXR1cm4geyBvcjogZmlsdGVycyB9XG59XG5cbi8qKlxuICogTWVyZ2VzIHZhcmlhYmxlIG9iamVjdHMuXG4gKlxuICogTk9URTogVGhpcyBkb2VzIG5vdCB0cnkgdG8gZGVlcCBtZXJnZSwgc28gaWYgdHdvIG9iamVjdHMgZGVmaW5lIHRoZSBzYW1lXG4gKiB2YXJpYWJsZSB0aGVuIHRoZSBsYXN0IG9iamVjdCdzIHZhbHVlIHdpbGwgYmUgaW4gdGhlIG1lcmdlZCBvYmplY3QuICpJblxuICogZGV2TW9kZSBhbiBlcnJvciB3aWxsIGJlIHRocm93bi4qXG4gKi9cbmZ1bmN0aW9uIG1lcmdlVmFyaWFibGVzKHZhcmlhYmxlT2JqZWN0czogRmlsdGVyU3RhdGVNYXBwZXJWYXJpYWJsZXNbXSk6IEZpbHRlclN0YXRlTWFwcGVyVmFyaWFibGVzIHtcbiAgY29uc3QgdmFyaWFibGVzOiBGaWx0ZXJTdGF0ZU1hcHBlclZhcmlhYmxlcyA9IHt9XG5cbiAgZm9yIChjb25zdCB2IG9mIHZhcmlhYmxlT2JqZWN0cykge1xuICAgIGNvbnN0IHByb3BzID0gT2JqZWN0LmtleXModilcblxuICAgIGlmIChpc0Rldk1vZGUoKSkge1xuICAgICAgZm9yIChjb25zdCBwIG9mIHByb3BzKSB7XG4gICAgICAgIGlmIChub3ROdWxsT3JVbmRlZmluZWQodmFyaWFibGVzW3BdKSAmJiB2YXJpYWJsZXNbcF0gIT09IHZbcF0pIHtcbiAgICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgICAgIGNvbnNvbGUud2FybihgTXVsdGlwbGUgZmlsdGVycyBhZGRpbmcgdGhlIHNhbWUgdmFyaWFibGUgd2l0aCBhIGRpZmZlcmVudCByZXN1bHQuIFRoaXMgY291bGQgY2F1c2UgdW5leHBlY3RlZCByZXN1bHRzLmApXG4gICAgICAgICAgYnJlYWtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIGZvciAoY29uc3QgcCBvZiBwcm9wcykge1xuICAgICAgdmFyaWFibGVzW3BdID0gdltwXVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiB2YXJpYWJsZXNcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1hcEZpbHRlclN0YXRlcyhcbiAgZmlsdGVyU3RhdGVzOiBEYXRhRmlsdGVyU3RhdGVbXSxcbiAgZmlsdGVyU3RhdGVNYXBwZXJzOiBGaWx0ZXJTdGF0ZU1hcHBlcnMsXG4gIGNvbnRleHQ6IE1hcHBlckNvbnRleHRcbik6IFByb21pc2U8RmlsdGVyU3RhdGVNYXBwZXJSZXN1bHQ+IHtcbiAgLy8gVE9ETzogRml4IHR5cGVzXG4gIGNvbnN0IHJlc3VsdHM6IGFueSA9IGF3YWl0IHJlc29sdmVNYXBwZXJzKGZpbHRlclN0YXRlcywgZmlsdGVyU3RhdGVNYXBwZXJzLCBjb250ZXh0KS50b1Byb21pc2UoKVxuXG4gIGlmIChyZXN1bHRzLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiBudWxsXG4gIH1cblxuICBjb25zdCBmaWx0ZXJzID0gcmVzdWx0c1xuICAgIC5tYXAoKHI6IGFueSkgPT4gci5maWx0ZXIpXG4gICAgLmZpbHRlcihub3ROdWxsT3JVbmRlZmluZWQpXG5cbiAgY29uc3QgdmFyaWFibGVPYmpzID0gcmVzdWx0c1xuICAgIC5tYXAoKHI6IGFueSkgPT4gci52YXJpYWJsZXMpXG4gICAgLmZpbHRlcihub3ROdWxsT3JVbmRlZmluZWQpXG5cbiAgcmV0dXJuIHtcbiAgICBmaWx0ZXI6IG1lcmdlRmlsdGVycyhmaWx0ZXJzKSxcbiAgICB2YXJpYWJsZXM6IG1lcmdlVmFyaWFibGVzKHZhcmlhYmxlT2JqcylcbiAgfVxufVxuIl19
|
|
@@ -21,6 +21,7 @@ export function inlineVariable(query, variableName, variableValue) {
|
|
|
21
21
|
// TODO: Decide if this is a good solution.
|
|
22
22
|
if (hasProperty(variableValue, 'value') && variableValue.value === 'undefined') {
|
|
23
23
|
if (isDevMode()) {
|
|
24
|
+
// eslint-disable-next-line no-console
|
|
24
25
|
console.warn(`Ignoring attempt to inline '${variableName}', because it is undefined.`);
|
|
25
26
|
}
|
|
26
27
|
return visit(query, {
|
|
@@ -47,4 +48,4 @@ export function inlineVariable(query, variableName, variableValue) {
|
|
|
47
48
|
}
|
|
48
49
|
});
|
|
49
50
|
}
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5saW5lLXZhcmlhYmxlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9ncmFwaHFsL3V0aWxzL2lubGluZS12YXJpYWJsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUV6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sMEJBQTBCLENBQUE7QUFDdEQsT0FBTyxFQUFrQyxLQUFLLEVBQUUsTUFBTSxTQUFTLENBQUE7QUFFL0QsTUFBTSxVQUFVLGNBQWMsQ0FBQyxLQUFtQixFQUFFLFlBQW9CLEVBQUUsYUFBd0I7SUFDaEcsd0JBQXdCO0lBQ3hCLCtCQUErQjtJQUMvQix1REFBdUQ7SUFDdkQsMEJBQTBCO0lBQzFCLHdCQUF3QjtJQUN4Qiw2Q0FBNkM7SUFDN0Msd0JBQXdCO0lBRXhCLDZDQUE2QztJQUM3QyxpQkFBaUI7SUFDakIsbUJBQW1CO0lBQ25CLHNDQUFzQztJQUN0QyxVQUFVO0lBQ1YsUUFBUTtJQUNSLE1BQU07SUFDTixLQUFLO0lBRUwsOERBQThEO0lBRTlELDJDQUEyQztJQUMzQyxJQUFJLFdBQVcsQ0FBQyxhQUFvQixFQUFFLE9BQU8sQ0FBQyxJQUFLLGFBQXFCLENBQUMsS0FBSyxLQUFLLFdBQVcsRUFBRTtRQUM5RixJQUFJLFNBQVMsRUFBRSxFQUFFO1lBQ2Ysc0NBQXNDO1lBQ3RDLE9BQU8sQ0FBQyxJQUFJLENBQUMsK0JBQStCLFlBQVksNkJBQTZCLENBQUMsQ0FBQTtTQUN2RjtRQUNELE9BQU8sS0FBSyxDQUFDLEtBQUssRUFBRTtZQUNsQixZQUFZLENBQUMsZ0JBQWdCO2dCQUMzQixPQUFPLEtBQUssQ0FBQyxnQkFBZ0IsRUFBRTtvQkFDN0IsUUFBUSxDQUFDLFlBQVk7d0JBQ25CLElBQUksWUFBWSxLQUFLLFlBQVksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFOzRCQUM1QyxPQUFPLElBQUksQ0FBQTt5QkFDWjtvQkFDSCxDQUFDO2lCQUNGLENBQUMsQ0FBQTtZQUNKLENBQUM7U0FDRixDQUFDLENBQUE7S0FDSDtJQUVELE9BQU8sS0FBSyxDQUFDLEtBQUssRUFBRTtRQUNsQixZQUFZLENBQUMsZ0JBQWdCO1lBQzNCLE9BQU8sS0FBSyxDQUFDLGdCQUFnQixFQUFFO2dCQUM3QixRQUFRLENBQUMsWUFBWTtvQkFDbkIsSUFBSSxZQUFZLEtBQUssWUFBWSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUU7d0JBQzVDLE9BQU8sYUFBYSxDQUFBO3FCQUNyQjtnQkFDSCxDQUFDO2FBQ0YsQ0FBQyxDQUFBO1FBQ0osQ0FBQztLQUNGLENBQUMsQ0FBQTtBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc0Rldk1vZGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuXG5pbXBvcnQgeyBoYXNQcm9wZXJ0eSB9IGZyb20gJ0B0aGVzZWFtL3VpLWNvbW1vbi91dGlscydcbmltcG9ydCB7IEJSRUFLLCBEb2N1bWVudE5vZGUsIFZhbHVlTm9kZSwgdmlzaXQgfSBmcm9tICdncmFwaHFsJ1xuXG5leHBvcnQgZnVuY3Rpb24gaW5saW5lVmFyaWFibGUocXVlcnk6IERvY3VtZW50Tm9kZSwgdmFyaWFibGVOYW1lOiBzdHJpbmcsIHZhcmlhYmxlVmFsdWU6IFZhbHVlTm9kZSk6IERvY3VtZW50Tm9kZSB7XG4gIC8vIHJldHVybiB2aXNpdChxdWVyeSwge1xuICAvLyAgIFZhcmlhYmxlRGVmaW5pdGlvbihub2RlKSB7XG4gIC8vICAgICBpZiAodmFyaWFibGVOYW1lID09PSBub2RlLnZhcmlhYmxlLm5hbWUudmFsdWUpIHtcbiAgLy8gICAgICAgY29uc29sZS5sb2cobm9kZSlcbiAgLy8gICAgICAgLy8gZm91bmQgPSB0cnVlXG4gIC8vICAgICAgIGNvbnNvbGUubG9nKCdpbnNlcnQnLCB2YXJpYWJsZVZhbHVlKVxuICAvLyAgICAgICAvLyByZXR1cm4gQlJFQUtcblxuICAvLyAgICAgICAvLyBub2RlLmRlZmF1bHRWYWx1ZSA9IHZhcmlhYmxlVmFsdWVcbiAgLy8gICAgICAgcmV0dXJuIHtcbiAgLy8gICAgICAgICAuLi5ub2RlLFxuICAvLyAgICAgICAgIGRlZmF1bHRWYWx1ZTogdmFyaWFibGVWYWx1ZVxuICAvLyAgICAgICB9XG4gIC8vICAgICB9XG4gIC8vICAgfVxuICAvLyB9KVxuXG4gIC8vIGNvbnNvbGUubG9nKCd+aW5saW5lVmFyaWFibGUnLCB2YXJpYWJsZU5hbWUsIHZhcmlhYmxlVmFsdWUpXG5cbiAgLy8gVE9ETzogRGVjaWRlIGlmIHRoaXMgaXMgYSBnb29kIHNvbHV0aW9uLlxuICBpZiAoaGFzUHJvcGVydHkodmFyaWFibGVWYWx1ZSBhcyBhbnksICd2YWx1ZScpICYmICh2YXJpYWJsZVZhbHVlIGFzIGFueSkudmFsdWUgPT09ICd1bmRlZmluZWQnKSB7XG4gICAgaWYgKGlzRGV2TW9kZSgpKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgY29uc29sZS53YXJuKGBJZ25vcmluZyBhdHRlbXB0IHRvIGlubGluZSAnJHt2YXJpYWJsZU5hbWV9JywgYmVjYXVzZSBpdCBpcyB1bmRlZmluZWQuYClcbiAgICB9XG4gICAgcmV0dXJuIHZpc2l0KHF1ZXJ5LCB7XG4gICAgICBTZWxlY3Rpb25TZXQoc2VsZWN0aW9uU2V0Tm9kZSkge1xuICAgICAgICByZXR1cm4gdmlzaXQoc2VsZWN0aW9uU2V0Tm9kZSwge1xuICAgICAgICAgIFZhcmlhYmxlKHZhcmlhYmxlTm9kZSkge1xuICAgICAgICAgICAgaWYgKHZhcmlhYmxlTmFtZSA9PT0gdmFyaWFibGVOb2RlLm5hbWUudmFsdWUpIHtcbiAgICAgICAgICAgICAgcmV0dXJuIG51bGxcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH0pXG4gICAgICB9XG4gICAgfSlcbiAgfVxuXG4gIHJldHVybiB2aXNpdChxdWVyeSwge1xuICAgIFNlbGVjdGlvblNldChzZWxlY3Rpb25TZXROb2RlKSB7XG4gICAgICByZXR1cm4gdmlzaXQoc2VsZWN0aW9uU2V0Tm9kZSwge1xuICAgICAgICBWYXJpYWJsZSh2YXJpYWJsZU5vZGUpIHtcbiAgICAgICAgICBpZiAodmFyaWFibGVOYW1lID09PSB2YXJpYWJsZU5vZGUubmFtZS52YWx1ZSkge1xuICAgICAgICAgICAgcmV0dXJuIHZhcmlhYmxlVmFsdWVcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfVxuICB9KVxufVxuIl19
|
|
@@ -24,8 +24,8 @@ export function isCommentToken(token) {
|
|
|
24
24
|
return token.kind === 'Comment';
|
|
25
25
|
}
|
|
26
26
|
export function isHintToken(token) {
|
|
27
|
-
return isCommentToken(token) &&
|
|
28
|
-
(token.value?.match(HINT_PREFIX_REGEX)?.length || 0) > 0 || false;
|
|
27
|
+
return (isCommentToken(token) &&
|
|
28
|
+
(token.value?.match(HINT_PREFIX_REGEX)?.length || 0) > 0) || false;
|
|
29
29
|
}
|
|
30
30
|
export function isInlineComment(token) {
|
|
31
31
|
return isCommentToken(token) &&
|
|
@@ -105,4 +105,4 @@ export function parseHints(ast) {
|
|
|
105
105
|
.map(r => getHintsToken(r, _ast))
|
|
106
106
|
.filter(notNullOrUndefined);
|
|
107
107
|
}
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parse-hints.js","sourceRoot":"","sources":["../../../../../projects/ui-common/graphql/utils/parse-hints.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ArgumentNode,\n  BREAK,\n  DocumentNode,\n  FieldNode,\n  OperationDefinitionNode,\n  parse,\n  Token,\n  VariableDefinitionNode,\n  VariableNode,\n  visit\n} from 'graphql'\n\nimport { notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport { HintsKind, HintsToken } from '../models'\nimport { parseComments } from './parse-comments'\n\nexport const HINT_PREFIX_REGEX = /^\\s*@gql-hint:.+/\nexport const HINT_NAMES_CAPTURE_REGEX = /^\\s*@gql-hint:([a-zA-z-\\d\\s]+)$/\n\n/**\n * If AST loc has startToken prop then return same AST else reparse with config\n * to contain comments and loc at each node.\n */\nexport function parseAst(ast: DocumentNode): DocumentNode {\n  if (ast.loc === undefined) {\n    throw Error(`Expected AST to have loc.`)\n  }\n\n  if (ast.loc.startToken !== undefined) {\n    return ast\n  }\n\n  return parse(ast.loc.source, {\n    allowLegacySDLImplementsInterfaces: false,\n    experimentalFragmentVariables: true,\n  })\n}\n\nexport function isCommentToken(token: Token): boolean {\n  return token.kind === 'Comment'\n}\n\nexport function isHintToken(token: Token): boolean {\n  return (isCommentToken(token) &&\n    (token.value?.match(HINT_PREFIX_REGEX)?.length || 0) > 0) || false\n}\n\nexport function isInlineComment(token: Token): boolean {\n  return isCommentToken(token) &&\n    token.prev !== null &&\n    token.prev.line === token.line\n}\n\nexport function hintNamesFromHintToken(token: Token): string[] {\n  const grp = token.value?.match(HINT_NAMES_CAPTURE_REGEX)\n  if (grp === null || grp === undefined || grp.length === 0) {\n    return []\n  }\n  return grp[1].split(' ').map(x => x.trim()).filter(x => x.length > 0)\n}\n\nexport function getTokenAppliesTo(token: Token): Token | null {\n  if (isInlineComment(token)) {\n    return token.prev\n  }\n\n  let t = token.next\n  if (t?.kind === '$' && t.next?.kind === 'Name') {\n    t = t.next\n  }\n  return t\n}\n\nexport function createHintsToken(token: Token, node: HintsToken['node'], kind: HintsKind): HintsToken {\n  return {\n    node,\n    hints: hintNamesFromHintToken(token),\n    kind\n  }\n}\n\nexport function getHintsToken(token: Token, ast: DocumentNode): HintsToken | null {\n  // console.log('getHintsToken', token)\n  const appliesTo = getTokenAppliesTo(token)\n  if (appliesTo === null) {\n    return null\n  }\n\n  let appliesToNode: HintsToken | null = null\n  visit(ast, {\n    OperationDefinition(node: OperationDefinitionNode) {\n      if (node.loc?.start === appliesTo.start) {\n        appliesToNode = createHintsToken(token, node, HintsKind.OperationDefinition)\n        return BREAK\n      }\n    },\n    VariableDefinition(node: VariableDefinitionNode) {\n      if (node.variable.name.loc?.start === appliesTo.start) {\n        appliesToNode = createHintsToken(token, node, HintsKind.VariableDefinition)\n        return BREAK\n      }\n    },\n    Variable(node: VariableNode) {\n      if (node.name.loc?.start === appliesTo.start) {\n        appliesToNode = createHintsToken(token, node, HintsKind.Variable)\n        return BREAK\n      }\n    },\n    Argument(node: ArgumentNode) {\n      if (node.name.loc?.start === appliesTo.start) {\n        appliesToNode = createHintsToken(token, node, HintsKind.Argument)\n        return BREAK\n      }\n    },\n    Field(node: FieldNode) {\n      if (node.name.loc?.start === appliesTo.start) {\n        appliesToNode = createHintsToken(token, node, HintsKind.Field)\n        return BREAK\n      }\n    }\n  })\n  return appliesToNode\n}\n\nexport function parseHints(ast: DocumentNode): HintsToken[] {\n  const _ast = parseAst(ast)\n  // console.log('_ast', _ast)\n  return parseComments(_ast)\n    .filter(isHintToken)\n    .map(r => getHintsToken(r, _ast))\n    .filter(notNullOrUndefined)\n}\n"]}
|
|
@@ -11,7 +11,7 @@ export function toGQL(json) {
|
|
|
11
11
|
const value = json[prop];
|
|
12
12
|
let resultValue;
|
|
13
13
|
if (typeof value === 'string') {
|
|
14
|
-
resultValue =
|
|
14
|
+
resultValue = `"${value}"`;
|
|
15
15
|
}
|
|
16
16
|
else if (value instanceof GQLDirection) {
|
|
17
17
|
resultValue = `${value.direction}`;
|
|
@@ -20,7 +20,7 @@ export function toGQL(json) {
|
|
|
20
20
|
resultValue = `[${value.map(v => toGQL(v)).join(',')}]`;
|
|
21
21
|
}
|
|
22
22
|
else if (typeof value === 'object') {
|
|
23
|
-
if (
|
|
23
|
+
if (Object.prototype.hasOwnProperty.call(value, 'gqlVar')) {
|
|
24
24
|
resultValue = `${value.gqlVar}`;
|
|
25
25
|
}
|
|
26
26
|
else {
|
|
@@ -37,4 +37,4 @@ export function toGQL(json) {
|
|
|
37
37
|
});
|
|
38
38
|
return `{${props.join(', ')}}`;
|
|
39
39
|
}
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG8tZ3FsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL2dyYXBocWwvdXRpbHMvdG8tZ3FsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxXQUFXLENBQUE7QUFFeEMsNkVBQTZFO0FBQzdFLDRFQUE0RTtBQUM1RSxrQ0FBa0M7QUFDbEMsRUFBRTtBQUNGLDBFQUEwRTtBQUMxRSx5RUFBeUU7QUFDekUsd0JBQXdCO0FBQ3hCLE1BQU0sVUFBVSxLQUFLLENBQUMsSUFBUztJQUM3QixNQUFNLEtBQUssR0FBYSxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUNuRCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDeEIsSUFBSSxXQUErQixDQUFBO1FBQ25DLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFO1lBQzdCLFdBQVcsR0FBRyxJQUFJLEtBQUssR0FBRyxDQUFBO1NBQzNCO2FBQU0sSUFBSSxLQUFLLFlBQVksWUFBWSxFQUFFO1lBQ3hDLFdBQVcsR0FBRyxHQUFHLEtBQUssQ0FBQyxTQUFTLEVBQUUsQ0FBQTtTQUNuQzthQUFNLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUMvQixXQUFXLEdBQUcsSUFBSSxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUE7U0FDeEQ7YUFBTSxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRTtZQUNwQyxJQUFJLE1BQU0sQ0FBQyxTQUFTLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLEVBQUU7Z0JBQ3pELFdBQVcsR0FBRyxHQUFHLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQTthQUNoQztpQkFBTTtnQkFDTCxXQUFXLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFBO2FBQzNCO1NBQ0Y7YUFBTTtZQUNMLFdBQVcsR0FBRyxHQUFHLEtBQUssRUFBRSxDQUFBO1NBQ3pCO1FBQ0QsSUFBSSxPQUFPLFdBQVcsS0FBSyxRQUFRLEVBQUU7WUFDbkMsTUFBTSxLQUFLLENBQUMsbUJBQW1CLENBQUMsQ0FBQTtTQUNqQztRQUNELE9BQU8sR0FBRyxJQUFJLEtBQUssV0FBVyxFQUFFLENBQUE7SUFDbEMsQ0FBQyxDQUFDLENBQUE7SUFDRixPQUFPLElBQUksS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFBO0FBQ2hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHUUxEaXJlY3Rpb24gfSBmcm9tICcuLi9tb2RlbHMnXG5cbi8vIE5haXZlIGluaXRpYWwgaW1wbGVtZW50YXRpb24uIFRoaXMgaXMgaW50ZW5kZWQgZm9yIGR5bmFtaWMgdmFsdWVzLCBzdWNoIGFzXG4vLyBzb3J0aW5nIGFuZCBmaWx0ZXJpbmcuIElmIHlvdSBhcmUgZGVmaW5pbmcgYSBzY2hlbWEsIHVzZSB0aGUgZ3FsIHRlbXBsYXRlXG4vLyBmdW5jdGlvbiBmcm9tICdhcG9sbG8tYW5ndWxhcicuXG4vL1xuLy8gVE9ETzogVHJ5IHRvIGZpbmQgYSBtYWludGFpbmVkIGxpYnJhcnkgdGhhdCB3aWxsIGhhbmRsZSB0aGlzLiBJZGVhbGx5IGFcbi8vIHR5cGUtc2FmZSBvbmUsIGJ1dCB0aGF0IGlzIGJlY29taW5nIHN1cnByaXNpbmdseSBoYXJkZXIgdG8gZmluZCB0aGFuIElcbi8vIGV4cGVjdGVkIGZvciBHcmFwaFFMLlxuZXhwb3J0IGZ1bmN0aW9uIHRvR1FMKGpzb246IGFueSk6IHN0cmluZyB7XG4gIGNvbnN0IHByb3BzOiBzdHJpbmdbXSA9IE9iamVjdC5rZXlzKGpzb24pLm1hcChwcm9wID0+IHtcbiAgICBjb25zdCB2YWx1ZSA9IGpzb25bcHJvcF1cbiAgICBsZXQgcmVzdWx0VmFsdWU6IHN0cmluZyB8IHVuZGVmaW5lZFxuICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICByZXN1bHRWYWx1ZSA9IGBcIiR7dmFsdWV9XCJgXG4gICAgfSBlbHNlIGlmICh2YWx1ZSBpbnN0YW5jZW9mIEdRTERpcmVjdGlvbikge1xuICAgICAgcmVzdWx0VmFsdWUgPSBgJHt2YWx1ZS5kaXJlY3Rpb259YFxuICAgIH0gZWxzZSBpZiAoQXJyYXkuaXNBcnJheSh2YWx1ZSkpIHtcbiAgICAgIHJlc3VsdFZhbHVlID0gYFske3ZhbHVlLm1hcCh2ID0+IHRvR1FMKHYpKS5qb2luKCcsJyl9XWBcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcpIHtcbiAgICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwodmFsdWUsICdncWxWYXInKSkge1xuICAgICAgICByZXN1bHRWYWx1ZSA9IGAke3ZhbHVlLmdxbFZhcn1gXG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXN1bHRWYWx1ZSA9IHRvR1FMKHZhbHVlKVxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICByZXN1bHRWYWx1ZSA9IGAke3ZhbHVlfWBcbiAgICB9XG4gICAgaWYgKHR5cGVvZiByZXN1bHRWYWx1ZSAhPT0gJ3N0cmluZycpIHtcbiAgICAgIHRocm93IEVycm9yKGBVbmV4cGVjdGVkIHZhbHVlLmApXG4gICAgfVxuICAgIHJldHVybiBgJHtwcm9wfTogJHtyZXN1bHRWYWx1ZX1gXG4gIH0pXG4gIHJldHVybiBgeyR7cHJvcHMuam9pbignLCAnKX19YFxufVxuIl19
|
|
@@ -10,7 +10,7 @@ import * as i2 from "@fortawesome/angular-fontawesome";
|
|
|
10
10
|
// on initial load.
|
|
11
11
|
//
|
|
12
12
|
// Browsers that do not support css grayscale filter.
|
|
13
|
-
const needToFix = /(MSIE 10)|(Trident.*rv:11\.0)|( Edge\/[\d
|
|
13
|
+
const needToFix = /(MSIE 10)|(Trident.*rv:11\.0)|( Edge\/[\d.]+$)/.test(navigator.userAgent);
|
|
14
14
|
export class IconComponent {
|
|
15
15
|
constructor() {
|
|
16
16
|
this.needToFix = needToFix;
|
|
@@ -99,15 +99,15 @@ export class IconComponent {
|
|
|
99
99
|
get _cssDisabled() { return this.disabled || null; }
|
|
100
100
|
get _cssNoGreyscale() { return !this.grayscaleOnDisable; }
|
|
101
101
|
}
|
|
102
|
-
IconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.
|
|
103
|
-
IconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.
|
|
102
|
+
IconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: IconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
103
|
+
IconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: IconComponent, selector: "seam-icon", inputs: { grayscaleOnDisable: "grayscaleOnDisable", disabled: "disabled", iconClass: "iconClass", icon: "icon", size: "size", showDefaultOnError: "showDefaultOnError", defaultIcon: "defaultIcon", iconType: "iconType" }, host: { properties: { "attr.icon-type": "this._iconTypeAttr", "class.disabled": "this._cssDisabled", "class.no-grayscale": "this._cssNoGreyscale" } }, ngImport: i0, template: "<fa-icon *ngIf=\"_iconObj\"\n class=\"seam-icon--fa {{ iconClass }}\"\n [icon]=\"_iconObj\"\n [size]=\"size || undefined\">\n</fa-icon>\n\n<ng-container *ngIf=\"_iconUrl\">\n <!-- Partial fix for IE greyscale -->\n <ng-container *ngIf=\"needToFix\">\n <ng-container *ngIf=\"disabled && grayscaleOnDisable\">\n <span class=\"grayscale-fix\" style=\"display: inline-block; position: relative;\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" id=\"svgroot\" style=\"position: absolute; left: 0; right: 0;\" viewBox=\"0 0 48 48\" width=\"100%\" height=\"100%\">\n <defs><filter id=\"gray\"><feColorMatrix type=\"matrix\" values=\"0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\" /></filter></defs>\n <image filter=\"url("#gray")\" preserveAspectRatio=\"none meet\" x=\"0\" y=\"0\" width=\"48\" height=\"48\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n [attr.xlink:href]=\"_iconUrl\" />\n </svg>\n <img class=\"seam-icon--img {{ iconClass }}\" style=\"display: block; visibility: hidden;\" alt=\"Icon\" [src]=\"_iconUrl\" (error)=\"_imgError($event)\">\n </span>\n </ng-container>\n <ng-container *ngIf=\"!disabled\">\n <img class=\"seam-icon--img {{ iconClass }}\" [src]=\"_iconUrl\" alt=\"Icon\" (error)=\"_imgError($event)\">\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!needToFix\">\n <img class=\"seam-icon--img {{ iconClass }}\" [src]=\"_iconUrl\" alt=\"Icon\" (error)=\"_imgError($event)\">\n </ng-container>\n</ng-container>\n\n<ng-content select=\".sr-only,seam-icon-notification\"></ng-content>\n", styles: [":host{display:inline-block}:host:disabled:not(.no-grayscale),:host.disabled:not(.no-grayscale){filter:grayscale(1)}:host[icon-type=styled-square]{border:1px solid #dee2e6;border-radius:8px}:host[icon-type=styled-square],:host[icon-type=borderless-styled-square]{-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden;min-width:39px;width:39px;min-height:39px;height:39px;padding:1px;align-items:center;display:inline-flex;vertical-align:top}:host[icon-type=styled-square] img,:host[icon-type=borderless-styled-square] img{max-width:100%;max-height:100%;margin:0 auto}:host[icon-type=styled-square] .seam-icon--fa,:host[icon-type=borderless-styled-square] .seam-icon--fa{height:100%;display:flex;flex-direction:row;justify-content:center;text-align:center;width:100%;padding:2px}:host[icon-type=styled-square] .seam-icon--fa ::ng-deep .svg-inline--fa,:host[icon-type=borderless-styled-square] .seam-icon--fa ::ng-deep .svg-inline--fa{max-width:100%;height:100%;width:100%}:host[icon-type=image-fill]{max-height:100%;max-width:100%;width:100%;height:100%}:host[icon-type=image-fill] img{max-width:100%;max-height:100%;margin:0 auto}:host[icon-type=image-fill] .seam-icon--fa{height:100%;display:flex;flex-direction:row;justify-content:center;text-align:center;width:100%}:host[icon-type=image-fill] .seam-icon--fa ::ng-deep .svg-inline--fa{max-width:100%;height:100%;width:100%}.grey-fix{visibility:hidden;display:block}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }] });
|
|
104
104
|
__decorate([
|
|
105
105
|
InputBoolean()
|
|
106
106
|
], IconComponent.prototype, "grayscaleOnDisable", void 0);
|
|
107
107
|
__decorate([
|
|
108
108
|
InputBoolean()
|
|
109
109
|
], IconComponent.prototype, "disabled", void 0);
|
|
110
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
110
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: IconComponent, decorators: [{
|
|
111
111
|
type: Component,
|
|
112
112
|
args: [{ selector: 'seam-icon', template: "<fa-icon *ngIf=\"_iconObj\"\n class=\"seam-icon--fa {{ iconClass }}\"\n [icon]=\"_iconObj\"\n [size]=\"size || undefined\">\n</fa-icon>\n\n<ng-container *ngIf=\"_iconUrl\">\n <!-- Partial fix for IE greyscale -->\n <ng-container *ngIf=\"needToFix\">\n <ng-container *ngIf=\"disabled && grayscaleOnDisable\">\n <span class=\"grayscale-fix\" style=\"display: inline-block; position: relative;\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" id=\"svgroot\" style=\"position: absolute; left: 0; right: 0;\" viewBox=\"0 0 48 48\" width=\"100%\" height=\"100%\">\n <defs><filter id=\"gray\"><feColorMatrix type=\"matrix\" values=\"0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\" /></filter></defs>\n <image filter=\"url("#gray")\" preserveAspectRatio=\"none meet\" x=\"0\" y=\"0\" width=\"48\" height=\"48\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n [attr.xlink:href]=\"_iconUrl\" />\n </svg>\n <img class=\"seam-icon--img {{ iconClass }}\" style=\"display: block; visibility: hidden;\" alt=\"Icon\" [src]=\"_iconUrl\" (error)=\"_imgError($event)\">\n </span>\n </ng-container>\n <ng-container *ngIf=\"!disabled\">\n <img class=\"seam-icon--img {{ iconClass }}\" [src]=\"_iconUrl\" alt=\"Icon\" (error)=\"_imgError($event)\">\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!needToFix\">\n <img class=\"seam-icon--img {{ iconClass }}\" [src]=\"_iconUrl\" alt=\"Icon\" (error)=\"_imgError($event)\">\n </ng-container>\n</ng-container>\n\n<ng-content select=\".sr-only,seam-icon-notification\"></ng-content>\n", styles: [":host{display:inline-block}:host:disabled:not(.no-grayscale),:host.disabled:not(.no-grayscale){filter:grayscale(1)}:host[icon-type=styled-square]{border:1px solid #dee2e6;border-radius:8px}:host[icon-type=styled-square],:host[icon-type=borderless-styled-square]{-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden;min-width:39px;width:39px;min-height:39px;height:39px;padding:1px;align-items:center;display:inline-flex;vertical-align:top}:host[icon-type=styled-square] img,:host[icon-type=borderless-styled-square] img{max-width:100%;max-height:100%;margin:0 auto}:host[icon-type=styled-square] .seam-icon--fa,:host[icon-type=borderless-styled-square] .seam-icon--fa{height:100%;display:flex;flex-direction:row;justify-content:center;text-align:center;width:100%;padding:2px}:host[icon-type=styled-square] .seam-icon--fa ::ng-deep .svg-inline--fa,:host[icon-type=borderless-styled-square] .seam-icon--fa ::ng-deep .svg-inline--fa{max-width:100%;height:100%;width:100%}:host[icon-type=image-fill]{max-height:100%;max-width:100%;width:100%;height:100%}:host[icon-type=image-fill] img{max-width:100%;max-height:100%;margin:0 auto}:host[icon-type=image-fill] .seam-icon--fa{height:100%;display:flex;flex-direction:row;justify-content:center;text-align:center;width:100%}:host[icon-type=image-fill] .seam-icon--fa ::ng-deep .svg-inline--fa{max-width:100%;height:100%;width:100%}.grey-fix{visibility:hidden;display:block}\n"] }]
|
|
113
113
|
}], propDecorators: { grayscaleOnDisable: [{
|
|
@@ -136,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.6", ngImpor
|
|
|
136
136
|
type: HostBinding,
|
|
137
137
|
args: ['class.no-grayscale']
|
|
138
138
|
}] } });
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/icon/icon/icon.component.ts","../../../../../projects/ui-common/icon/icon/icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { Component, HostBinding, Input } from '@angular/core'\n\nimport { IconProp, SizeProp } from '@fortawesome/fontawesome-svg-core'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\n\nimport { SeamIcon } from '../icon'\n\n//\n// TODO: Ensure all inputs correctly update the state whenever changed, not just\n// on initial load.\n//\n\n// Browsers that do not support css grayscale filter.\nconst needToFix = /(MSIE 10)|(Trident.*rv:11\\.0)|( Edge\\/[\\d\\.]+$)/.test(navigator.userAgent)\n\nexport type TheSeamIconType = 'borderless-styled-square' | 'styled-square' | 'image-fill' | undefined\n\n@Component({\n  selector: 'seam-icon',\n  templateUrl: './icon.component.html',\n  styleUrls: ['./icon.component.scss']\n})\nexport class IconComponent {\n  static ngAcceptInputType_grayscaleOnDisable: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_showDefaultOnError: BooleanInput\n\n  needToFix = needToFix\n\n  /** Toggles whether the img/icon will attempt to be grayscale when disabled is true. */\n  @Input() @InputBoolean() grayscaleOnDisable: boolean = true\n\n  /** Toggles the img/icon to grayscale if `grayscaleOnDisable` is true. */\n  @Input() @InputBoolean() disabled: boolean = false\n\n  /**\n   * Placed on the `.seam-icon--fa` and `seam-icon--img` elements.\n   */\n  @Input() iconClass: string | undefined | null\n\n  /**\n   * The icon to display.\n   *\n   * If the input icon is a string an `img` element will be used with icon as `src`.\n   * If the input is not a string it will be assumed to be a font-awesome IconProp object.\n   */\n  @Input()\n  get icon(): SeamIcon | undefined | null { return this._iconUrl || this._iconObj }\n  set icon(value: SeamIcon | undefined | null) {\n    if (typeof value === 'string') {\n      this._iconUrl = value\n      this._iconObj = undefined\n    } else {\n      this._iconUrl = undefined\n      this._iconObj = value\n    }\n\n    this._iconUrlBeforeError = undefined\n    this._iconObjBeforeError = undefined\n\n    if (!this._iconUrl && !this._iconObj) {\n      this._iconUrl = this._defaultIconUrl\n      this._iconObj = this._defaultIconObj\n    }\n  }\n\n  public _iconUrl: string | undefined | null\n  public _iconObj: IconProp | undefined | null\n\n  private _iconUrlBeforeError: string | undefined | null\n  private _iconObjBeforeError: IconProp | undefined | null\n\n  /**\n   * NOTE: Only works for fa-icon for now.\n   */\n  @Input() size: SizeProp | undefined | null\n\n  /**\n   * Toggles whether an image that has thrown the `onerror` event should show\n   * the `defaultIcon` instead.\n   */\n  @Input()\n  get showDefaultOnError(): boolean { return this._showDefaultOnError }\n  set showDefaultOnError(value: boolean) {\n    this._showDefaultOnError = coerceBooleanProperty(value)\n    if (this._hasError) {\n      if (this._iconUrlBeforeError || this._iconObjBeforeError) {\n        this._iconUrl = this._iconUrlBeforeError\n        this._iconObj = this._iconObjBeforeError\n        this._iconUrlBeforeError = undefined\n        this._iconObjBeforeError = undefined\n      } else if (this._showDefaultOnError) {\n        this._iconUrl = this._defaultIconUrl\n        this._iconObj = this._defaultIconObj\n      }\n    }\n  }\n  private _showDefaultOnError = false\n\n  /**\n   * Shown if icon is not set or if showDefaultOnError is true and img has thrown an error.\n   */\n  @Input()\n  get defaultIcon(): SeamIcon | undefined | null { return this._defaultIconUrl || this._defaultIconObj }\n  set defaultIcon(value: SeamIcon | undefined | null) {\n    if (typeof value === 'string') {\n      this._defaultIconUrl = value\n      this._defaultIconObj = undefined\n    } else {\n      this._defaultIconUrl = undefined\n      this._defaultIconObj = value\n    }\n\n    if (!this._defaultIconUrl && !this._defaultIconObj) {\n      this._iconUrl = this._iconUrlBeforeError\n      this._iconObj = this._iconObjBeforeError\n    }\n\n    if (!this._iconUrl && !this._iconObj) {\n      this._iconUrl = this._defaultIconUrl\n      this._iconObj = this._defaultIconObj\n    }\n  }\n\n  public _defaultIconUrl: string | undefined | null\n  public _defaultIconObj: IconProp | undefined | null\n\n  @Input() iconType: TheSeamIconType | undefined | null\n\n  @HostBinding('attr.icon-type')\n  get _iconTypeAttr() { return this.iconType }\n\n  private _hasError = false\n\n  public _imgError(event: ErrorEvent): void {\n    this._hasError = true\n    if (this._showDefaultOnError && (this._defaultIconUrl || this._defaultIconObj)) {\n      this._iconUrlBeforeError = this._iconUrl\n      this._iconObjBeforeError = this._iconObj\n      this._iconUrl = this._defaultIconUrl\n      this._iconObj = this._defaultIconObj\n    }\n  }\n\n  @HostBinding('class.disabled')\n  get _cssDisabled() { return this.disabled || null }\n\n  @HostBinding('class.no-grayscale')\n  get _cssNoGreyscale() { return !this.grayscaleOnDisable }\n\n}\n","<fa-icon *ngIf=\"_iconObj\"\n  class=\"seam-icon--fa {{ iconClass }}\"\n  [icon]=\"_iconObj\"\n  [size]=\"size || undefined\">\n</fa-icon>\n\n<ng-container *ngIf=\"_iconUrl\">\n  <!-- Partial fix for IE greyscale -->\n  <ng-container *ngIf=\"needToFix\">\n    <ng-container *ngIf=\"disabled && grayscaleOnDisable\">\n      <span class=\"grayscale-fix\" style=\"display: inline-block; position: relative;\">\n        <svg xmlns=\"http://www.w3.org/2000/svg\" id=\"svgroot\" style=\"position: absolute; left: 0; right: 0;\" viewBox=\"0 0 48 48\" width=\"100%\" height=\"100%\">\n          <defs><filter id=\"gray\"><feColorMatrix type=\"matrix\" values=\"0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\" /></filter></defs>\n          <image filter=\"url(&quot;#gray&quot;)\" preserveAspectRatio=\"none meet\" x=\"0\" y=\"0\" width=\"48\" height=\"48\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n            [attr.xlink:href]=\"_iconUrl\" />\n        </svg>\n        <img class=\"seam-icon--img {{ iconClass }}\" style=\"display: block; visibility: hidden;\" alt=\"Icon\" [src]=\"_iconUrl\" (error)=\"_imgError($event)\">\n      </span>\n    </ng-container>\n    <ng-container *ngIf=\"!disabled\">\n      <img class=\"seam-icon--img {{ iconClass }}\" [src]=\"_iconUrl\" alt=\"Icon\" (error)=\"_imgError($event)\">\n    </ng-container>\n  </ng-container>\n  <ng-container *ngIf=\"!needToFix\">\n    <img class=\"seam-icon--img {{ iconClass }}\" [src]=\"_iconUrl\" alt=\"Icon\" (error)=\"_imgError($event)\">\n  </ng-container>\n</ng-container>\n\n<ng-content select=\".sr-only,seam-icon-notification\"></ng-content>\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/icon/icon/icon.component.ts","../../../../../projects/ui-common/icon/icon/icon.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { Component, HostBinding, Input } from '@angular/core'\n\nimport { IconProp, SizeProp } from '@fortawesome/fontawesome-svg-core'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\n\nimport { SeamIcon } from '../icon'\n\n//\n// TODO: Ensure all inputs correctly update the state whenever changed, not just\n// on initial load.\n//\n\n// Browsers that do not support css grayscale filter.\nconst needToFix = /(MSIE 10)|(Trident.*rv:11\\.0)|( Edge\\/[\\d.]+$)/.test(navigator.userAgent)\n\nexport type TheSeamIconType = 'borderless-styled-square' | 'styled-square' | 'image-fill' | undefined\n\n@Component({\n  selector: 'seam-icon',\n  templateUrl: './icon.component.html',\n  styleUrls: ['./icon.component.scss']\n})\nexport class IconComponent {\n  static ngAcceptInputType_grayscaleOnDisable: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_showDefaultOnError: BooleanInput\n\n  needToFix = needToFix\n\n  /** Toggles whether the img/icon will attempt to be grayscale when disabled is true. */\n  @Input() @InputBoolean() grayscaleOnDisable = true\n\n  /** Toggles the img/icon to grayscale if `grayscaleOnDisable` is true. */\n  @Input() @InputBoolean() disabled = false\n\n  /**\n   * Placed on the `.seam-icon--fa` and `seam-icon--img` elements.\n   */\n  @Input() iconClass: string | undefined | null\n\n  /**\n   * The icon to display.\n   *\n   * If the input icon is a string an `img` element will be used with icon as `src`.\n   * If the input is not a string it will be assumed to be a font-awesome IconProp object.\n   */\n  @Input()\n  get icon(): SeamIcon | undefined | null { return this._iconUrl || this._iconObj }\n  set icon(value: SeamIcon | undefined | null) {\n    if (typeof value === 'string') {\n      this._iconUrl = value\n      this._iconObj = undefined\n    } else {\n      this._iconUrl = undefined\n      this._iconObj = value\n    }\n\n    this._iconUrlBeforeError = undefined\n    this._iconObjBeforeError = undefined\n\n    if (!this._iconUrl && !this._iconObj) {\n      this._iconUrl = this._defaultIconUrl\n      this._iconObj = this._defaultIconObj\n    }\n  }\n\n  public _iconUrl: string | undefined | null\n  public _iconObj: IconProp | undefined | null\n\n  private _iconUrlBeforeError: string | undefined | null\n  private _iconObjBeforeError: IconProp | undefined | null\n\n  /**\n   * NOTE: Only works for fa-icon for now.\n   */\n  @Input() size: SizeProp | undefined | null\n\n  /**\n   * Toggles whether an image that has thrown the `onerror` event should show\n   * the `defaultIcon` instead.\n   */\n  @Input()\n  get showDefaultOnError(): boolean { return this._showDefaultOnError }\n  set showDefaultOnError(value: boolean) {\n    this._showDefaultOnError = coerceBooleanProperty(value)\n    if (this._hasError) {\n      if (this._iconUrlBeforeError || this._iconObjBeforeError) {\n        this._iconUrl = this._iconUrlBeforeError\n        this._iconObj = this._iconObjBeforeError\n        this._iconUrlBeforeError = undefined\n        this._iconObjBeforeError = undefined\n      } else if (this._showDefaultOnError) {\n        this._iconUrl = this._defaultIconUrl\n        this._iconObj = this._defaultIconObj\n      }\n    }\n  }\n  private _showDefaultOnError = false\n\n  /**\n   * Shown if icon is not set or if showDefaultOnError is true and img has thrown an error.\n   */\n  @Input()\n  get defaultIcon(): SeamIcon | undefined | null { return this._defaultIconUrl || this._defaultIconObj }\n  set defaultIcon(value: SeamIcon | undefined | null) {\n    if (typeof value === 'string') {\n      this._defaultIconUrl = value\n      this._defaultIconObj = undefined\n    } else {\n      this._defaultIconUrl = undefined\n      this._defaultIconObj = value\n    }\n\n    if (!this._defaultIconUrl && !this._defaultIconObj) {\n      this._iconUrl = this._iconUrlBeforeError\n      this._iconObj = this._iconObjBeforeError\n    }\n\n    if (!this._iconUrl && !this._iconObj) {\n      this._iconUrl = this._defaultIconUrl\n      this._iconObj = this._defaultIconObj\n    }\n  }\n\n  public _defaultIconUrl: string | undefined | null\n  public _defaultIconObj: IconProp | undefined | null\n\n  @Input() iconType: TheSeamIconType | undefined | null\n\n  @HostBinding('attr.icon-type')\n  get _iconTypeAttr() { return this.iconType }\n\n  private _hasError = false\n\n  public _imgError(event: ErrorEvent): void {\n    this._hasError = true\n    if (this._showDefaultOnError && (this._defaultIconUrl || this._defaultIconObj)) {\n      this._iconUrlBeforeError = this._iconUrl\n      this._iconObjBeforeError = this._iconObj\n      this._iconUrl = this._defaultIconUrl\n      this._iconObj = this._defaultIconObj\n    }\n  }\n\n  @HostBinding('class.disabled')\n  get _cssDisabled() { return this.disabled || null }\n\n  @HostBinding('class.no-grayscale')\n  get _cssNoGreyscale() { return !this.grayscaleOnDisable }\n\n}\n","<fa-icon *ngIf=\"_iconObj\"\n  class=\"seam-icon--fa {{ iconClass }}\"\n  [icon]=\"_iconObj\"\n  [size]=\"size || undefined\">\n</fa-icon>\n\n<ng-container *ngIf=\"_iconUrl\">\n  <!-- Partial fix for IE greyscale -->\n  <ng-container *ngIf=\"needToFix\">\n    <ng-container *ngIf=\"disabled && grayscaleOnDisable\">\n      <span class=\"grayscale-fix\" style=\"display: inline-block; position: relative;\">\n        <svg xmlns=\"http://www.w3.org/2000/svg\" id=\"svgroot\" style=\"position: absolute; left: 0; right: 0;\" viewBox=\"0 0 48 48\" width=\"100%\" height=\"100%\">\n          <defs><filter id=\"gray\"><feColorMatrix type=\"matrix\" values=\"0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\" /></filter></defs>\n          <image filter=\"url(&quot;#gray&quot;)\" preserveAspectRatio=\"none meet\" x=\"0\" y=\"0\" width=\"48\" height=\"48\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n            [attr.xlink:href]=\"_iconUrl\" />\n        </svg>\n        <img class=\"seam-icon--img {{ iconClass }}\" style=\"display: block; visibility: hidden;\" alt=\"Icon\" [src]=\"_iconUrl\" (error)=\"_imgError($event)\">\n      </span>\n    </ng-container>\n    <ng-container *ngIf=\"!disabled\">\n      <img class=\"seam-icon--img {{ iconClass }}\" [src]=\"_iconUrl\" alt=\"Icon\" (error)=\"_imgError($event)\">\n    </ng-container>\n  </ng-container>\n  <ng-container *ngIf=\"!needToFix\">\n    <img class=\"seam-icon--img {{ iconClass }}\" [src]=\"_iconUrl\" alt=\"Icon\" (error)=\"_imgError($event)\">\n  </ng-container>\n</ng-container>\n\n<ng-content select=\".sr-only,seam-icon-notification\"></ng-content>\n"]}
|
|
@@ -51,7 +51,6 @@ export class IconBtnComponent {
|
|
|
51
51
|
this.badgeTheme = 'light';
|
|
52
52
|
this.badgeText = '';
|
|
53
53
|
}
|
|
54
|
-
ngOnInit() { }
|
|
55
54
|
ngDoCheck() {
|
|
56
55
|
if (this._isButton()) {
|
|
57
56
|
this._renderer.setAttribute(this._elementRef.nativeElement, 'type', this._type || 'button');
|
|
@@ -70,8 +69,8 @@ export class IconBtnComponent {
|
|
|
70
69
|
return this._elementRef.nativeElement.nodeName.toLowerCase() === 'button';
|
|
71
70
|
}
|
|
72
71
|
}
|
|
73
|
-
IconBtnComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.
|
|
74
|
-
IconBtnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.
|
|
72
|
+
IconBtnComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: IconBtnComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
|
|
73
|
+
IconBtnComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: IconBtnComponent, selector: "button[seamIconBtn]", inputs: { grayscaleOnDisable: "grayscaleOnDisable", disabled: "disabled", iconClass: "iconClass", icon: "icon", size: "size", showDefaultOnError: "showDefaultOnError", iconType: "iconType", btnTheme: "btnTheme", badgeTheme: "badgeTheme", badgeText: "badgeText", btnSize: "btnSize", type: "type", role: "role" }, host: { properties: { "attr.aria-disabled": "disabled.toString()", "attr.disabled": "disabled || null", "class.p-0": "this._cssPadding0", "class.btn": "this._btn", "class.text-nowrap": "this._textNoWrap", "class.btn-default": "this._btnDefault", "class.btn-primary": "this._btnPrimary", "class.btn-secondary": "this._btnSecondary", "class.btn-success": "this._btnSuccess", "class.btn-danger": "this._btnDanger", "class.btn-warning": "this._btnWarning", "class.btn-info": "this._btnInfo", "class.btn-light": "this._btnLight", "class.btn-dark": "this._btnDark", "class.btn-lightgray": "this._btnLightGray", "class.btn-sm": "this._btnSizeSm", "class.btn-lg": "this._btnSizeLg" } }, ngImport: i0, template: `
|
|
75
74
|
<seam-icon *ngIf="icon"
|
|
76
75
|
[grayscaleOnDisable]="grayscaleOnDisable"
|
|
77
76
|
[disabled]="disabled"
|
|
@@ -92,7 +91,7 @@ __decorate([
|
|
|
92
91
|
__decorate([
|
|
93
92
|
InputBoolean()
|
|
94
93
|
], IconBtnComponent.prototype, "showDefaultOnError", void 0);
|
|
95
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
94
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: IconBtnComponent, decorators: [{
|
|
96
95
|
type: Component,
|
|
97
96
|
args: [{ selector: 'button[seamIconBtn]', template: `
|
|
98
97
|
<seam-icon *ngIf="icon"
|
|
@@ -181,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.6", ngImpor
|
|
|
181
180
|
}], role: [{
|
|
182
181
|
type: Input
|
|
183
182
|
}] } });
|
|
184
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon-btn.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/icon/icon-btn/icon-btn.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput } from '@angular/cdk/coercion'\nimport { Component, DoCheck, ElementRef, HostBinding, Input, OnInit, Renderer2 } from '@angular/core'\n\nimport { SizeProp } from '@fortawesome/fontawesome-svg-core'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport type { ThemeTypes } from '@theseam/ui-common/models'\n\nimport type { SeamIcon } from '../icon'\nimport type { TheSeamIconType } from '../icon/icon.component'\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector: 'button[seamIconBtn]',\n  template: `\n    <seam-icon *ngIf=\"icon\"\n      [grayscaleOnDisable]=\"grayscaleOnDisable\"\n      [disabled]=\"disabled\"\n      [iconClass]=\"iconClass\"\n      [icon]=\"icon\"\n      [size]=\"size\"\n      [showDefaultOnError]=\"showDefaultOnError\"\n      [iconType]=\"iconType\">\n    </seam-icon>\n    <ng-content select=\".sr-only,seam-icon-notification\"></ng-content>\n  `,\n  styles: [],\n  // tslint:disable-next-line:use-host-property-decorator\n  host: {\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.disabled]': 'disabled || null',\n  },\n})\nexport class IconBtnComponent implements OnInit, DoCheck {\n  static ngAcceptInputType_grayscaleOnDisable: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_showDefaultOnError: BooleanInput\n\n  /** Toggles whether the img/icon will attempt to be grayscale when disabled is true. */\n  @Input() @InputBoolean() grayscaleOnDisable: boolean = true\n\n  /** Toggles the img/icon to grayscale if `grayscaleOnDisable` is true. */\n  @Input() @InputBoolean() disabled: boolean = false\n\n  /**\n   * Placed on the `.seam-icon--fa` and `seam-icon--img` elements.\n   */\n  @Input() iconClass: string | undefined | null\n\n  /**\n   * The icon to display.\n   *\n   * If the input icon is a string an `img` element will be used with icon as `src`.\n   * If the input is not a string it will be assumed to be a font-awesome IconProp object.\n   */\n  @Input() icon: SeamIcon | undefined | null\n\n  /**\n   * NOTE: Only works for fa-icon for now.\n   */\n  @Input() size: SizeProp | undefined | null\n\n  /**\n   * Toggles whether an image that has thrown the `onerror` event should show\n   * the `defaultIcon` instead.\n   */\n   @Input() @InputBoolean() showDefaultOnError: boolean = false\n\n  /**\n   * Shown if icon is not set or if showDefaultOnError is true and img has thrown an error.\n   *\n   * NOTE: Not supported for icon-btn yet.\n   */\n  // @Input() defaultIcon: SeamIcon\n\n  @Input() iconType: TheSeamIconType | undefined | null = 'image-fill'\n\n  @HostBinding('class.p-0') _cssPadding0 = true\n\n  @HostBinding('class.btn') _btn = true\n  @HostBinding('class.text-nowrap') _textNoWrap = true\n\n  @HostBinding('class.btn-default') get _btnDefault() { return this.isBtnTheme('default') }\n  @HostBinding('class.btn-primary') get _btnPrimary() { return this.isBtnTheme('primary') }\n  @HostBinding('class.btn-secondary') get _btnSecondary() { return this.isBtnTheme('secondary') }\n  @HostBinding('class.btn-success') get _btnSuccess() { return this.isBtnTheme('success') }\n  @HostBinding('class.btn-danger') get _btnDanger() { return this.isBtnTheme('danger') }\n  @HostBinding('class.btn-warning') get _btnWarning() { return this.isBtnTheme('warning') }\n  @HostBinding('class.btn-info') get _btnInfo() { return this.isBtnTheme('info') }\n  @HostBinding('class.btn-light') get _btnLight() { return this.isBtnTheme('light') }\n  @HostBinding('class.btn-dark') get _btnDark() { return this.isBtnTheme('dark') }\n  @HostBinding('class.btn-lightgray') get _btnLightGray() { return this.isBtnTheme('lightgray') }\n\n  @HostBinding('class.btn-sm') get _btnSizeSm() { return this.btnSize === 'sm' }\n  @HostBinding('class.btn-lg') get _btnSizeLg() { return this.btnSize === 'lg' }\n\n  @Input() btnTheme: ThemeTypes | undefined | null = 'default'\n  @Input() badgeTheme: ThemeTypes | undefined | null = 'light'\n  @Input() badgeText: string | undefined | null = ''\n\n  @Input() btnSize: 'sm' | 'lg' | undefined | null\n\n  @Input()\n  get type(): string | undefined | null { return this._type }\n  set type(value: string | undefined | null) {\n    this._type = value\n  }\n  private _type: string | undefined | null\n\n  @Input()\n  get role(): string | undefined | null { return this._role }\n  set role(value: string | undefined | null) {\n    this._role = value\n  }\n  private _role: string | undefined | null\n\n  constructor(\n    private _elementRef: ElementRef<HTMLButtonElement | HTMLAnchorElement>,\n    private _renderer: Renderer2\n  ) { }\n\n  ngOnInit() { }\n\n  ngDoCheck() {\n    if (this._isButton()) {\n      this._renderer.setAttribute(this._elementRef.nativeElement, 'type', this._type || 'button')\n    } else if (this._isAnchor()) {\n      this._renderer.setAttribute(this._elementRef.nativeElement, 'role', this._role || 'button')\n    }\n  }\n\n  public isBtnTheme(type: ThemeTypes): boolean {\n    return this.btnTheme === type\n  }\n\n  protected _isButton() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'button'\n  }\n\n  protected _isAnchor() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'button'\n  }\n\n}\n"]}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon-btn.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/icon/icon-btn/icon-btn.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput } from '@angular/cdk/coercion'\nimport { Component, DoCheck, ElementRef, HostBinding, Input, Renderer2 } from '@angular/core'\n\nimport { SizeProp } from '@fortawesome/fontawesome-svg-core'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport type { ThemeTypes } from '@theseam/ui-common/models'\n\nimport type { SeamIcon } from '../icon'\nimport type { TheSeamIconType } from '../icon/icon.component'\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'button[seamIconBtn]',\n  template: `\n    <seam-icon *ngIf=\"icon\"\n      [grayscaleOnDisable]=\"grayscaleOnDisable\"\n      [disabled]=\"disabled\"\n      [iconClass]=\"iconClass\"\n      [icon]=\"icon\"\n      [size]=\"size\"\n      [showDefaultOnError]=\"showDefaultOnError\"\n      [iconType]=\"iconType\">\n    </seam-icon>\n    <ng-content select=\".sr-only,seam-icon-notification\"></ng-content>\n  `,\n  styles: [],\n  host: {\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.disabled]': 'disabled || null',\n  },\n})\nexport class IconBtnComponent implements DoCheck {\n  static ngAcceptInputType_grayscaleOnDisable: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_showDefaultOnError: BooleanInput\n\n  /** Toggles whether the img/icon will attempt to be grayscale when disabled is true. */\n  @Input() @InputBoolean() grayscaleOnDisable = true\n\n  /** Toggles the img/icon to grayscale if `grayscaleOnDisable` is true. */\n  @Input() @InputBoolean() disabled = false\n\n  /**\n   * Placed on the `.seam-icon--fa` and `seam-icon--img` elements.\n   */\n  @Input() iconClass: string | undefined | null\n\n  /**\n   * The icon to display.\n   *\n   * If the input icon is a string an `img` element will be used with icon as `src`.\n   * If the input is not a string it will be assumed to be a font-awesome IconProp object.\n   */\n  @Input() icon: SeamIcon | undefined | null\n\n  /**\n   * NOTE: Only works for fa-icon for now.\n   */\n  @Input() size: SizeProp | undefined | null\n\n  /**\n   * Toggles whether an image that has thrown the `onerror` event should show\n   * the `defaultIcon` instead.\n   */\n   @Input() @InputBoolean() showDefaultOnError = false\n\n  /**\n   * Shown if icon is not set or if showDefaultOnError is true and img has thrown an error.\n   *\n   * NOTE: Not supported for icon-btn yet.\n   */\n  // @Input() defaultIcon: SeamIcon\n\n  @Input() iconType: TheSeamIconType | undefined | null = 'image-fill'\n\n  @HostBinding('class.p-0') _cssPadding0 = true\n\n  @HostBinding('class.btn') _btn = true\n  @HostBinding('class.text-nowrap') _textNoWrap = true\n\n  @HostBinding('class.btn-default') get _btnDefault() { return this.isBtnTheme('default') }\n  @HostBinding('class.btn-primary') get _btnPrimary() { return this.isBtnTheme('primary') }\n  @HostBinding('class.btn-secondary') get _btnSecondary() { return this.isBtnTheme('secondary') }\n  @HostBinding('class.btn-success') get _btnSuccess() { return this.isBtnTheme('success') }\n  @HostBinding('class.btn-danger') get _btnDanger() { return this.isBtnTheme('danger') }\n  @HostBinding('class.btn-warning') get _btnWarning() { return this.isBtnTheme('warning') }\n  @HostBinding('class.btn-info') get _btnInfo() { return this.isBtnTheme('info') }\n  @HostBinding('class.btn-light') get _btnLight() { return this.isBtnTheme('light') }\n  @HostBinding('class.btn-dark') get _btnDark() { return this.isBtnTheme('dark') }\n  @HostBinding('class.btn-lightgray') get _btnLightGray() { return this.isBtnTheme('lightgray') }\n\n  @HostBinding('class.btn-sm') get _btnSizeSm() { return this.btnSize === 'sm' }\n  @HostBinding('class.btn-lg') get _btnSizeLg() { return this.btnSize === 'lg' }\n\n  @Input() btnTheme: ThemeTypes | undefined | null = 'default'\n  @Input() badgeTheme: ThemeTypes | undefined | null = 'light'\n  @Input() badgeText: string | undefined | null = ''\n\n  @Input() btnSize: 'sm' | 'lg' | undefined | null\n\n  @Input()\n  get type(): string | undefined | null { return this._type }\n  set type(value: string | undefined | null) {\n    this._type = value\n  }\n  private _type: string | undefined | null\n\n  @Input()\n  get role(): string | undefined | null { return this._role }\n  set role(value: string | undefined | null) {\n    this._role = value\n  }\n  private _role: string | undefined | null\n\n  constructor(\n    private _elementRef: ElementRef<HTMLButtonElement | HTMLAnchorElement>,\n    private _renderer: Renderer2\n  ) { }\n\n  ngDoCheck() {\n    if (this._isButton()) {\n      this._renderer.setAttribute(this._elementRef.nativeElement, 'type', this._type || 'button')\n    } else if (this._isAnchor()) {\n      this._renderer.setAttribute(this._elementRef.nativeElement, 'role', this._role || 'button')\n    }\n  }\n\n  public isBtnTheme(type: ThemeTypes): boolean {\n    return this.btnTheme === type\n  }\n\n  protected _isButton() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'button'\n  }\n\n  protected _isAnchor() {\n    return this._elementRef.nativeElement.nodeName.toLowerCase() === 'button'\n  }\n\n}\n"]}
|
|
@@ -42,8 +42,8 @@ export class IconNotificationComponent {
|
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
44
|
}
|
|
45
|
-
IconNotificationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.
|
|
46
|
-
IconNotificationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.
|
|
45
|
+
IconNotificationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: IconNotificationComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
46
|
+
IconNotificationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: IconNotificationComponent, selector: "seam-icon-notification", inputs: { count: "count", hidden: "hidden", grayscaleOnDisable: "grayscaleOnDisable", disabled: "disabled", iconClass: "iconClass", icon: "icon", showDefaultOnError: "showDefaultOnError", size: "size", iconType: "iconType" }, host: { properties: { "attr.aria-disabled": "disabled.toString()", "attr.disabled": "disabled || null" } }, ngImport: i0, template: `
|
|
47
47
|
<seam-icon *ngIf="icon && !hidden" [@counterChange]="count"
|
|
48
48
|
[grayscaleOnDisable]="grayscaleOnDisable"
|
|
49
49
|
[disabled]="disabled"
|
|
@@ -76,7 +76,7 @@ __decorate([
|
|
|
76
76
|
__decorate([
|
|
77
77
|
InputBoolean()
|
|
78
78
|
], IconNotificationComponent.prototype, "showDefaultOnError", void 0);
|
|
79
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: IconNotificationComponent, decorators: [{
|
|
80
80
|
type: Component,
|
|
81
81
|
args: [{ selector: 'seam-icon-notification', template: `
|
|
82
82
|
<seam-icon *ngIf="icon && !hidden" [@counterChange]="count"
|
|
@@ -7,16 +7,16 @@ import { IconComponent } from './icon/icon.component';
|
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export class TheSeamIconModule {
|
|
9
9
|
}
|
|
10
|
-
TheSeamIconModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.
|
|
11
|
-
TheSeamIconModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.
|
|
10
|
+
TheSeamIconModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamIconModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
+
TheSeamIconModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: TheSeamIconModule, declarations: [IconComponent,
|
|
12
12
|
IconBtnComponent,
|
|
13
13
|
IconNotificationComponent], imports: [CommonModule,
|
|
14
14
|
FontAwesomeModule], exports: [IconComponent,
|
|
15
15
|
IconBtnComponent,
|
|
16
16
|
IconNotificationComponent] });
|
|
17
|
-
TheSeamIconModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.
|
|
17
|
+
TheSeamIconModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamIconModule, imports: [CommonModule,
|
|
18
18
|
FontAwesomeModule] });
|
|
19
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: TheSeamIconModule, decorators: [{
|
|
20
20
|
type: NgModule,
|
|
21
21
|
args: [{
|
|
22
22
|
declarations: [
|