@theseam/ui-common 0.2.10 → 0.2.14
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/assets/vendor/intl-tel-input/js/utils.js +255 -254
- package/bundles/theseam-ui-common-asset-reader.umd.js +7 -9
- package/bundles/theseam-ui-common-asset-reader.umd.js.map +1 -1
- package/bundles/theseam-ui-common-breadcrumbs.umd.js +6 -8
- package/bundles/theseam-ui-common-breadcrumbs.umd.js.map +1 -1
- package/bundles/theseam-ui-common-buttons.umd.js +5 -5
- package/bundles/theseam-ui-common-buttons.umd.js.map +1 -1
- package/bundles/theseam-ui-common-card.umd.js +6 -6
- package/bundles/theseam-ui-common-card.umd.js.map +1 -1
- package/bundles/theseam-ui-common-checkbox.umd.js +4 -4
- package/bundles/theseam-ui-common-checkbox.umd.js.map +1 -1
- package/bundles/theseam-ui-common-confirm-dialog.umd.js +4 -4
- package/bundles/theseam-ui-common-confirm-dialog.umd.js.map +1 -1
- package/bundles/theseam-ui-common-core.umd.js +4 -4
- package/bundles/theseam-ui-common-core.umd.js.map +1 -1
- package/bundles/theseam-ui-common-data-exporter.umd.js +5 -5
- package/bundles/theseam-ui-common-data-filters.umd.js +9 -6
- package/bundles/theseam-ui-common-data-filters.umd.js.map +1 -1
- package/bundles/theseam-ui-common-datatable-dynamic.umd.js +7 -7
- package/bundles/theseam-ui-common-datatable-dynamic.umd.js.map +1 -1
- package/bundles/theseam-ui-common-datatable.umd.js +1313 -378
- package/bundles/theseam-ui-common-datatable.umd.js.map +1 -1
- package/bundles/theseam-ui-common-dynamic-component-loader.umd.js +5 -7
- package/bundles/theseam-ui-common-dynamic-component-loader.umd.js.map +1 -1
- package/bundles/theseam-ui-common-dynamic.umd.js +7 -9
- package/bundles/theseam-ui-common-dynamic.umd.js.map +1 -1
- package/bundles/theseam-ui-common-footer-bar.umd.js +3 -3
- package/bundles/theseam-ui-common-form-field-error.umd.js +5 -5
- package/bundles/theseam-ui-common-form-field-error.umd.js.map +1 -1
- package/bundles/theseam-ui-common-form-field.umd.js +5 -5
- package/bundles/theseam-ui-common-form-field.umd.js.map +1 -1
- package/bundles/theseam-ui-common-framework.umd.js +27 -29
- package/bundles/theseam-ui-common-framework.umd.js.map +1 -1
- package/bundles/theseam-ui-common-graphql.umd.js +958 -8
- package/bundles/theseam-ui-common-graphql.umd.js.map +1 -1
- package/bundles/theseam-ui-common-icon.umd.js +5 -5
- package/bundles/theseam-ui-common-icon.umd.js.map +1 -1
- package/bundles/theseam-ui-common-layout.umd.js +5 -7
- package/bundles/theseam-ui-common-layout.umd.js.map +1 -1
- package/bundles/theseam-ui-common-loading.umd.js +4 -4
- package/bundles/theseam-ui-common-menu.umd.js +5 -5
- package/bundles/theseam-ui-common-menu.umd.js.map +1 -1
- package/bundles/theseam-ui-common-modal.umd.js +6 -6
- package/bundles/theseam-ui-common-modal.umd.js.map +1 -1
- package/bundles/theseam-ui-common-models.umd.js +3 -3
- package/bundles/theseam-ui-common-popover.umd.js +4 -4
- package/bundles/theseam-ui-common-progress.umd.js +5 -5
- package/bundles/theseam-ui-common-progress.umd.js.map +1 -1
- package/bundles/theseam-ui-common-scrollbar.umd.js +7 -9
- package/bundles/theseam-ui-common-scrollbar.umd.js.map +1 -1
- package/bundles/theseam-ui-common-services.umd.js +6 -8
- package/bundles/theseam-ui-common-services.umd.js.map +1 -1
- package/bundles/theseam-ui-common-shared.umd.js +4 -4
- package/bundles/theseam-ui-common-shared.umd.js.map +1 -1
- package/bundles/theseam-ui-common-storage.umd.js +5 -7
- package/bundles/theseam-ui-common-storage.umd.js.map +1 -1
- package/bundles/theseam-ui-common-story-helpers.umd.js +4 -4
- package/bundles/theseam-ui-common-story-helpers.umd.js.map +1 -1
- package/bundles/theseam-ui-common-tabbed.umd.js +5 -5
- package/bundles/theseam-ui-common-tabbed.umd.js.map +1 -1
- package/bundles/theseam-ui-common-table-cell-type.umd.js +5 -7
- package/bundles/theseam-ui-common-table-cell-type.umd.js.map +1 -1
- package/bundles/theseam-ui-common-table-cell-types.umd.js +258 -32
- package/bundles/theseam-ui-common-table-cell-types.umd.js.map +1 -1
- package/bundles/theseam-ui-common-table.umd.js +5 -5
- package/bundles/theseam-ui-common-table.umd.js.map +1 -1
- package/bundles/theseam-ui-common-tel-input.umd.js +6 -6
- package/bundles/theseam-ui-common-tel-input.umd.js.map +1 -1
- package/bundles/theseam-ui-common-testing.umd.js +568 -0
- package/bundles/theseam-ui-common-testing.umd.js.map +1 -0
- package/bundles/theseam-ui-common-tiled-select.umd.js +56 -39
- package/bundles/theseam-ui-common-tiled-select.umd.js.map +1 -1
- package/bundles/theseam-ui-common-toggle-edit.umd.js +8 -10
- package/bundles/theseam-ui-common-toggle-edit.umd.js.map +1 -1
- package/bundles/theseam-ui-common-toggle-group.umd.js +4 -4
- package/bundles/theseam-ui-common-toggle-group.umd.js.map +1 -1
- package/bundles/theseam-ui-common-unsaved-changes-dialog.umd.js +5 -7
- package/bundles/theseam-ui-common-unsaved-changes-dialog.umd.js.map +1 -1
- package/bundles/theseam-ui-common-utils.umd.js +174 -81
- package/bundles/theseam-ui-common-utils.umd.js.map +1 -1
- package/bundles/theseam-ui-common-validators.umd.js +3 -3
- package/bundles/theseam-ui-common-viewers.umd.js +6 -8
- package/bundles/theseam-ui-common-viewers.umd.js.map +1 -1
- package/bundles/theseam-ui-common-widget.umd.js +18 -20
- package/bundles/theseam-ui-common-widget.umd.js.map +1 -1
- package/bundles/theseam-ui-common.umd.js +2 -2
- package/buttons/theseam-ui-common-buttons.metadata.json +1 -1
- package/card/theseam-ui-common-card.metadata.json +1 -1
- package/data-filters/data-filter.d.ts +10 -6
- package/data-filters/theseam-ui-common-data-filters.metadata.json +1 -1
- package/datatable/datatable/datatable.component.d.ts +46 -32
- package/datatable/datatable-column/datatable-column.component.d.ts +26 -25
- package/datatable/datatable-column-preferences/datatable-column-preferences.component.d.ts +7 -5
- package/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.d.ts +7 -1
- package/datatable/datatable-menu-bar/datatable-menu-bar.component.d.ts +1 -1
- package/datatable/directives/datatable-filter.directive.d.ts +1 -1
- package/datatable/models/columns-alteration.d.ts +61 -0
- package/datatable/models/columns-alterations/hide-column.columns-alteration.d.ts +15 -0
- package/datatable/models/columns-alterations/order.columns-alteration.d.ts +20 -0
- package/datatable/models/columns-alterations/sort.columns-alteration.d.ts +14 -0
- package/datatable/models/columns-alterations/width.columns-alteration.d.ts +16 -0
- package/datatable/models/datatable-accessor.d.ts +5 -3
- package/datatable/models/internal-column-props.d.ts +7 -0
- package/datatable/models/page-info.d.ts +12 -0
- package/datatable/models/preferences-accessor.d.ts +1 -1
- package/datatable/models/preferences.d.ts +11 -3
- package/datatable/models/sort-item.d.ts +2 -1
- package/datatable/services/columns-alterations-manager.service.d.ts +39 -0
- package/datatable/services/columns-manager.service.d.ts +55 -0
- package/datatable/services/datatable-preferences.service.d.ts +10 -7
- package/datatable/theseam-ui-common-datatable.d.ts +2 -0
- package/datatable/theseam-ui-common-datatable.metadata.json +1 -1
- package/datatable/tokens/datatable-preferences-accessor.d.ts +2 -2
- package/datatable/utils/create-action-menu-column.d.ts +3 -0
- package/datatable/utils/create-checkbox-column.d.ts +3 -0
- package/datatable/utils/get-column-prop.d.ts +5 -0
- package/datatable/utils/map-columns-alterations-states.d.ts +2 -0
- package/datatable/utils/remove-unused-diffs.d.ts +7 -0
- package/datatable/utils/set-column-defaults.d.ts +2 -0
- package/datatable/utils/translate-templates.d.ts +2 -0
- package/datatable/utils/with-stored-column-info.d.ts +2 -2
- package/datatable-dynamic/theseam-ui-common-datatable-dynamic.metadata.json +1 -1
- package/esm2015/buttons/progress-circle-button/progress-circle-button.component.js +1 -1
- package/esm2015/card/card-action/card-action.component.js +1 -1
- package/esm2015/card/card-body/card-body.component.js +1 -1
- package/esm2015/data-filters/data-filter.js +5 -2
- package/esm2015/data-filters/filters/data-filter-search/data-filter-search.component.js +1 -1
- package/esm2015/data-filters/filters/data-filter-text/data-filter-text.component.js +1 -1
- package/esm2015/datatable/datatable/datatable.component.js +195 -211
- package/esm2015/datatable/datatable-action-menu/datatable-action-menu.component.js +1 -1
- package/esm2015/datatable/datatable-column/datatable-column.component.js +1 -1
- package/esm2015/datatable/datatable-column-preferences/datatable-column-preferences.component.js +42 -19
- package/esm2015/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.js +38 -4
- package/esm2015/datatable/datatable-export-button/datatable-export-button.component.js +7 -6
- package/esm2015/datatable/datatable-menu-bar/datatable-menu-bar.component.js +1 -1
- package/esm2015/datatable/datatable-menu-bar-column-center/datatable-menu-bar-column-center.component.js +1 -1
- package/esm2015/datatable/datatable-menu-bar-column-left/datatable-menu-bar-column-left.component.js +1 -1
- package/esm2015/datatable/datatable-menu-bar-column-right/datatable-menu-bar-column-right.component.js +1 -1
- package/esm2015/datatable/datatable-menu-bar-row/datatable-menu-bar-row.component.js +1 -1
- package/esm2015/datatable/models/columns-alteration.js +38 -0
- package/esm2015/datatable/models/columns-alterations/hide-column.columns-alteration.js +38 -0
- package/esm2015/datatable/models/columns-alterations/order.columns-alteration.js +81 -0
- package/esm2015/datatable/models/columns-alterations/sort.columns-alteration.js +33 -0
- package/esm2015/datatable/models/columns-alterations/width.columns-alteration.js +41 -0
- package/esm2015/datatable/models/datatable-accessor.js +1 -1
- package/esm2015/datatable/models/internal-column-props.js +15 -0
- package/esm2015/datatable/models/page-info.js +1 -1
- package/esm2015/datatable/models/preferences-accessor.js +1 -1
- package/esm2015/datatable/models/preferences.js +6 -2
- package/esm2015/datatable/models/sort-item.js +1 -1
- package/esm2015/datatable/services/columns-alterations-manager.service.js +134 -0
- package/esm2015/datatable/services/columns-manager.service.js +257 -0
- package/esm2015/datatable/services/datatable-preferences.service.js +78 -32
- package/esm2015/datatable/theseam-ui-common-datatable.js +3 -1
- package/esm2015/datatable/tokens/datatable-preferences-accessor.js +2 -2
- package/esm2015/datatable/utils/create-action-menu-column.js +18 -0
- package/esm2015/datatable/utils/create-checkbox-column.js +15 -0
- package/esm2015/datatable/utils/get-column-prop.js +9 -0
- package/esm2015/datatable/utils/map-columns-alterations-states.js +39 -0
- package/esm2015/datatable/utils/remove-unused-diffs.js +9 -0
- package/esm2015/datatable/utils/set-column-defaults.js +10 -0
- package/esm2015/datatable/utils/translate-templates.js +12 -0
- package/esm2015/datatable/utils/with-stored-column-info.js +1 -1
- package/esm2015/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.js +1 -1
- package/esm2015/datatable-dynamic/datatable-dynamic-filter-container/datatable-dynamic-filter-container.component.js +1 -1
- package/esm2015/datatable-dynamic/datatable-dynamic.component.js +1 -1
- package/esm2015/form-field/form-field.component.js +1 -1
- package/esm2015/form-field-error/form-field-error/form-field-error.component.js +1 -1
- package/esm2015/framework/base-layout/base-layout.component.js +1 -1
- package/esm2015/framework/dashboard/dashboard-widgets/dashboard-widgets.component.js +1 -1
- package/esm2015/framework/dynamic-router/hierarchy-router-outlet/hierarchy-router-outlet.component.js +1 -1
- package/esm2015/framework/schema-form-controls/schema-form-input/schema-form-input.component.js +1 -1
- package/esm2015/framework/schema-form-controls/schema-form-number/schema-form-number.component.js +1 -1
- package/esm2015/framework/schema-form-controls/schema-form-select/schema-form-select.component.js +1 -1
- package/esm2015/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.js +1 -1
- package/esm2015/framework/side-nav/side-nav-item/side-nav-item.component.js +1 -1
- package/esm2015/framework/side-nav/side-nav-toggle/side-nav-toggle.component.js +1 -1
- package/esm2015/framework/side-nav/side-nav.component.js +1 -1
- package/esm2015/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.js +1 -1
- package/esm2015/framework/top-bar/top-bar-title/top-bar-title.component.js +1 -1
- package/esm2015/framework/top-bar/top-bar.component.js +1 -1
- package/esm2015/graphql/datatable/create-page-info-observable.js +38 -0
- package/esm2015/graphql/datatable/datatable-graphql-query-ref.js +236 -0
- package/esm2015/graphql/datatable/datatable-graphql.service.js +35 -0
- package/esm2015/graphql/datatable/datatable-helpers.js +170 -0
- package/esm2015/graphql/datatable/get-page-info.js +11 -0
- package/esm2015/graphql/datatable/index.js +7 -0
- package/esm2015/graphql/datatable/map-filter-states.js +64 -0
- package/esm2015/graphql/datatable/map-page-info.js +14 -0
- package/esm2015/graphql/datatable/mapper-context.js +2 -0
- package/esm2015/graphql/models/gql-datatable-accessor.js +2 -0
- package/esm2015/graphql/models/index.js +2 -1
- package/esm2015/graphql/models/query-processing-config.js +1 -1
- package/esm2015/graphql/public-api.js +2 -1
- package/esm2015/graphql/utils/parse-hints.js +3 -3
- package/esm2015/icon/icon/icon.component.js +1 -1
- package/esm2015/loading/loading/loading.component.js +1 -1
- package/esm2015/menu/menu.component.js +1 -1
- package/esm2015/modal/modal-body/modal-body.component.js +1 -1
- package/esm2015/modal/modal-container/modal-container.component.js +1 -1
- package/esm2015/popover/popover/popover.component.js +1 -1
- package/esm2015/progress/progress-circle/progress-circle.component.js +1 -1
- package/esm2015/tabbed/tabbed.component.js +1 -1
- package/esm2015/table/table/table.component.js +1 -1
- package/esm2015/table-cell-types/public-api.js +8 -1
- package/esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.js +2 -0
- package/esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.js +74 -0
- package/esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency.js +2 -0
- package/esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.js +1 -1
- package/esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.js +73 -0
- package/esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.js +2 -0
- package/esm2015/table-cell-types/table-cell-type-icon/table-cell-type-icon.component.js +1 -1
- package/esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.js +1 -1
- package/esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.js +71 -0
- package/esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer.js +2 -0
- package/esm2015/table-cell-types/table-cell-type-manifests.js +29 -17
- package/esm2015/table-cell-types/table-cell-type-progress-circle/table-cell-type-progress-circle.component.js +1 -1
- package/esm2015/table-cell-types/table-cell-types.module.js +9 -2
- package/esm2015/tel-input/tel-input/tel-input.component.js +1 -1
- package/esm2015/testing/current-tick-time.js +16 -0
- package/esm2015/testing/fake-toastr.js +29 -0
- package/esm2015/testing/get-harness.js +16 -0
- package/esm2015/testing/public-api.js +7 -0
- package/esm2015/testing/render-story.js +12 -0
- package/esm2015/testing/story-expect.js +39 -0
- package/esm2015/testing/theseam-ui-common-testing.js +5 -0
- package/esm2015/testing/tick-helper.js +74 -0
- package/esm2015/tiled-select/components/tiled-select/tiled-select.component.js +25 -17
- package/esm2015/tiled-select/components/tiled-select-tile/tiled-select-tile.component.js +5 -2
- package/esm2015/tiled-select/components/tiled-select-tile-icon/tiled-select-tile-icon.component.js +1 -1
- package/esm2015/tiled-select/public-api.js +2 -1
- package/esm2015/tiled-select/tiled-select.models.js +1 -1
- package/esm2015/tiled-select/tiled-select.module.js +4 -4
- package/esm2015/toggle-edit/toggle-edit-actions-container/toggle-edit-actions-container.component.js +1 -1
- package/esm2015/toggle-edit/toggle-edit.component.js +1 -1
- package/esm2015/utils/array-move.js +62 -0
- package/esm2015/utils/public-api.js +2 -1
- package/esm2015/utils/router/is-empty-url-route.js +1 -1
- package/esm2015/utils/subscriber-count.js +31 -4
- package/esm2015/widget/widget/widget.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-button-group/widget-button-group.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-content-header/widget-content-header.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-empty-label/widget-empty-label.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-footer-link/widget-footer-link.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-footer-text/widget-footer-text.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-header-badge/widget-header-badge.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-tile/widget-tile-footer-item/widget-tile-footer-item.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-tile/widget-tile-group/widget-tile-group.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-tile/widget-tile.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-tile-list/widget-tile-list.component.js +1 -1
- package/esm2015/widget/widget-footer/widget-footer.component.js +1 -1
- package/fesm2015/theseam-ui-common-buttons.js +1 -1
- package/fesm2015/theseam-ui-common-card.js +2 -2
- package/fesm2015/theseam-ui-common-data-filters.js +6 -3
- package/fesm2015/theseam-ui-common-data-filters.js.map +1 -1
- package/fesm2015/theseam-ui-common-datatable-dynamic.js +3 -3
- package/fesm2015/theseam-ui-common-datatable.js +1105 -319
- package/fesm2015/theseam-ui-common-datatable.js.map +1 -1
- package/fesm2015/theseam-ui-common-form-field-error.js +1 -1
- package/fesm2015/theseam-ui-common-form-field.js +1 -1
- package/fesm2015/theseam-ui-common-framework.js +13 -13
- package/fesm2015/theseam-ui-common-graphql.js +555 -5
- package/fesm2015/theseam-ui-common-graphql.js.map +1 -1
- package/fesm2015/theseam-ui-common-icon.js +1 -1
- package/fesm2015/theseam-ui-common-loading.js +1 -1
- package/fesm2015/theseam-ui-common-menu.js +1 -1
- package/fesm2015/theseam-ui-common-modal.js +2 -2
- package/fesm2015/theseam-ui-common-popover.js +1 -1
- package/fesm2015/theseam-ui-common-progress.js +1 -1
- package/fesm2015/theseam-ui-common-tabbed.js +1 -1
- package/fesm2015/theseam-ui-common-table-cell-types.js +234 -22
- package/fesm2015/theseam-ui-common-table-cell-types.js.map +1 -1
- package/fesm2015/theseam-ui-common-table.js +1 -1
- package/fesm2015/theseam-ui-common-tel-input.js +1 -1
- package/fesm2015/theseam-ui-common-testing.js +191 -0
- package/fesm2015/theseam-ui-common-testing.js.map +1 -0
- package/fesm2015/theseam-ui-common-tiled-select.js +34 -21
- package/fesm2015/theseam-ui-common-tiled-select.js.map +1 -1
- package/fesm2015/theseam-ui-common-toggle-edit.js +2 -2
- package/fesm2015/theseam-ui-common-utils.js +92 -4
- package/fesm2015/theseam-ui-common-utils.js.map +1 -1
- package/fesm2015/theseam-ui-common-widget.js +12 -12
- package/form-field/theseam-ui-common-form-field.metadata.json +1 -1
- package/form-field-error/theseam-ui-common-form-field-error.metadata.json +1 -1
- package/framework/theseam-ui-common-framework.metadata.json +1 -1
- package/graphql/datatable/create-page-info-observable.d.ts +4 -0
- package/graphql/datatable/datatable-graphql-query-ref.d.ts +65 -0
- package/graphql/datatable/datatable-graphql.service.d.ts +26 -0
- package/graphql/datatable/datatable-helpers.d.ts +12 -0
- package/graphql/datatable/get-page-info.d.ts +4 -0
- package/graphql/datatable/index.d.ts +6 -0
- package/graphql/datatable/map-filter-states.d.ts +18 -0
- package/graphql/datatable/map-page-info.d.ts +11 -0
- package/graphql/datatable/mapper-context.d.ts +6 -0
- package/graphql/models/gql-datatable-accessor.d.ts +9 -0
- package/graphql/models/index.d.ts +1 -0
- package/graphql/models/query-processing-config.d.ts +4 -0
- package/graphql/public-api.d.ts +1 -0
- package/graphql/theseam-ui-common-graphql.metadata.json +1 -1
- package/icon/theseam-ui-common-icon.metadata.json +1 -1
- package/loading/theseam-ui-common-loading.metadata.json +1 -1
- package/menu/theseam-ui-common-menu.metadata.json +1 -1
- package/modal/theseam-ui-common-modal.metadata.json +1 -1
- package/package.json +1 -1
- package/popover/theseam-ui-common-popover.metadata.json +1 -1
- package/progress/theseam-ui-common-progress.metadata.json +1 -1
- package/styles/vendor/ngx-datatable/_ngx-datatable.scss +87 -82
- package/styles/vendor/ngx-datatable/_themes/bootstrap/_variables.scss +3 -2
- package/tabbed/theseam-ui-common-tabbed.metadata.json +1 -1
- package/table/theseam-ui-common-table.metadata.json +1 -1
- package/table-cell-types/public-api.d.ts +7 -0
- package/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.d.ts +39 -0
- package/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.d.ts +19 -0
- package/table-cell-types/table-cell-type-currency/table-cell-type-currency.d.ts +3 -0
- package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.d.ts +31 -1
- package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.d.ts +19 -0
- package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.d.ts +3 -0
- package/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.d.ts +23 -1
- package/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.d.ts +19 -0
- package/table-cell-types/table-cell-type-integer/table-cell-type-integer.d.ts +3 -0
- package/table-cell-types/table-cell-type-manifests.d.ts +2 -1
- package/table-cell-types/theseam-ui-common-table-cell-types.metadata.json +1 -1
- package/tel-input/theseam-ui-common-tel-input.metadata.json +1 -1
- package/testing/current-tick-time.d.ts +13 -0
- package/testing/fake-toastr.d.ts +30 -0
- package/testing/get-harness.d.ts +7 -0
- package/testing/package.json +11 -0
- package/testing/public-api.d.ts +6 -0
- package/testing/render-story.d.ts +2 -0
- package/testing/story-expect.d.ts +5 -0
- package/{test-helpers/theseam-ui-common-test-helpers.d.ts → testing/theseam-ui-common-testing.d.ts} +0 -0
- package/testing/theseam-ui-common-testing.metadata.json +1 -0
- package/{test-helpers → testing}/tick-helper.d.ts +0 -0
- package/tiled-select/components/tiled-select/tiled-select.component.d.ts +7 -3
- package/tiled-select/components/tiled-select-tile/tiled-select-tile.component.d.ts +1 -0
- package/tiled-select/theseam-ui-common-tiled-select.metadata.json +1 -1
- package/tiled-select/tiled-select.models.d.ts +3 -1
- package/toggle-edit/theseam-ui-common-toggle-edit.metadata.json +1 -1
- package/utils/array-move.d.ts +49 -0
- package/utils/public-api.d.ts +1 -0
- package/utils/subscriber-count.d.ts +13 -1
- package/utils/theseam-ui-common-utils.metadata.json +1 -1
- package/widget/theseam-ui-common-widget.metadata.json +1 -1
- package/bundles/theseam-ui-common-test-helpers.umd.js +0 -94
- package/bundles/theseam-ui-common-test-helpers.umd.js.map +0 -1
- package/esm2015/test-helpers/public-api.js +0 -2
- package/esm2015/test-helpers/theseam-ui-common-test-helpers.js +0 -5
- package/esm2015/test-helpers/tick-helper.js +0 -74
- package/fesm2015/theseam-ui-common-test-helpers.js +0 -81
- package/fesm2015/theseam-ui-common-test-helpers.js.map +0 -1
- package/test-helpers/package.json +0 -11
- package/test-helpers/public-api.d.ts +0 -1
- package/test-helpers/theseam-ui-common-test-helpers.metadata.json +0 -1
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export class FakeToastrService {
|
|
2
|
+
constructor() {
|
|
3
|
+
this.currentlyActive = 0;
|
|
4
|
+
this.toasts = [];
|
|
5
|
+
}
|
|
6
|
+
/** show toast */
|
|
7
|
+
show(message, title, override = {}, type = '') { }
|
|
8
|
+
/** show successful toast */
|
|
9
|
+
success(message, title, override = {}) { }
|
|
10
|
+
/** show error toast */
|
|
11
|
+
error(message, title, override = {}) { }
|
|
12
|
+
/** show info toast */
|
|
13
|
+
info(message, title, override = {}) { }
|
|
14
|
+
/** show warning toast */
|
|
15
|
+
warning(message, title, override = {}) { }
|
|
16
|
+
/**
|
|
17
|
+
* Remove all or a single toast by id
|
|
18
|
+
*/
|
|
19
|
+
clear(toastId) { }
|
|
20
|
+
/**
|
|
21
|
+
* Remove and destroy a single toast by id
|
|
22
|
+
*/
|
|
23
|
+
remove(toastId) { }
|
|
24
|
+
/**
|
|
25
|
+
* Determines if toast message is already shown
|
|
26
|
+
*/
|
|
27
|
+
findDuplicate(message, resetOnDuplicate, countDuplicates) { }
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFrZS10b2FzdHIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdGVzdGluZy9mYWtlLXRvYXN0ci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8saUJBQWlCO0lBQTlCO1FBRUUsb0JBQWUsR0FBRyxDQUFDLENBQUE7UUFDbkIsV0FBTSxHQUF1QixFQUFFLENBQUE7SUF1RGpDLENBQUM7SUFuREMsaUJBQWlCO0lBQ2pCLElBQUksQ0FDRixPQUFnQixFQUNoQixLQUFjLEVBQ2QsV0FBc0MsRUFBRSxFQUN4QyxJQUFJLEdBQUcsRUFBRSxJQUNQLENBQUM7SUFFTCw0QkFBNEI7SUFDNUIsT0FBTyxDQUNMLE9BQWdCLEVBQ2hCLEtBQWMsRUFDZCxXQUFzQyxFQUFFLElBQ3RDLENBQUM7SUFFTCx1QkFBdUI7SUFDdkIsS0FBSyxDQUNILE9BQWdCLEVBQ2hCLEtBQWMsRUFDZCxXQUFzQyxFQUFFLElBQ3RDLENBQUM7SUFFTCxzQkFBc0I7SUFDdEIsSUFBSSxDQUNGLE9BQWdCLEVBQ2hCLEtBQWMsRUFDZCxXQUFzQyxFQUFFLElBQ3RDLENBQUM7SUFFTCx5QkFBeUI7SUFDekIsT0FBTyxDQUNMLE9BQWdCLEVBQ2hCLEtBQWMsRUFDZCxXQUFzQyxFQUFFLElBQ3RDLENBQUM7SUFFTDs7T0FFRztJQUNILEtBQUssQ0FBQyxPQUFnQixJQUFJLENBQUM7SUFFM0I7O09BRUc7SUFDSCxNQUFNLENBQUMsT0FBZSxJQUFJLENBQUM7SUFFM0I7O09BRUc7SUFDSCxhQUFhLENBQUMsT0FBZSxFQUFFLGdCQUF5QixFQUFFLGVBQXdCLElBQUksQ0FBQztDQUV4RiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFjdGl2ZVRvYXN0LCBHbG9iYWxDb25maWcsIEluZGl2aWR1YWxDb25maWcsIFRvYXN0Q29udGFpbmVyRGlyZWN0aXZlIH0gZnJvbSAnbmd4LXRvYXN0cidcblxuZXhwb3J0IGNsYXNzIEZha2VUb2FzdHJTZXJ2aWNlIHtcbiAgdG9hc3RyQ29uZmlnITogR2xvYmFsQ29uZmlnXG4gIGN1cnJlbnRseUFjdGl2ZSA9IDBcbiAgdG9hc3RzOiBBY3RpdmVUb2FzdDxhbnk+W10gPSBbXVxuICBvdmVybGF5Q29udGFpbmVyITogVG9hc3RDb250YWluZXJEaXJlY3RpdmVcbiAgcHJldmlvdXNUb2FzdE1lc3NhZ2U6IHN0cmluZyB8IHVuZGVmaW5lZFxuXG4gIC8qKiBzaG93IHRvYXN0ICovXG4gIHNob3coXG4gICAgbWVzc2FnZT86IHN0cmluZyxcbiAgICB0aXRsZT86IHN0cmluZyxcbiAgICBvdmVycmlkZTogUGFydGlhbDxJbmRpdmlkdWFsQ29uZmlnPiA9IHt9LFxuICAgIHR5cGUgPSAnJ1xuICApIHsgfVxuXG4gIC8qKiBzaG93IHN1Y2Nlc3NmdWwgdG9hc3QgKi9cbiAgc3VjY2VzcyhcbiAgICBtZXNzYWdlPzogc3RyaW5nLFxuICAgIHRpdGxlPzogc3RyaW5nLFxuICAgIG92ZXJyaWRlOiBQYXJ0aWFsPEluZGl2aWR1YWxDb25maWc+ID0ge31cbiAgKSB7IH1cblxuICAvKiogc2hvdyBlcnJvciB0b2FzdCAqL1xuICBlcnJvcihcbiAgICBtZXNzYWdlPzogc3RyaW5nLFxuICAgIHRpdGxlPzogc3RyaW5nLFxuICAgIG92ZXJyaWRlOiBQYXJ0aWFsPEluZGl2aWR1YWxDb25maWc+ID0ge31cbiAgKSB7IH1cblxuICAvKiogc2hvdyBpbmZvIHRvYXN0ICovXG4gIGluZm8oXG4gICAgbWVzc2FnZT86IHN0cmluZyxcbiAgICB0aXRsZT86IHN0cmluZyxcbiAgICBvdmVycmlkZTogUGFydGlhbDxJbmRpdmlkdWFsQ29uZmlnPiA9IHt9XG4gICkgeyB9XG5cbiAgLyoqIHNob3cgd2FybmluZyB0b2FzdCAqL1xuICB3YXJuaW5nKFxuICAgIG1lc3NhZ2U/OiBzdHJpbmcsXG4gICAgdGl0bGU/OiBzdHJpbmcsXG4gICAgb3ZlcnJpZGU6IFBhcnRpYWw8SW5kaXZpZHVhbENvbmZpZz4gPSB7fVxuICApIHsgfVxuXG4gIC8qKlxuICAgKiBSZW1vdmUgYWxsIG9yIGEgc2luZ2xlIHRvYXN0IGJ5IGlkXG4gICAqL1xuICBjbGVhcih0b2FzdElkPzogbnVtYmVyKSB7IH1cblxuICAvKipcbiAgICogUmVtb3ZlIGFuZCBkZXN0cm95IGEgc2luZ2xlIHRvYXN0IGJ5IGlkXG4gICAqL1xuICByZW1vdmUodG9hc3RJZDogbnVtYmVyKSB7IH1cblxuICAvKipcbiAgICogRGV0ZXJtaW5lcyBpZiB0b2FzdCBtZXNzYWdlIGlzIGFscmVhZHkgc2hvd25cbiAgICovXG4gIGZpbmREdXBsaWNhdGUobWVzc2FnZTogc3RyaW5nLCByZXNldE9uRHVwbGljYXRlOiBib29sZWFuLCBjb3VudER1cGxpY2F0ZXM6IGJvb2xlYW4pIHsgfVxuXG59XG4iXX0=
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { TestbedHarnessEnvironment } from '@angular/cdk/testing/testbed';
|
|
3
|
+
import { StorybookHarnessEnvironment } from '@marklb/storybook-harness';
|
|
4
|
+
export function getHarness(harnessType, options) {
|
|
5
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
6
|
+
if (options.fixture !== undefined) {
|
|
7
|
+
return TestbedHarnessEnvironment.harnessForFixture(options.fixture, harnessType);
|
|
8
|
+
}
|
|
9
|
+
if (options.canvasElement !== undefined) {
|
|
10
|
+
return (new StorybookHarnessEnvironment(options.canvasElement))
|
|
11
|
+
.getHarness(harnessType);
|
|
12
|
+
}
|
|
13
|
+
throw Error(`Unable to get harness. fixture or canvasElement must be provided.`);
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWhhcm5lc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdGVzdGluZy9nZXQtaGFybmVzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0EsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sOEJBQThCLENBQUE7QUFHeEUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMkJBQTJCLENBQUE7QUFPdkUsTUFBTSxVQUFnQixVQUFVLENBQzlCLFdBQTJDLEVBQzNDLE9BQTBCOztRQUUxQixJQUFJLE9BQU8sQ0FBQyxPQUFPLEtBQUssU0FBUyxFQUFFO1lBQ2pDLE9BQU8seUJBQXlCLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxXQUFXLENBQUMsQ0FBQTtTQUNqRjtRQUVELElBQUksT0FBTyxDQUFDLGFBQWEsS0FBSyxTQUFTLEVBQUU7WUFDdkMsT0FBTyxDQUFDLElBQUksMkJBQTJCLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO2lCQUM1RCxVQUFVLENBQUMsV0FBVyxDQUFDLENBQUE7U0FDM0I7UUFFRCxNQUFNLEtBQUssQ0FBQyxtRUFBbUUsQ0FBQyxDQUFBO0lBQ2xGLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudEhhcm5lc3MsIENvbXBvbmVudEhhcm5lc3NDb25zdHJ1Y3RvciB9IGZyb20gJ0Bhbmd1bGFyL2Nkay90ZXN0aW5nJ1xuaW1wb3J0IHsgVGVzdGJlZEhhcm5lc3NFbnZpcm9ubWVudCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay90ZXN0aW5nL3Rlc3RiZWQnXG5pbXBvcnQgeyBDb21wb25lbnRGaXh0dXJlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS90ZXN0aW5nJ1xuXG5pbXBvcnQgeyBTdG9yeWJvb2tIYXJuZXNzRW52aXJvbm1lbnQgfSBmcm9tICdAbWFya2xiL3N0b3J5Ym9vay1oYXJuZXNzJ1xuXG5leHBvcnQgaW50ZXJmYWNlIEdldEhhcm5lc3NPcHRpb25zPFRDb21wb25lbnQgPSBhbnk+IHtcbiAgY2FudmFzRWxlbWVudD86IEhUTUxFbGVtZW50XG4gIGZpeHR1cmU/OiBDb21wb25lbnRGaXh0dXJlPFRDb21wb25lbnQ+XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBnZXRIYXJuZXNzPFQgZXh0ZW5kcyBDb21wb25lbnRIYXJuZXNzPihcbiAgaGFybmVzc1R5cGU6IENvbXBvbmVudEhhcm5lc3NDb25zdHJ1Y3RvcjxUPixcbiAgb3B0aW9uczogR2V0SGFybmVzc09wdGlvbnNcbik6IFByb21pc2U8VD4ge1xuICBpZiAob3B0aW9ucy5maXh0dXJlICE9PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gVGVzdGJlZEhhcm5lc3NFbnZpcm9ubWVudC5oYXJuZXNzRm9yRml4dHVyZShvcHRpb25zLmZpeHR1cmUsIGhhcm5lc3NUeXBlKVxuICB9XG5cbiAgaWYgKG9wdGlvbnMuY2FudmFzRWxlbWVudCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgcmV0dXJuIChuZXcgU3Rvcnlib29rSGFybmVzc0Vudmlyb25tZW50KG9wdGlvbnMuY2FudmFzRWxlbWVudCkpXG4gICAgICAuZ2V0SGFybmVzcyhoYXJuZXNzVHlwZSlcbiAgfVxuXG4gIHRocm93IEVycm9yKGBVbmFibGUgdG8gZ2V0IGhhcm5lc3MuIGZpeHR1cmUgb3IgY2FudmFzRWxlbWVudCBtdXN0IGJlIHByb3ZpZGVkLmApXG59XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './fake-toastr';
|
|
2
|
+
export * from './render-story';
|
|
3
|
+
export * from './tick-helper';
|
|
4
|
+
export * from './current-tick-time';
|
|
5
|
+
export * from './story-expect';
|
|
6
|
+
export * from './get-harness';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90ZXN0aW5nL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxlQUFlLENBQUE7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQTtBQUM5QixjQUFjLGVBQWUsQ0FBQTtBQUM3QixjQUFjLHFCQUFxQixDQUFBO0FBRW5DLGNBQWMsZ0JBQWdCLENBQUE7QUFDOUIsY0FBYyxlQUFlLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Zha2UtdG9hc3RyJ1xuZXhwb3J0ICogZnJvbSAnLi9yZW5kZXItc3RvcnknXG5leHBvcnQgKiBmcm9tICcuL3RpY2staGVscGVyJ1xuZXhwb3J0ICogZnJvbSAnLi9jdXJyZW50LXRpY2stdGltZSdcblxuZXhwb3J0ICogZnJvbSAnLi9zdG9yeS1leHBlY3QnXG5leHBvcnQgKiBmcm9tICcuL2dldC1oYXJuZXNzJ1xuIl19
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { createMountableStoryComponent } from '@storybook/testing-angular';
|
|
3
|
+
import { render } from '@testing-library/angular';
|
|
4
|
+
// NOTE: This is an experimental attempt at removing some of the boilerplate. If
|
|
5
|
+
// this ends up being worth it, then I will add it to `@storybook/testing-angular`.
|
|
6
|
+
export function renderStory(story) {
|
|
7
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
8
|
+
const { component, ngModule } = createMountableStoryComponent(story({}, {}));
|
|
9
|
+
return yield render(component, { imports: [ngModule] });
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLXN0b3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3Rlc3RpbmcvcmVuZGVyLXN0b3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQTtBQUMxRSxPQUFPLEVBQUUsTUFBTSxFQUFnQixNQUFNLDBCQUEwQixDQUFBO0FBRS9ELGdGQUFnRjtBQUNoRixtRkFBbUY7QUFDbkYsTUFBTSxVQUFnQixXQUFXLENBQXNCLEtBQVU7O1FBQy9ELE1BQU0sRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLEdBQUcsNkJBQTZCLENBQzNELEtBQUssQ0FBQyxFQUFFLEVBQUUsRUFBUyxDQUFDLENBQ3JCLENBQUE7UUFDRCxPQUFPLE1BQU0sTUFBTSxDQUFDLFNBQVMsRUFBRSxFQUFFLE9BQU8sRUFBRSxDQUFFLFFBQVEsQ0FBRSxFQUFFLENBQUMsQ0FBQTtJQUMzRCxDQUFDO0NBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVNb3VudGFibGVTdG9yeUNvbXBvbmVudCB9IGZyb20gJ0BzdG9yeWJvb2svdGVzdGluZy1hbmd1bGFyJ1xuaW1wb3J0IHsgcmVuZGVyLCBSZW5kZXJSZXN1bHQgfSBmcm9tICdAdGVzdGluZy1saWJyYXJ5L2FuZ3VsYXInXG5cbi8vIE5PVEU6IFRoaXMgaXMgYW4gZXhwZXJpbWVudGFsIGF0dGVtcHQgYXQgcmVtb3Zpbmcgc29tZSBvZiB0aGUgYm9pbGVycGxhdGUuIElmXG4vLyB0aGlzIGVuZHMgdXAgYmVpbmcgd29ydGggaXQsIHRoZW4gSSB3aWxsIGFkZCBpdCB0byBgQHN0b3J5Ym9vay90ZXN0aW5nLWFuZ3VsYXJgLlxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHJlbmRlclN0b3J5PENvbXBvbmVudFR5cGUgPSBhbnk+KHN0b3J5OiBhbnkpOiBQcm9taXNlPFJlbmRlclJlc3VsdDxDb21wb25lbnRUeXBlLCBDb21wb25lbnRUeXBlPj4ge1xuICBjb25zdCB7IGNvbXBvbmVudCwgbmdNb2R1bGUgfSA9IGNyZWF0ZU1vdW50YWJsZVN0b3J5Q29tcG9uZW50KFxuICAgIHN0b3J5KHt9LCB7fSBhcyBhbnkpXG4gIClcbiAgcmV0dXJuIGF3YWl0IHJlbmRlcihjb21wb25lbnQsIHsgaW1wb3J0czogWyBuZ01vZHVsZSBdIH0pXG59XG4iXX0=
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { default as expectPatched } from '@storybook/expect';
|
|
3
|
+
import { instrument } from '@storybook/instrumenter';
|
|
4
|
+
import * as mock from 'jest-mock';
|
|
5
|
+
export const { jest } = instrument({ jest: mock });
|
|
6
|
+
// const expectJasmineFn = (window as any).expect
|
|
7
|
+
const expectJestFn = expectPatched;
|
|
8
|
+
// const isInJasmine = expectJasmineFn !== undefined && expectJasmineFn !== null
|
|
9
|
+
// const expectFn = expectJasmineFn || exp
|
|
10
|
+
const isInJasmine = false;
|
|
11
|
+
// console.log('isInJasmine', isInJasmine)
|
|
12
|
+
const { expect } = instrument(
|
|
13
|
+
// { expect: expectJasmineFn || expectJestFn },
|
|
14
|
+
{ expect: expectJestFn },
|
|
15
|
+
// { intercept: (method, path) => path[0] !== 'expect' }
|
|
16
|
+
{ intercept: (method, path) => {
|
|
17
|
+
// console.log('intercept', method, path)
|
|
18
|
+
return path[0] !== 'expect';
|
|
19
|
+
} });
|
|
20
|
+
function toBeFn(matcher) {
|
|
21
|
+
// if (isInJasmine) {
|
|
22
|
+
// // @ts-ignore
|
|
23
|
+
// const m = matcher as jasmine.Matchers<any>
|
|
24
|
+
// return async (value: any) => m.toBe(value) as any
|
|
25
|
+
// } else {
|
|
26
|
+
// const m = matcher as ReturnType<typeof expectJestFn>
|
|
27
|
+
// return async (value: any) => m.toBe(value) as any
|
|
28
|
+
// }
|
|
29
|
+
const m = matcher;
|
|
30
|
+
return (value) => __awaiter(this, void 0, void 0, function* () { return m.toBe(value); });
|
|
31
|
+
}
|
|
32
|
+
export function expectFn(value) {
|
|
33
|
+
// const t = isInJasmine ? expectJasmineFn(value) : expect(value)
|
|
34
|
+
const t = expect(value);
|
|
35
|
+
return {
|
|
36
|
+
toBe: toBeFn(t)
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcnktZXhwZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3Rlc3Rpbmcvc3RvcnktZXhwZWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsT0FBTyxJQUFJLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBQzVELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQTtBQUNwRCxPQUFPLEtBQUssSUFBSSxNQUFNLFdBQVcsQ0FBQTtBQUVqQyxNQUFNLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLFVBQVUsQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFBO0FBRWxELGlEQUFpRDtBQUNqRCxNQUFNLFlBQVksR0FBRyxhQUFhLENBQUE7QUFDbEMsZ0ZBQWdGO0FBQ2hGLDBDQUEwQztBQUMxQyxNQUFNLFdBQVcsR0FBRyxLQUFLLENBQUE7QUFFekIsMENBQTBDO0FBRTFDLE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxVQUFVO0FBQzNCLCtDQUErQztBQUMvQyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUU7QUFDeEIsd0RBQXdEO0FBQ3hELEVBQUUsU0FBUyxFQUFFLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxFQUFFO1FBQzVCLHlDQUF5QztRQUN6QyxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxRQUFRLENBQUE7SUFDN0IsQ0FBQyxFQUFFLENBQ0osQ0FBQTtBQU1ELFNBQVMsTUFBTSxDQUFDLE9BQVk7SUFDMUIscUJBQXFCO0lBQ3JCLGtCQUFrQjtJQUNsQiwrQ0FBK0M7SUFDL0Msc0RBQXNEO0lBQ3RELFdBQVc7SUFDWCx5REFBeUQ7SUFDekQsc0RBQXNEO0lBQ3RELElBQUk7SUFDSixNQUFNLENBQUMsR0FBRyxPQUEwQyxDQUFBO0lBQ3BELE9BQU8sQ0FBTyxLQUFVLEVBQUUsRUFBRSxnREFBQyxPQUFBLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFRLENBQUEsR0FBQSxDQUFBO0FBQ25ELENBQUM7QUFFRCxNQUFNLFVBQVUsUUFBUSxDQUFDLEtBQVU7SUFDakMsa0VBQWtFO0lBQ2xFLE1BQU0sQ0FBQyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUN2QixPQUFPO1FBQ0wsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUM7S0FDaEIsQ0FBQTtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBkZWZhdWx0IGFzIGV4cGVjdFBhdGNoZWQgfSBmcm9tICdAc3Rvcnlib29rL2V4cGVjdCdcbmltcG9ydCB7IGluc3RydW1lbnQgfSBmcm9tICdAc3Rvcnlib29rL2luc3RydW1lbnRlcidcbmltcG9ydCAqIGFzIG1vY2sgZnJvbSAnamVzdC1tb2NrJ1xuXG5leHBvcnQgY29uc3QgeyBqZXN0IH0gPSBpbnN0cnVtZW50KHsgamVzdDogbW9jayB9KVxuXG4vLyBjb25zdCBleHBlY3RKYXNtaW5lRm4gPSAod2luZG93IGFzIGFueSkuZXhwZWN0XG5jb25zdCBleHBlY3RKZXN0Rm4gPSBleHBlY3RQYXRjaGVkXG4vLyBjb25zdCBpc0luSmFzbWluZSA9IGV4cGVjdEphc21pbmVGbiAhPT0gdW5kZWZpbmVkICYmIGV4cGVjdEphc21pbmVGbiAhPT0gbnVsbFxuLy8gY29uc3QgZXhwZWN0Rm4gPSBleHBlY3RKYXNtaW5lRm4gfHwgZXhwXG5jb25zdCBpc0luSmFzbWluZSA9IGZhbHNlXG5cbi8vIGNvbnNvbGUubG9nKCdpc0luSmFzbWluZScsIGlzSW5KYXNtaW5lKVxuXG5jb25zdCB7IGV4cGVjdCB9ID0gaW5zdHJ1bWVudChcbiAgLy8geyBleHBlY3Q6IGV4cGVjdEphc21pbmVGbiB8fCBleHBlY3RKZXN0Rm4gfSxcbiAgeyBleHBlY3Q6IGV4cGVjdEplc3RGbiB9LFxuICAvLyB7IGludGVyY2VwdDogKG1ldGhvZCwgcGF0aCkgPT4gcGF0aFswXSAhPT0gJ2V4cGVjdCcgfVxuICB7IGludGVyY2VwdDogKG1ldGhvZCwgcGF0aCkgPT4ge1xuICAgIC8vIGNvbnNvbGUubG9nKCdpbnRlcmNlcHQnLCBtZXRob2QsIHBhdGgpXG4gICAgcmV0dXJuIHBhdGhbMF0gIT09ICdleHBlY3QnXG4gIH0gfVxuKVxuXG5cblxuXG5cbmZ1bmN0aW9uIHRvQmVGbihtYXRjaGVyOiBhbnkpOiAodmFsdWU6IGFueSkgPT4gUHJvbWlzZTx2b2lkPiB7XG4gIC8vIGlmIChpc0luSmFzbWluZSkge1xuICAvLyAgIC8vIEB0cy1pZ25vcmVcbiAgLy8gICBjb25zdCBtID0gbWF0Y2hlciBhcyBqYXNtaW5lLk1hdGNoZXJzPGFueT5cbiAgLy8gICByZXR1cm4gYXN5bmMgKHZhbHVlOiBhbnkpID0+IG0udG9CZSh2YWx1ZSkgYXMgYW55XG4gIC8vIH0gZWxzZSB7XG4gIC8vICAgY29uc3QgbSA9IG1hdGNoZXIgYXMgUmV0dXJuVHlwZTx0eXBlb2YgZXhwZWN0SmVzdEZuPlxuICAvLyAgIHJldHVybiBhc3luYyAodmFsdWU6IGFueSkgPT4gbS50b0JlKHZhbHVlKSBhcyBhbnlcbiAgLy8gfVxuICBjb25zdCBtID0gbWF0Y2hlciBhcyBSZXR1cm5UeXBlPHR5cGVvZiBleHBlY3RKZXN0Rm4+XG4gIHJldHVybiBhc3luYyAodmFsdWU6IGFueSkgPT4gbS50b0JlKHZhbHVlKSBhcyBhbnlcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGV4cGVjdEZuKHZhbHVlOiBhbnkpIHtcbiAgLy8gY29uc3QgdCA9IGlzSW5KYXNtaW5lID8gZXhwZWN0SmFzbWluZUZuKHZhbHVlKSA6ICBleHBlY3QodmFsdWUpXG4gIGNvbnN0IHQgPSBleHBlY3QodmFsdWUpXG4gIHJldHVybiB7XG4gICAgdG9CZTogdG9CZUZuKHQpXG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlc2VhbS11aS1jb21tb24tdGVzdGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90ZXN0aW5nL3RoZXNlYW0tdWktY29tbW9uLXRlc3RpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { tick } from '@angular/core/testing';
|
|
2
|
+
/**
|
|
3
|
+
* Helps advance tests to specific elapsed times.
|
|
4
|
+
*
|
|
5
|
+
* # When to use
|
|
6
|
+
*
|
|
7
|
+
* If a test needs to do something at 100 ticks, but expected values should
|
|
8
|
+
* also be tested at multiple ticks before 100 ticks, then the previous tick
|
|
9
|
+
* sum needs to be counted. If the elapsed can be easily counted by just
|
|
10
|
+
* skimming the code you should just use `tick()`.
|
|
11
|
+
*
|
|
12
|
+
* The following example is simple enough that `tick()` is probably better, but
|
|
13
|
+
* it shows how it is used.
|
|
14
|
+
*
|
|
15
|
+
* ## Example without
|
|
16
|
+
*
|
|
17
|
+
* ```ts
|
|
18
|
+
* const thing = new Thing()
|
|
19
|
+
* thing.dieAfterTicks(100)
|
|
20
|
+
*
|
|
21
|
+
* tick(25)
|
|
22
|
+
* expect(thing.isAlive).toBe(true)
|
|
23
|
+
*
|
|
24
|
+
* tick(25)
|
|
25
|
+
* expect(thing.isAlive).toBe(true)
|
|
26
|
+
*
|
|
27
|
+
* tick(25)
|
|
28
|
+
* expect(thing.isAlive).toBe(true)
|
|
29
|
+
*
|
|
30
|
+
* tick(25)
|
|
31
|
+
* expect(thing.isAlive).toBe(false)
|
|
32
|
+
* ```
|
|
33
|
+
*
|
|
34
|
+
* ## Example with
|
|
35
|
+
*
|
|
36
|
+
* ```ts
|
|
37
|
+
* const t = new TickHelper()
|
|
38
|
+
* const thing = new Thing()
|
|
39
|
+
* thing.dieAfterTicks(100)
|
|
40
|
+
*
|
|
41
|
+
* t.tickTo(25)
|
|
42
|
+
* expect(thing.isAlive).toBe(true)
|
|
43
|
+
*
|
|
44
|
+
* t.tickTo(50)
|
|
45
|
+
* expect(thing.isAlive).toBe(true)
|
|
46
|
+
*
|
|
47
|
+
* t.tickTo(75)
|
|
48
|
+
* expect(thing.isAlive).toBe(true)
|
|
49
|
+
*
|
|
50
|
+
* t.tickTo(100)
|
|
51
|
+
* expect(thing.isAlive).toBe(false)
|
|
52
|
+
* ```
|
|
53
|
+
*/
|
|
54
|
+
export class TickHelper {
|
|
55
|
+
constructor() {
|
|
56
|
+
this._startTime = Date.now();
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Returns the number of ticks that have elapsed since this class was
|
|
60
|
+
* initialized.
|
|
61
|
+
*/
|
|
62
|
+
get ticksElapsed() { return Date.now() - this._startTime; }
|
|
63
|
+
/**
|
|
64
|
+
* Calls `tick()` for the remaining number of ticks to reach elapsed ticks.
|
|
65
|
+
*
|
|
66
|
+
* ```
|
|
67
|
+
* const t = new TickHelper()
|
|
68
|
+
* tick(3)
|
|
69
|
+
* t.tickTo(10) // Equivalent to `tick(7)` in this case to reach 10 ticks.
|
|
70
|
+
* ```
|
|
71
|
+
*/
|
|
72
|
+
tickTo(ticks) { tick(ticks - this.ticksElapsed); }
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGljay1oZWxwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdGVzdGluZy90aWNrLWhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sdUJBQXVCLENBQUE7QUFFNUM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW1ERztBQUNILE1BQU0sT0FBTyxVQUFVO0lBQXZCO1FBRVUsZUFBVSxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQTtJQW1CakMsQ0FBQztJQWpCQzs7O09BR0c7SUFDSCxJQUFXLFlBQVksS0FBSyxPQUFPLElBQUksQ0FBQyxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFBLENBQUMsQ0FBQztJQUVqRTs7Ozs7Ozs7T0FRRztJQUNJLE1BQU0sQ0FBQyxLQUFhLElBQUksSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUEsQ0FBQyxDQUFDO0NBRWpFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdGljayB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvdGVzdGluZydcblxuLyoqXG4gKiBIZWxwcyBhZHZhbmNlIHRlc3RzIHRvIHNwZWNpZmljIGVsYXBzZWQgdGltZXMuXG4gKlxuICogIyBXaGVuIHRvIHVzZVxuICpcbiAqIElmIGEgdGVzdCBuZWVkcyB0byBkbyBzb21ldGhpbmcgYXQgMTAwIHRpY2tzLCBidXQgZXhwZWN0ZWQgdmFsdWVzIHNob3VsZFxuICogYWxzbyBiZSB0ZXN0ZWQgYXQgbXVsdGlwbGUgdGlja3MgYmVmb3JlIDEwMCB0aWNrcywgdGhlbiB0aGUgcHJldmlvdXMgdGlja1xuICogc3VtIG5lZWRzIHRvIGJlIGNvdW50ZWQuIElmIHRoZSBlbGFwc2VkIGNhbiBiZSBlYXNpbHkgY291bnRlZCBieSBqdXN0XG4gKiBza2ltbWluZyB0aGUgY29kZSB5b3Ugc2hvdWxkIGp1c3QgdXNlIGB0aWNrKClgLlxuICpcbiAqIFRoZSBmb2xsb3dpbmcgZXhhbXBsZSBpcyBzaW1wbGUgZW5vdWdoIHRoYXQgYHRpY2soKWAgaXMgcHJvYmFibHkgYmV0dGVyLCBidXRcbiAqIGl0IHNob3dzIGhvdyBpdCBpcyB1c2VkLlxuICpcbiAqICMjIEV4YW1wbGUgd2l0aG91dFxuICpcbiAqIGBgYHRzXG4gKiBjb25zdCB0aGluZyA9IG5ldyBUaGluZygpXG4gKiB0aGluZy5kaWVBZnRlclRpY2tzKDEwMClcbiAqXG4gKiB0aWNrKDI1KVxuICogZXhwZWN0KHRoaW5nLmlzQWxpdmUpLnRvQmUodHJ1ZSlcbiAqXG4gKiB0aWNrKDI1KVxuICogZXhwZWN0KHRoaW5nLmlzQWxpdmUpLnRvQmUodHJ1ZSlcbiAqXG4gKiB0aWNrKDI1KVxuICogZXhwZWN0KHRoaW5nLmlzQWxpdmUpLnRvQmUodHJ1ZSlcbiAqXG4gKiB0aWNrKDI1KVxuICogZXhwZWN0KHRoaW5nLmlzQWxpdmUpLnRvQmUoZmFsc2UpXG4gKiBgYGBcbiAqXG4gKiAjIyBFeGFtcGxlIHdpdGhcbiAqXG4gKiBgYGB0c1xuICogY29uc3QgdCA9IG5ldyBUaWNrSGVscGVyKClcbiAqIGNvbnN0IHRoaW5nID0gbmV3IFRoaW5nKClcbiAqIHRoaW5nLmRpZUFmdGVyVGlja3MoMTAwKVxuICpcbiAqIHQudGlja1RvKDI1KVxuICogZXhwZWN0KHRoaW5nLmlzQWxpdmUpLnRvQmUodHJ1ZSlcbiAqXG4gKiB0LnRpY2tUbyg1MClcbiAqIGV4cGVjdCh0aGluZy5pc0FsaXZlKS50b0JlKHRydWUpXG4gKlxuICogdC50aWNrVG8oNzUpXG4gKiBleHBlY3QodGhpbmcuaXNBbGl2ZSkudG9CZSh0cnVlKVxuICpcbiAqIHQudGlja1RvKDEwMClcbiAqIGV4cGVjdCh0aGluZy5pc0FsaXZlKS50b0JlKGZhbHNlKVxuICogYGBgXG4gKi9cbmV4cG9ydCBjbGFzcyBUaWNrSGVscGVyIHtcblxuICBwcml2YXRlIF9zdGFydFRpbWUgPSBEYXRlLm5vdygpXG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIG51bWJlciBvZiB0aWNrcyB0aGF0IGhhdmUgZWxhcHNlZCBzaW5jZSB0aGlzIGNsYXNzIHdhc1xuICAgKiBpbml0aWFsaXplZC5cbiAgICovXG4gIHB1YmxpYyBnZXQgdGlja3NFbGFwc2VkKCkgeyByZXR1cm4gRGF0ZS5ub3coKSAtIHRoaXMuX3N0YXJ0VGltZSB9XG5cbiAgLyoqXG4gICAqIENhbGxzIGB0aWNrKClgIGZvciB0aGUgcmVtYWluaW5nIG51bWJlciBvZiB0aWNrcyB0byByZWFjaCBlbGFwc2VkIHRpY2tzLlxuICAgKlxuICAgKiBgYGBcbiAgICogY29uc3QgdCA9IG5ldyBUaWNrSGVscGVyKClcbiAgICogdGljaygzKVxuICAgKiB0LnRpY2tUbygxMCkgLy8gRXF1aXZhbGVudCB0byBgdGljayg3KWAgaW4gdGhpcyBjYXNlIHRvIHJlYWNoIDEwIHRpY2tzLlxuICAgKiBgYGBcbiAgICovXG4gIHB1YmxpYyB0aWNrVG8odGlja3M6IG51bWJlcikgeyB0aWNrKHRpY2tzIC0gdGhpcy50aWNrc0VsYXBzZWQpIH1cblxufVxuIl19
|
|
@@ -2,7 +2,7 @@ import { __decorate } from "tslib";
|
|
|
2
2
|
import { animate, animation, query, stagger, style, transition, trigger, useAnimation } from '@angular/animations';
|
|
3
3
|
import { coerceArray } from '@angular/cdk/coercion';
|
|
4
4
|
import { Platform } from '@angular/cdk/platform';
|
|
5
|
-
import { ChangeDetectorRef, Component, ContentChildren, EventEmitter, forwardRef, Input, Output } from '@angular/core';
|
|
5
|
+
import { ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, forwardRef, Input, Output, Renderer2 } from '@angular/core';
|
|
6
6
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
7
7
|
import { InputBoolean } from '@theseam/ui-common/core';
|
|
8
8
|
import { TiledSelectTileOverlayDirective } from './../../directives/tiled-select-tile-overlay.directive';
|
|
@@ -15,13 +15,15 @@ export const slideEnterAnimation = animation([
|
|
|
15
15
|
export const TILED_SELECT_VALUE_ACCESSOR = {
|
|
16
16
|
provide: NG_VALUE_ACCESSOR,
|
|
17
17
|
// tslint:disable-next-line:no-use-before-declare
|
|
18
|
-
useExisting: forwardRef(() =>
|
|
18
|
+
useExisting: forwardRef(() => TheSeamTiledSelectComponent),
|
|
19
19
|
multi: true,
|
|
20
20
|
};
|
|
21
|
-
export class
|
|
22
|
-
constructor(_platform, _cdr) {
|
|
21
|
+
export class TheSeamTiledSelectComponent {
|
|
22
|
+
constructor(_platform, _cdr, _renderer, _elementRef) {
|
|
23
23
|
this._platform = _platform;
|
|
24
24
|
this._cdr = _cdr;
|
|
25
|
+
this._renderer = _renderer;
|
|
26
|
+
this._elementRef = _elementRef;
|
|
25
27
|
this.layout = 'grid';
|
|
26
28
|
this._tiles = [];
|
|
27
29
|
this.disabled = false;
|
|
@@ -64,6 +66,7 @@ export class TiledSelectComponent {
|
|
|
64
66
|
}
|
|
65
67
|
set value(value) {
|
|
66
68
|
this.val = (this.multiple) ? [...(value || [])] : value || '';
|
|
69
|
+
this._renderer.setProperty(this._elementRef.nativeElement, 'value', this.val);
|
|
67
70
|
if (this.onChange) {
|
|
68
71
|
this.onChange(this.val);
|
|
69
72
|
this.change.emit(this.val);
|
|
@@ -144,11 +147,14 @@ export class TiledSelectComponent {
|
|
|
144
147
|
return (this.overlayTpls || []).find(t => { var _a; return ((_a = t.record) === null || _a === void 0 ? void 0 : _a.name) === tile.name; });
|
|
145
148
|
}
|
|
146
149
|
}
|
|
147
|
-
|
|
150
|
+
TheSeamTiledSelectComponent.decorators = [
|
|
148
151
|
{ type: Component, args: [{
|
|
149
152
|
selector: 'seam-tiled-select',
|
|
150
|
-
template: "<div class=\"tiled-select--container\"\n [class.grid]=\"layout === 'grid'\"\n [class.list]=\"layout === 'list'\"\n [@tiles]=\"tilesAnimationState\"\n [@.disabled]=\"animationsDisabled\">\n <ng-container *ngFor=\"let tile of tiles\">\n <div class=\"tile-wrapper\" [ngClass]=\"tile.customClass || ''\">\n <seam-tiled-select-tile\n class=\"tiled-select-tile\"\n [ngClass]=\"tile.customClass || ''\"\n [name]=\"tile.name\"\n [label]=\"tile.label\"\n [icon]=\"tile.icon\"\n [disabled]=\"disabled || tile.disabled\"\n [attr.hidden]=\"tile.hidden\"\n [layout]=\"layout\"\n [selected]=\"isSelected(tile)\"\n [selectable]=\"true\"\n [tileBackdrop]=\"tileBackdrop\"\n [showSelectedIcon]=\"showSelectedIcon\"\n [overlayTpl]=\"getOverlayTpl(tile)\"\n (activated)=\"onTileSelected($event, tile)\">\n </seam-tiled-select-tile>\n </div>\n </ng-container>\n</div>\n",
|
|
153
|
+
template: "<div class=\"tiled-select--container\"\n [class.grid]=\"layout === 'grid'\"\n [class.list]=\"layout === 'list'\"\n [@tiles]=\"tilesAnimationState\"\n [@.disabled]=\"animationsDisabled\">\n <ng-container *ngFor=\"let tile of tiles; let index = index\">\n <div class=\"tile-wrapper\" [ngClass]=\"tile.customClass || ''\">\n <seam-tiled-select-tile\n class=\"tiled-select-tile\"\n [ngClass]=\"tile.customClass || ''\"\n [name]=\"tile.name\"\n [label]=\"tile.label\"\n [icon]=\"tile.icon\"\n [disabled]=\"disabled || tile.disabled\"\n [attr.hidden]=\"tile.hidden\"\n [layout]=\"layout\"\n [selected]=\"isSelected(tile)\"\n [selectable]=\"true\"\n [tileBackdrop]=\"tileBackdrop\"\n [showSelectedIcon]=\"showSelectedIcon\"\n [overlayTpl]=\"getOverlayTpl(tile)\"\n (activated)=\"onTileSelected($event, tile)\"\n [attr.data-tile-index]=\"index\"\n [attr.data-testid]=\"tile.name\">\n </seam-tiled-select-tile>\n </div>\n </ng-container>\n</div>\n",
|
|
151
154
|
providers: [TILED_SELECT_VALUE_ACCESSOR],
|
|
155
|
+
host: {
|
|
156
|
+
'[attr.data-testid]': '"tiled-select"'
|
|
157
|
+
},
|
|
152
158
|
animations: [
|
|
153
159
|
trigger('tiles', [
|
|
154
160
|
transition('* => *', [
|
|
@@ -156,14 +162,16 @@ TiledSelectComponent.decorators = [
|
|
|
156
162
|
])
|
|
157
163
|
])
|
|
158
164
|
],
|
|
159
|
-
styles: [":host{display:block;width:100%}.tiled-select--container{display:flex;flex-wrap:wrap;justify-content:center}.tiled-select--container.grid{flex-direction:row}.tiled-select--container.grid .tile-wrapper{padding:12px;width:200px;height:180px}.tiled-select--container.grid .tile-wrapper .tiled-select-tile{height:100%}.tiled-select--container.grid .tile-wrapper.other-org{width:auto;height:auto}@media screen and (max-width:600px){.tiled-select--container.grid .tile-wrapper{padding:6px;width:150px;height:135px}}.tiled-select--container.list{flex-direction:column}.tiled-select--container.list .tile-wrapper{width:100%;height:50px}.tiled-select--container.list .tile-wrapper:not(:last-child){margin-bottom:4px}"]
|
|
165
|
+
styles: [":host{display:block;width:100%}.tiled-select--container{display:flex;flex-wrap:wrap;justify-content:center}.tiled-select--container.grid{flex-direction:row}.tiled-select--container.grid .tile-wrapper{padding:12px;width:200px;height:180px}.tiled-select--container.grid .tile-wrapper .tiled-select-tile{height:100%}.tiled-select--container.grid .tile-wrapper.other-org{width:auto;height:auto}@media screen and (max-width: 600px){.tiled-select--container.grid .tile-wrapper{padding:6px;width:150px;height:135px}}.tiled-select--container.list{flex-direction:column}.tiled-select--container.list .tile-wrapper{width:100%;height:50px}.tiled-select--container.list .tile-wrapper:not(:last-child){margin-bottom:4px}\n"]
|
|
160
166
|
},] }
|
|
161
167
|
];
|
|
162
|
-
|
|
168
|
+
TheSeamTiledSelectComponent.ctorParameters = () => [
|
|
163
169
|
{ type: Platform },
|
|
164
|
-
{ type: ChangeDetectorRef }
|
|
170
|
+
{ type: ChangeDetectorRef },
|
|
171
|
+
{ type: Renderer2 },
|
|
172
|
+
{ type: ElementRef }
|
|
165
173
|
];
|
|
166
|
-
|
|
174
|
+
TheSeamTiledSelectComponent.propDecorators = {
|
|
167
175
|
layout: [{ type: Input }],
|
|
168
176
|
tiles: [{ type: Input }],
|
|
169
177
|
val: [{ type: Input, args: ['value',] }],
|
|
@@ -178,20 +186,20 @@ TiledSelectComponent.propDecorators = {
|
|
|
178
186
|
};
|
|
179
187
|
__decorate([
|
|
180
188
|
InputBoolean()
|
|
181
|
-
],
|
|
189
|
+
], TheSeamTiledSelectComponent.prototype, "disabled", void 0);
|
|
182
190
|
__decorate([
|
|
183
191
|
InputBoolean()
|
|
184
|
-
],
|
|
192
|
+
], TheSeamTiledSelectComponent.prototype, "multiple", void 0);
|
|
185
193
|
__decorate([
|
|
186
194
|
InputBoolean()
|
|
187
|
-
],
|
|
195
|
+
], TheSeamTiledSelectComponent.prototype, "selectionToggleable", void 0);
|
|
188
196
|
__decorate([
|
|
189
197
|
InputBoolean()
|
|
190
|
-
],
|
|
198
|
+
], TheSeamTiledSelectComponent.prototype, "tileBackdrop", void 0);
|
|
191
199
|
__decorate([
|
|
192
200
|
InputBoolean()
|
|
193
|
-
],
|
|
201
|
+
], TheSeamTiledSelectComponent.prototype, "showSelectedIcon", void 0);
|
|
194
202
|
__decorate([
|
|
195
203
|
InputBoolean()
|
|
196
|
-
],
|
|
197
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiled-select.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/tiled-select/components/tiled-select/tiled-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, animation, query, stagger, style, transition, trigger, useAnimation } from '@angular/animations'\nimport { BooleanInput, coerceArray } from '@angular/cdk/coercion'\nimport { Platform } from '@angular/cdk/platform'\nimport { ChangeDetectorRef, Component, ContentChildren, EventEmitter, forwardRef, Input, OnInit, Output, QueryList } from '@angular/core'\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\n\nimport { TiledSelectTileOverlayDirective } from './../../directives/tiled-select-tile-overlay.directive'\n\nimport { ITiledSelectItem, TiledSelectLayout } from '../../tiled-select.models'\n\nexport const slideEnterAnimation = animation([\n  style({ opacity: 0, transform: 'translateX(-15px)' }),\n  stagger(100, [\n    animate('0.5s', style({ opacity: 1, transform: 'translateX(0)' }))\n  ])\n])\n\nexport const TILED_SELECT_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  // tslint:disable-next-line:no-use-before-declare\n  useExisting: forwardRef(() => TiledSelectComponent),\n  multi: true,\n}\n\n@Component({\n  selector: 'seam-tiled-select',\n  templateUrl: './tiled-select.component.html',\n  styleUrls: ['./tiled-select.component.scss'],\n  providers: [ TILED_SELECT_VALUE_ACCESSOR ],\n  animations: [\n    trigger('tiles', [\n      transition('* => *', [\n        query(':enter', useAnimation(slideEnterAnimation), { optional: true })\n      ])\n    ])\n  ],\n})\nexport class TiledSelectComponent implements OnInit, ControlValueAccessor {\n  static ngAcceptInputType_val: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_multiple: BooleanInput\n  static ngAcceptInputType_selectionToggleable: BooleanInput\n  static ngAcceptInputType_tileBackdrop: BooleanInput\n  static ngAcceptInputType_showSelectedIcon: BooleanInput\n  static ngAcceptInputType_animationsDisabled: BooleanInput\n\n  @Input() layout: TiledSelectLayout = 'grid'\n  @Input()\n  get tiles() { return this._tiles }\n  set tiles(value: ITiledSelectItem[]) {\n    const _value = [ ...(value || []) ]\n    for (const v of _value) {\n      if (v.value === undefined) {\n        if (v.name === undefined) {\n          throw new Error('If value is undefined then name must be defined.')\n        }\n        v.value = v.name\n      }\n    }\n\n    const prev = this._tiles\n    if (prev.length !== _value.length) {\n      this.tilesAnimationState = !this.tilesAnimationState\n    } else {\n      for (const t of _value) {\n        if (!prev.find(p => p.name === t.name)) {\n          this.tilesAnimationState = !this.tilesAnimationState\n          break\n        }\n      }\n    }\n\n    this._tiles = _value\n  }\n  private _tiles: ITiledSelectItem[] = []\n\n  // tslint:disable-next-line:no-input-rename\n  @Input('value') val: string | string[] | undefined\n\n  @Input() @InputBoolean() disabled: boolean = false\n  @Input() @InputBoolean() multiple: boolean = false\n  @Input() @InputBoolean() selectionToggleable: boolean = true\n  @Input() @InputBoolean() tileBackdrop: boolean = false\n  @Input() @InputBoolean() showSelectedIcon: boolean = true\n  @Input() @InputBoolean() animationsDisabled: boolean = this._platform.IOS\n\n  @Output() readonly change = new EventEmitter<string | string[] | undefined>()\n\n  tilesAnimationState = false\n\n  onChange: any\n  onTouched: any\n\n  @ContentChildren(TiledSelectTileOverlayDirective)\n  public overlayTpls?: QueryList<TiledSelectTileOverlayDirective>\n\n  constructor(\n    private readonly _platform: Platform,\n    private readonly _cdr: ChangeDetectorRef\n  ) { }\n\n  ngOnInit() { }\n\n  get value(): string | string[] | undefined {\n    return this.val\n  }\n\n  set value(value: string | string[] | undefined) {\n    this.val = (this.multiple) ? [ ...(<string[]>value || []) ] : value || ''\n    if (this.onChange) {\n      this.onChange(this.val)\n      this.change.emit(this.val)\n      this._cdr.markForCheck()\n    }\n    if (this.onTouched) { this.onTouched() }\n  }\n\n  writeValue(value: any): void {\n    this.value = value\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled\n  }\n\n  onTileSelected(event: MouseEvent, tile: ITiledSelectItem) {\n    this.toggleTileSelected(tile)\n  }\n\n  public isSelected(tile: ITiledSelectItem) {\n    if (!this.multiple) {\n      if (this.value === tile.value) {\n        return true\n      }\n    } else {\n      if (this.value) {\n        for (const v of this.value) {\n          if (v === tile.value) {\n            return true\n          }\n        }\n      }\n    }\n\n    return false\n  }\n\n  public toggleTileSelected(tile: ITiledSelectItem): void {\n    if (!this.selectionToggleable && this.isSelected(tile)) {\n      return\n    }\n\n    if (this.isSelected(tile)) {\n      this.unselectTile(tile)\n    } else {\n      this.selectTile(tile)\n    }\n  }\n\n  public selectTile(tile: ITiledSelectItem): void {\n    if (this.multiple) {\n      if (!this.isSelected(tile)) {\n        const value: string[] = <string[]>this.value || []\n        this.value = [ ...coerceArray(value), tile.value ]\n      }\n    } else {\n      this.value = tile.value\n    }\n  }\n\n  public unselectTile(tile: ITiledSelectItem): void {\n    if (this.multiple) {\n      const value: string[] = <string[]>this.value || []\n      this.value = value.filter(v => v !== tile.value)\n    } else {\n      this.value = undefined\n    }\n  }\n\n  public getSelectedTiles(): ITiledSelectItem[] {\n    return this.tiles.filter(t => this.isSelected(t))\n  }\n\n  getOverlayTpl(tile: ITiledSelectItem): TiledSelectTileOverlayDirective | undefined {\n    // console.log('overlayTpls', this.overlayTpls)\n    return (this.overlayTpls || []).find(t => t.record?.name === tile.name)\n  }\n\n}\n"]}
|
|
204
|
+
], TheSeamTiledSelectComponent.prototype, "animationsDisabled", void 0);
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiled-select.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/tiled-select/components/tiled-select/tiled-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, animation, query, stagger, style, transition, trigger, useAnimation } from '@angular/animations'\nimport { BooleanInput, coerceArray } from '@angular/cdk/coercion'\nimport { Platform } from '@angular/cdk/platform'\nimport { ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, forwardRef, Input, OnInit, Output, QueryList, Renderer2 } from '@angular/core'\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\n\nimport { TiledSelectTileOverlayDirective } from './../../directives/tiled-select-tile-overlay.directive'\n\nimport { ITiledSelectItem, TiledSelectLayout } from '../../tiled-select.models'\n\nexport const slideEnterAnimation = animation([\n  style({ opacity: 0, transform: 'translateX(-15px)' }),\n  stagger(100, [\n    animate('0.5s', style({ opacity: 1, transform: 'translateX(0)' }))\n  ])\n])\n\nexport const TILED_SELECT_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  // tslint:disable-next-line:no-use-before-declare\n  useExisting: forwardRef(() => TheSeamTiledSelectComponent),\n  multi: true,\n}\n\n@Component({\n  selector: 'seam-tiled-select',\n  templateUrl: './tiled-select.component.html',\n  styleUrls: ['./tiled-select.component.scss'],\n  providers: [ TILED_SELECT_VALUE_ACCESSOR ],\n  host: {\n    '[attr.data-testid]': '\"tiled-select\"'\n  },\n  animations: [\n    trigger('tiles', [\n      transition('* => *', [\n        query(':enter', useAnimation(slideEnterAnimation), { optional: true })\n      ])\n    ])\n  ],\n})\nexport class TheSeamTiledSelectComponent implements OnInit, ControlValueAccessor {\n  static ngAcceptInputType_val: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_multiple: BooleanInput\n  static ngAcceptInputType_selectionToggleable: BooleanInput\n  static ngAcceptInputType_tileBackdrop: BooleanInput\n  static ngAcceptInputType_showSelectedIcon: BooleanInput\n  static ngAcceptInputType_animationsDisabled: BooleanInput\n\n  @Input() layout: TiledSelectLayout = 'grid'\n  @Input()\n  get tiles() { return this._tiles }\n  set tiles(value: ITiledSelectItem[]) {\n    const _value = [ ...(value || []) ]\n    for (const v of _value) {\n      if (v.value === undefined) {\n        if (v.name === undefined) {\n          throw new Error('If value is undefined then name must be defined.')\n        }\n        v.value = v.name\n      }\n    }\n\n    const prev = this._tiles\n    if (prev.length !== _value.length) {\n      this.tilesAnimationState = !this.tilesAnimationState\n    } else {\n      for (const t of _value) {\n        if (!prev.find(p => p.name === t.name)) {\n          this.tilesAnimationState = !this.tilesAnimationState\n          break\n        }\n      }\n    }\n\n    this._tiles = _value\n  }\n  private _tiles: ITiledSelectItem[] = []\n\n  // tslint:disable-next-line:no-input-rename\n  @Input('value') val: string | string[] | undefined\n\n  @Input() @InputBoolean() disabled: boolean = false\n  @Input() @InputBoolean() multiple: boolean = false\n  @Input() @InputBoolean() selectionToggleable: boolean = true\n  @Input() @InputBoolean() tileBackdrop: boolean = false\n  @Input() @InputBoolean() showSelectedIcon: boolean = true\n  @Input() @InputBoolean() animationsDisabled: boolean = this._platform.IOS\n\n  @Output() readonly change = new EventEmitter<string | string[] | undefined>()\n\n  tilesAnimationState = false\n\n  onChange: any\n  onTouched: any\n\n  @ContentChildren(TiledSelectTileOverlayDirective)\n  public overlayTpls?: QueryList<TiledSelectTileOverlayDirective>\n\n  constructor(\n    private readonly _platform: Platform,\n    private readonly _cdr: ChangeDetectorRef,\n    private readonly _renderer: Renderer2,\n    private readonly _elementRef: ElementRef\n  ) { }\n\n  ngOnInit() { }\n\n  get value(): string | string[] | undefined {\n    return this.val\n  }\n\n  set value(value: string | string[] | undefined) {\n    this.val = (this.multiple) ? [ ...(<string[]>value || []) ] : value || ''\n\n    this._renderer.setProperty(this._elementRef.nativeElement, 'value', this.val)\n\n    if (this.onChange) {\n      this.onChange(this.val)\n      this.change.emit(this.val)\n      this._cdr.markForCheck()\n    }\n    if (this.onTouched) { this.onTouched() }\n  }\n\n  writeValue(value: any): void {\n    this.value = value\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled\n  }\n\n  onTileSelected(event: MouseEvent, tile: ITiledSelectItem) {\n    this.toggleTileSelected(tile)\n  }\n\n  public isSelected(tile: ITiledSelectItem) {\n    if (!this.multiple) {\n      if (this.value === tile.value) {\n        return true\n      }\n    } else {\n      if (this.value) {\n        for (const v of this.value) {\n          if (v === tile.value) {\n            return true\n          }\n        }\n      }\n    }\n\n    return false\n  }\n\n  public toggleTileSelected(tile: ITiledSelectItem): void {\n    if (!this.selectionToggleable && this.isSelected(tile)) {\n      return\n    }\n\n    if (this.isSelected(tile)) {\n      this.unselectTile(tile)\n    } else {\n      this.selectTile(tile)\n    }\n  }\n\n  public selectTile(tile: ITiledSelectItem): void {\n    if (this.multiple) {\n      if (!this.isSelected(tile)) {\n        const value: string[] = <string[]>this.value || []\n        this.value = [ ...coerceArray(value), tile.value ]\n      }\n    } else {\n      this.value = tile.value\n    }\n  }\n\n  public unselectTile(tile: ITiledSelectItem): void {\n    if (this.multiple) {\n      const value: string[] = <string[]>this.value || []\n      this.value = value.filter(v => v !== tile.value)\n    } else {\n      this.value = undefined\n    }\n  }\n\n  public getSelectedTiles(): ITiledSelectItem[] {\n    return this.tiles.filter(t => this.isSelected(t))\n  }\n\n  getOverlayTpl(tile: ITiledSelectItem): TiledSelectTileOverlayDirective | undefined {\n    // console.log('overlayTpls', this.overlayTpls)\n    return (this.overlayTpls || []).find(t => t.record?.name === tile.name)\n  }\n\n}\n\n/** @deprecated Use `TheSeamTiledSelectComponent`. */\nexport type TiledSelectComponent = TheSeamTiledSelectComponent\n"]}
|
|
@@ -31,7 +31,9 @@ export class TiledSelectTileComponent {
|
|
|
31
31
|
this.activated = new EventEmitter();
|
|
32
32
|
this.pulsing = false;
|
|
33
33
|
}
|
|
34
|
+
get _tileNameAttr() { return this.name; }
|
|
34
35
|
onTileClick(event) {
|
|
36
|
+
console.log('event', event);
|
|
35
37
|
if (!this.selectable) {
|
|
36
38
|
return;
|
|
37
39
|
}
|
|
@@ -77,7 +79,7 @@ TiledSelectTileComponent.decorators = [
|
|
|
77
79
|
// transition('false <=> true', animate(500))
|
|
78
80
|
// ])
|
|
79
81
|
],
|
|
80
|
-
styles: [":host{display:block}.tiled-select-tile-panel{width:100%;height:100%;box-sizing:border-box;border:1px solid #e6e6e6;background-color:#fff;color:#505050;position:relative;overflow:hidden}.tiled-select-tile-panel:disabled:not(.no-grayscale){filter:grayscale(1)}.tiled-select-tile-panel .grey-fix{visibility:hidden;display:block}.tiled-select-tile-panel.selected{border:1px solid #3c96c8}.tiled-select-tile-panel.selectable:hover:not(:disabled){box-shadow:0 3px 1px -2px
|
|
82
|
+
styles: [":host{display:block}.tiled-select-tile-panel{width:100%;height:100%;box-sizing:border-box;border:1px solid #e6e6e6;background-color:#fff;color:#505050;position:relative;overflow:hidden}.tiled-select-tile-panel:disabled:not(.no-grayscale){filter:grayscale(1)}.tiled-select-tile-panel .grey-fix{visibility:hidden;display:block}.tiled-select-tile-panel.selected{border:1px solid #3c96c8}.tiled-select-tile-panel.selectable:hover:not(:disabled){box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f;cursor:pointer}.tiled-select-tile-panel.selectable:focus:not(:disabled){outline:none}.tiled-select-tile-panel:not(.selectable){box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f}.tiled-select-tile-panel .tiled-select-tile-panel--content{display:flex;height:100%;width:100%}.tiled-select-tile-panel .tiled-select-tile-panel--content .tiled-select-tile-panel--selected{position:absolute;top:4px;right:4px}.tiled-select-tile-panel .tiled-select-tile-panel--content .selected-backdrop{opacity:.2;position:absolute;top:0;right:0;bottom:0;left:0;border-radius:15px;transition:ease-in-out .2s background-color;pointer-events:none}.tiled-select-tile-panel .tiled-select-tile-panel--overlay{position:absolute;top:0;left:0;bottom:0;right:0}.tiled-select-tile-panel.grid{border-radius:15px;padding:0;margin:0}.tiled-select-tile-panel.grid .tiled-select-tile-panel--content{flex-direction:column}.tiled-select-tile-panel.grid .tiled-select-tile-panel--content .selected-backdrop{border-radius:15px}.tiled-select-tile-panel.grid .tiled-select-tile-panel--label-container{flex:0 0 auto;height:2.5em;line-height:1em}.tiled-select-tile-panel.grid .tiled-select-tile-panel--label-container .tiled-select-tile-panel--label{display:block;font-size:90%;padding:0 1em;white-space:normal;white-space:initial}@media screen and (max-width: 600px){.tiled-select-tile-panel.grid .tiled-select-tile-panel--label-container{height:2rem;line-height:.9em}.tiled-select-tile-panel.grid .tiled-select-tile-panel--label-container .tiled-select-tile-panel--label{font-size:13px;padding:0 .7em}}.tiled-select-tile-panel.list{border-radius:10px;padding:4px}.tiled-select-tile-panel.list .tiled-select-tile-panel--content{flex-direction:row}.tiled-select-tile-panel.list .tiled-select-tile-panel--content .selected-backdrop{border-radius:10px}.tiled-select-tile-panel.list .tiled-select-tile-panel--label-container{display:flex;max-height:100%;flex-direction:column;padding-right:40px}.tiled-select-tile-panel.list .tiled-select-tile-panel--label-container .tiled-select-tile-panel--label{padding:0 6px;text-align:left;margin:auto 0;font-size:80%;white-space:normal;white-space:initial}.tiled-select-tile-panel.list .tiled-select-tile-panel--selected ::ng-deep .svg-inline--fa{height:39px}:host(.other-org) .tiled-select-tile-panel.grid{border:0}:host(.other-org) .tiled-select-tile-panel.grid.selectable:hover:not(:disabled){box-shadow:0 0}:host(.other-org) .tiled-select-tile-panel.grid.selectable:hover:not(:disabled) .tiled-select-tile-panel--label-container{text-decoration:underline}:host(.other-org) .tiled-select-tile-panel.grid .tiled-select-tile-panel--icon,:host(.other-org) .tiled-select-tile-panel.grid .tiled-select-tile-panel--selected.text-success{display:none}:host(.other-org) .tiled-select-tile-panel.grid .tiled-select-tile-panel--label-container{height:auto;color:#357ebd}:host(.other-org) .tiled-select-tile-panel.grid .tiled-select-tile-panel--label{padding:.5rem 1rem}\n"]
|
|
81
83
|
},] }
|
|
82
84
|
];
|
|
83
85
|
TiledSelectTileComponent.ctorParameters = () => [
|
|
@@ -85,6 +87,7 @@ TiledSelectTileComponent.ctorParameters = () => [
|
|
|
85
87
|
];
|
|
86
88
|
TiledSelectTileComponent.propDecorators = {
|
|
87
89
|
pulseAnimationState: [{ type: HostBinding, args: ['@pulse',] }],
|
|
90
|
+
_tileNameAttr: [{ type: HostBinding, args: ['attr.data-tile-name',] }],
|
|
88
91
|
layout: [{ type: Input }],
|
|
89
92
|
name: [{ type: Input }],
|
|
90
93
|
label: [{ type: Input }],
|
|
@@ -122,4 +125,4 @@ __decorate([
|
|
|
122
125
|
__decorate([
|
|
123
126
|
InputBoolean()
|
|
124
127
|
], TiledSelectTileComponent.prototype, "showSelectedIcon", void 0);
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiled-select-tile.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/tiled-select/components/tiled-select-tile/tiled-select-tile.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, animation, keyframes, style, transition, trigger, useAnimation } from '@angular/animations'\nimport { BooleanInput } from '@angular/cdk/coercion'\nimport { ChangeDetectorRef, Component, ContentChild, EventEmitter, HostBinding, Input, Output } from '@angular/core'\n\nimport { faCheckCircle } from '@fortawesome/free-regular-svg-icons'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { SeamIcon } from '@theseam/ui-common/icon'\n\nimport { TiledSelectTileLabelTplDirective } from '../../directives/tiled-select-tile-label-tpl.directive'\nimport { TiledSelectTileOverlayDirective } from '../../directives/tiled-select-tile-overlay.directive'\nimport { TiledSelectLayout } from '../../tiled-select.models'\n\nexport const tilePulse = animation(\n  animate(\n    '{{ timing }}s {{ delay }}s',\n    keyframes([\n      style({ transform: 'scale3d(1, 1, 1)' }),\n      style({ transform: 'scale3d({{ scale }}, {{ scale }}, {{ scale }})' }),\n      style({ transform: 'scale3d(1, 1, 1)' }),\n    ])\n  ),\n  { params: { scale: 1.05, timing: 0.75, delay: 0 } }\n)\n\nexport const tileScaleUp = animation(\n  animate(\n    '{{ timing }}s {{ delay }}s',\n    keyframes([\n      style({ transform: 'scale3d({{ scale }}, {{ scale }}, {{ scale }})' }),\n    ])\n  ),\n  { params: { scale: 1.05, timing: 0.75, delay: 0 } }\n)\n\nexport const tileScaleDown = animation(\n  animate(\n    '{{ timing }}s {{ delay }}s',\n    keyframes([\n      style({ transform: 'scale3d(1, 1, 1)' }),\n    ])\n  ),\n  { params: { scale: 1.05, timing: 0.75, delay: 0 } }\n)\n\n@Component({\n  selector: 'seam-tiled-select-tile',\n  templateUrl: './tiled-select-tile.component.html',\n  styleUrls: ['./tiled-select-tile.component.scss'],\n  animations: [\n    trigger('pulse', [\n      transition('false => true', [\n        useAnimation(tilePulse)\n        // useAnimation(tileScaleUp)\n      ]),\n      // transition('true => false', [\n      //   useAnimation(tileScaleDown)\n      // ])\n    ]),\n    // trigger('openClose', [\n    //   state('true', style({ height: '*' })),\n    //   state('false', style({ height: '0px' })),\n    //   transition('false <=> true', animate(500))\n    // ])\n  ],\n  // changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TiledSelectTileComponent {\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_selected: BooleanInput\n  static ngAcceptInputType_tileBackdrop: BooleanInput\n  static ngAcceptInputType_selectable: BooleanInput\n  static ngAcceptInputType_grayscaleOnDisable: BooleanInput\n  static ngAcceptInputType_showLabel: BooleanInput\n  static ngAcceptInputType_showSelectedIcon: BooleanInput\n\n  faCheckCircle = faCheckCircle\n\n  @HostBinding('@pulse') pulseAnimationState = true\n\n  @Input() layout: TiledSelectLayout = 'grid'\n\n  @Input() name: string | undefined | null\n  @Input() label: string | undefined | null\n  @Input() icon: SeamIcon | undefined | null\n  @Input() @InputBoolean() disabled: boolean = false\n  @Input() @InputBoolean() selected: boolean = false\n\n  @Input() @InputBoolean() tileBackdrop: boolean = false\n  @Input() @InputBoolean() selectable: boolean = false\n  @Input() @InputBoolean() grayscaleOnDisable: boolean = true\n  @Input() @InputBoolean() showLabel: boolean = true\n  @Input() @InputBoolean() showSelectedIcon: boolean = true\n\n  @Input() iconClass: string | undefined | null\n\n  @Input() overlayTpl: TiledSelectTileOverlayDirective | undefined | null\n\n  @Output() activated = new EventEmitter<any>()\n\n  @ContentChild(TiledSelectTileLabelTplDirective, { static: true }) labelTpl?: TiledSelectTileLabelTplDirective\n\n  pulsing = false\n  pulsingTimeout: number | undefined\n\n  constructor(\n    private cdr: ChangeDetectorRef\n  ) { }\n\n  onTileClick(event: any) {\n    if (!this.selectable) { return }\n    this.activated.emit(event)\n\n    // this.pulsing = true\n    // setTimeout(() => {\n    //   this.pulsing = false\n    // }, 750)\n  }\n\n  mDown() {\n    if (this.pulsingTimeout) {\n      clearTimeout(this.pulsingTimeout)\n    }\n\n    if (!this.pulsing) {\n      this.pulsing = true\n      // this.cdr.detectChanges()\n    }\n\n    // console.log('start')\n    this.pulsingTimeout = window.setTimeout(() => {\n      this.pulsing = false\n      // this.cdr.detectChanges()\n      this.pulsingTimeout = undefined\n    }, 750)\n  }\n\n}\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiled-select-tile.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/tiled-select/components/tiled-select-tile/tiled-select-tile.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, animation, keyframes, style, transition, trigger, useAnimation } from '@angular/animations'\nimport { BooleanInput } from '@angular/cdk/coercion'\nimport { ChangeDetectorRef, Component, ContentChild, EventEmitter, HostBinding, Input, Output } from '@angular/core'\n\nimport { faCheckCircle } from '@fortawesome/free-regular-svg-icons'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { SeamIcon } from '@theseam/ui-common/icon'\n\nimport { TiledSelectTileLabelTplDirective } from '../../directives/tiled-select-tile-label-tpl.directive'\nimport { TiledSelectTileOverlayDirective } from '../../directives/tiled-select-tile-overlay.directive'\nimport { TiledSelectLayout } from '../../tiled-select.models'\n\nexport const tilePulse = animation(\n  animate(\n    '{{ timing }}s {{ delay }}s',\n    keyframes([\n      style({ transform: 'scale3d(1, 1, 1)' }),\n      style({ transform: 'scale3d({{ scale }}, {{ scale }}, {{ scale }})' }),\n      style({ transform: 'scale3d(1, 1, 1)' }),\n    ])\n  ),\n  { params: { scale: 1.05, timing: 0.75, delay: 0 } }\n)\n\nexport const tileScaleUp = animation(\n  animate(\n    '{{ timing }}s {{ delay }}s',\n    keyframes([\n      style({ transform: 'scale3d({{ scale }}, {{ scale }}, {{ scale }})' }),\n    ])\n  ),\n  { params: { scale: 1.05, timing: 0.75, delay: 0 } }\n)\n\nexport const tileScaleDown = animation(\n  animate(\n    '{{ timing }}s {{ delay }}s',\n    keyframes([\n      style({ transform: 'scale3d(1, 1, 1)' }),\n    ])\n  ),\n  { params: { scale: 1.05, timing: 0.75, delay: 0 } }\n)\n\n@Component({\n  selector: 'seam-tiled-select-tile',\n  templateUrl: './tiled-select-tile.component.html',\n  styleUrls: ['./tiled-select-tile.component.scss'],\n  animations: [\n    trigger('pulse', [\n      transition('false => true', [\n        useAnimation(tilePulse)\n        // useAnimation(tileScaleUp)\n      ]),\n      // transition('true => false', [\n      //   useAnimation(tileScaleDown)\n      // ])\n    ]),\n    // trigger('openClose', [\n    //   state('true', style({ height: '*' })),\n    //   state('false', style({ height: '0px' })),\n    //   transition('false <=> true', animate(500))\n    // ])\n  ],\n  // changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TiledSelectTileComponent {\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_selected: BooleanInput\n  static ngAcceptInputType_tileBackdrop: BooleanInput\n  static ngAcceptInputType_selectable: BooleanInput\n  static ngAcceptInputType_grayscaleOnDisable: BooleanInput\n  static ngAcceptInputType_showLabel: BooleanInput\n  static ngAcceptInputType_showSelectedIcon: BooleanInput\n\n  faCheckCircle = faCheckCircle\n\n  @HostBinding('@pulse') pulseAnimationState = true\n  @HostBinding('attr.data-tile-name') get _tileNameAttr() { return this.name }\n\n  @Input() layout: TiledSelectLayout = 'grid'\n\n  @Input() name: string | undefined | null\n  @Input() label: string | undefined | null\n  @Input() icon: SeamIcon | undefined | null\n  @Input() @InputBoolean() disabled: boolean = false\n  @Input() @InputBoolean() selected: boolean = false\n\n  @Input() @InputBoolean() tileBackdrop: boolean = false\n  @Input() @InputBoolean() selectable: boolean = false\n  @Input() @InputBoolean() grayscaleOnDisable: boolean = true\n  @Input() @InputBoolean() showLabel: boolean = true\n  @Input() @InputBoolean() showSelectedIcon: boolean = true\n\n  @Input() iconClass: string | undefined | null\n\n  @Input() overlayTpl: TiledSelectTileOverlayDirective | undefined | null\n\n  @Output() activated = new EventEmitter<any>()\n\n  @ContentChild(TiledSelectTileLabelTplDirective, { static: true }) labelTpl?: TiledSelectTileLabelTplDirective\n\n  pulsing = false\n  pulsingTimeout: number | undefined\n\n  constructor(\n    private cdr: ChangeDetectorRef\n  ) { }\n\n  onTileClick(event: any) {\n    console.log('event', event)\n    if (!this.selectable) { return }\n    this.activated.emit(event)\n\n    // this.pulsing = true\n    // setTimeout(() => {\n    //   this.pulsing = false\n    // }, 750)\n  }\n\n  mDown() {\n    if (this.pulsingTimeout) {\n      clearTimeout(this.pulsingTimeout)\n    }\n\n    if (!this.pulsing) {\n      this.pulsing = true\n      // this.cdr.detectChanges()\n    }\n\n    // console.log('start')\n    this.pulsingTimeout = window.setTimeout(() => {\n      this.pulsing = false\n      // this.cdr.detectChanges()\n      this.pulsingTimeout = undefined\n    }, 750)\n  }\n\n}\n"]}
|
package/esm2015/tiled-select/components/tiled-select-tile-icon/tiled-select-tile-icon.component.js
CHANGED
|
@@ -31,7 +31,7 @@ TiledSelectTileIconComponent.decorators = [
|
|
|
31
31
|
{ type: Component, args: [{
|
|
32
32
|
selector: 'seam-tiled-select-tile-icon',
|
|
33
33
|
template: "<ng-container *ngIf=\"iconTpl; else noIconTpl\">\n <ng-template\n [ngTemplateOutlet]=\"iconTpl.template\"\n [ngTemplateOutletContext]=\"{ $implicit: icon, icon: icon }\">\n </ng-template>\n</ng-container>\n<ng-template #noIconTpl>\n\n <fa-icon *ngIf=\"_iconObj\"\n class=\"tiled-select-tile-icon--fa {{ iconClass }}\"\n [icon]=\"_iconObj\"></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=\"tiled-select-tile-panel--icon-img {{ iconClass }}\" style=\"display: block; visibility: hidden;\" alt=\"Icon\" [src]=\"_iconUrl\">\n </span>\n </ng-container>\n <ng-container *ngIf=\"!disabled\">\n <img class=\"tiled-select-tile-panel--icon-img {{ iconClass }}\" [src]=\"_iconUrl\" alt=\"Icon\">\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!needToFix\">\n <img class=\"tiled-select-tile-panel--icon-img {{ iconClass }}\" [src]=\"_iconUrl\" alt=\"Icon\">\n </ng-container>\n </ng-container>\n\n</ng-template>\n",
|
|
34
|
-
styles: [":host{display:block;-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden}:host.grid{flex:1 1 auto;margin:0 auto;display:flex;align-items:center;width:100%}:host.grid .tiled-select-tile-panel--icon-img{width:100%;max-width:75px;max-height:75px;margin:0 auto}:host.grid .tiled-select-tile-panel--icon-img[src$=\".svg\"]{height:100%}:host.grid>.grayscale-fix{max-width:75px;max-height:75px;margin:0 auto}:host.list{border:1px solid #e6e6e6;border-radius:8px;min-width:39px;width:39px;min-height:39px;height:39px;padding:1px;align-items:center;display:flex}:host.list img{max-width:100%;max-height:100%;margin:0 auto}.grey-fix{visibility:hidden;display:block}.tiled-select-tile-icon--fa{height:100%;display:flex;flex-direction:row;justify-content:center;text-align:center;width:100%;padding:2px}.tiled-select-tile-icon--fa ::ng-deep .svg-inline--fa{max-width:100%;height:100%;width:100%}"]
|
|
34
|
+
styles: [":host{display:block;-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden}:host.grid{flex:1 1 auto;margin:0 auto;display:flex;align-items:center;width:100%}:host.grid .tiled-select-tile-panel--icon-img{width:100%;max-width:75px;max-height:75px;margin:0 auto}:host.grid .tiled-select-tile-panel--icon-img[src$=\".svg\"]{height:100%}:host.grid>.grayscale-fix{max-width:75px;max-height:75px;margin:0 auto}:host.list{border:1px solid #e6e6e6;border-radius:8px;min-width:39px;width:39px;min-height:39px;height:39px;padding:1px;align-items:center;display:flex}:host.list img{max-width:100%;max-height:100%;margin:0 auto}.grey-fix{visibility:hidden;display:block}.tiled-select-tile-icon--fa{height:100%;display:flex;flex-direction:row;justify-content:center;text-align:center;width:100%;padding:2px}.tiled-select-tile-icon--fa ::ng-deep .svg-inline--fa{max-width:100%;height:100%;width:100%}\n"]
|
|
35
35
|
},] }
|
|
36
36
|
];
|
|
37
37
|
TiledSelectTileIconComponent.ctorParameters = () => [];
|
|
@@ -6,4 +6,5 @@ export * from './directives/tiled-select-tile-label-tpl.directive';
|
|
|
6
6
|
export * from './directives/tiled-select-tile-overlay.directive';
|
|
7
7
|
export * from './tiled-select.models';
|
|
8
8
|
export * from './tiled-select.module';
|
|
9
|
-
|
|
9
|
+
// export * from './testing'
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90aWxlZC1zZWxlY3QvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtEQUFrRCxDQUFBO0FBQ2hFLGNBQWMsNERBQTRELENBQUE7QUFDMUUsY0FBYyxzRUFBc0UsQ0FBQTtBQUNwRixjQUFjLG1EQUFtRCxDQUFBO0FBQ2pFLGNBQWMsb0RBQW9ELENBQUE7QUFDbEUsY0FBYyxrREFBa0QsQ0FBQTtBQUNoRSxjQUFjLHVCQUF1QixDQUFBO0FBQ3JDLGNBQWMsdUJBQXVCLENBQUE7QUFDckMsNEJBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL3RpbGVkLXNlbGVjdC90aWxlZC1zZWxlY3QuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL3RpbGVkLXNlbGVjdC10aWxlL3RpbGVkLXNlbGVjdC10aWxlLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy90aWxlZC1zZWxlY3QtdGlsZS1pY29uL3RpbGVkLXNlbGVjdC10aWxlLWljb24uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL3RpbGVkLXNlbGVjdC10aWxlLWljb24tdHBsLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy90aWxlZC1zZWxlY3QtdGlsZS1sYWJlbC10cGwuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL3RpbGVkLXNlbGVjdC10aWxlLW92ZXJsYXkuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi90aWxlZC1zZWxlY3QubW9kZWxzJ1xuZXhwb3J0ICogZnJvbSAnLi90aWxlZC1zZWxlY3QubW9kdWxlJ1xuLy8gZXhwb3J0ICogZnJvbSAnLi90ZXN0aW5nJ1xuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZWQtc2VsZWN0Lm1vZGVscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90aWxlZC1zZWxlY3QvdGlsZWQtc2VsZWN0Lm1vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2VhbUljb24gfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vaWNvbidcblxuZXhwb3J0IGludGVyZmFjZSBUaWxlZFNlbGVjdEl0ZW0ge1xuICBuYW1lPzogc3RyaW5nXG4gIHZhbHVlOiBzdHJpbmdcbiAgbGFiZWw6IHN0cmluZ1xuICBpY29uPzogU2VhbUljb25cbiAgZGlzYWJsZWQ/OiBib29sZWFuXG4gIGhpZGRlbj86IGJvb2xlYW5cbiAgY3VzdG9tQ2xhc3M/OiBzdHJpbmdcbn1cblxuZXhwb3J0IHR5cGUgVGlsZWRTZWxlY3RMYXlvdXQgPSAnZ3JpZCcgfCAnbGlzdCdcblxuLyoqIEBkZXByZWNhdGVkIFVzZSBgVGlsZWRTZWxlY3RJdGVtYC4gKi9cbmV4cG9ydCB0eXBlIElUaWxlZFNlbGVjdEl0ZW0gPSBUaWxlZFNlbGVjdEl0ZW1cbiJdfQ==
|
|
@@ -3,7 +3,7 @@ import { NgModule } from '@angular/core';
|
|
|
3
3
|
import { FontAwesomeModule } from '@fortawesome/angular-fontawesome';
|
|
4
4
|
import { TiledSelectTileIconComponent } from './components/tiled-select-tile-icon/tiled-select-tile-icon.component';
|
|
5
5
|
import { TiledSelectTileComponent } from './components/tiled-select-tile/tiled-select-tile.component';
|
|
6
|
-
import {
|
|
6
|
+
import { TheSeamTiledSelectComponent } from './components/tiled-select/tiled-select.component';
|
|
7
7
|
import { TiledSelectTileIconTplDirective } from './directives/tiled-select-tile-icon-tpl.directive';
|
|
8
8
|
import { TiledSelectTileLabelTplDirective } from './directives/tiled-select-tile-label-tpl.directive';
|
|
9
9
|
import { TiledSelectTileOverlayDirective } from './directives/tiled-select-tile-overlay.directive';
|
|
@@ -16,7 +16,7 @@ TheSeamTiledSelectModule.decorators = [
|
|
|
16
16
|
FontAwesomeModule
|
|
17
17
|
],
|
|
18
18
|
declarations: [
|
|
19
|
-
|
|
19
|
+
TheSeamTiledSelectComponent,
|
|
20
20
|
TiledSelectTileComponent,
|
|
21
21
|
TiledSelectTileOverlayDirective,
|
|
22
22
|
TiledSelectTileIconComponent,
|
|
@@ -24,7 +24,7 @@ TheSeamTiledSelectModule.decorators = [
|
|
|
24
24
|
TiledSelectTileLabelTplDirective
|
|
25
25
|
],
|
|
26
26
|
exports: [
|
|
27
|
-
|
|
27
|
+
TheSeamTiledSelectComponent,
|
|
28
28
|
TiledSelectTileComponent,
|
|
29
29
|
TiledSelectTileOverlayDirective,
|
|
30
30
|
TiledSelectTileIconTplDirective,
|
|
@@ -32,4 +32,4 @@ TheSeamTiledSelectModule.decorators = [
|
|
|
32
32
|
]
|
|
33
33
|
},] }
|
|
34
34
|
];
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZWQtc2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90aWxlZC1zZWxlY3QvdGlsZWQtc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUV4QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQTtBQUVwRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxzRUFBc0UsQ0FBQTtBQUNuSCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQTtBQUNyRyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrREFBa0QsQ0FBQTtBQUM5RixPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQTtBQUNuRyxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSxvREFBb0QsQ0FBQTtBQUNyRyxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxrREFBa0QsQ0FBQTtBQXVCbEcsTUFBTSxPQUFPLHdCQUF3Qjs7O1lBckJwQyxRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osaUJBQWlCO2lCQUNsQjtnQkFDRCxZQUFZLEVBQUU7b0JBQ1osMkJBQTJCO29CQUMzQix3QkFBd0I7b0JBQ3hCLCtCQUErQjtvQkFDL0IsNEJBQTRCO29CQUM1QiwrQkFBK0I7b0JBQy9CLGdDQUFnQztpQkFDakM7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLDJCQUEyQjtvQkFDM0Isd0JBQXdCO29CQUN4QiwrQkFBK0I7b0JBQy9CLCtCQUErQjtvQkFDL0IsZ0NBQWdDO2lCQUNqQzthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuXG5pbXBvcnQgeyBGb250QXdlc29tZU1vZHVsZSB9IGZyb20gJ0Bmb3J0YXdlc29tZS9hbmd1bGFyLWZvbnRhd2Vzb21lJ1xuXG5pbXBvcnQgeyBUaWxlZFNlbGVjdFRpbGVJY29uQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3RpbGVkLXNlbGVjdC10aWxlLWljb24vdGlsZWQtc2VsZWN0LXRpbGUtaWNvbi5jb21wb25lbnQnXG5pbXBvcnQgeyBUaWxlZFNlbGVjdFRpbGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdGlsZWQtc2VsZWN0LXRpbGUvdGlsZWQtc2VsZWN0LXRpbGUuY29tcG9uZW50J1xuaW1wb3J0IHsgVGhlU2VhbVRpbGVkU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3RpbGVkLXNlbGVjdC90aWxlZC1zZWxlY3QuY29tcG9uZW50J1xuaW1wb3J0IHsgVGlsZWRTZWxlY3RUaWxlSWNvblRwbERpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy90aWxlZC1zZWxlY3QtdGlsZS1pY29uLXRwbC5kaXJlY3RpdmUnXG5pbXBvcnQgeyBUaWxlZFNlbGVjdFRpbGVMYWJlbFRwbERpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy90aWxlZC1zZWxlY3QtdGlsZS1sYWJlbC10cGwuZGlyZWN0aXZlJ1xuaW1wb3J0IHsgVGlsZWRTZWxlY3RUaWxlT3ZlcmxheURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy90aWxlZC1zZWxlY3QtdGlsZS1vdmVybGF5LmRpcmVjdGl2ZSdcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb250QXdlc29tZU1vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBUaGVTZWFtVGlsZWRTZWxlY3RDb21wb25lbnQsXG4gICAgVGlsZWRTZWxlY3RUaWxlQ29tcG9uZW50LFxuICAgIFRpbGVkU2VsZWN0VGlsZU92ZXJsYXlEaXJlY3RpdmUsXG4gICAgVGlsZWRTZWxlY3RUaWxlSWNvbkNvbXBvbmVudCxcbiAgICBUaWxlZFNlbGVjdFRpbGVJY29uVHBsRGlyZWN0aXZlLFxuICAgIFRpbGVkU2VsZWN0VGlsZUxhYmVsVHBsRGlyZWN0aXZlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBUaGVTZWFtVGlsZWRTZWxlY3RDb21wb25lbnQsXG4gICAgVGlsZWRTZWxlY3RUaWxlQ29tcG9uZW50LFxuICAgIFRpbGVkU2VsZWN0VGlsZU92ZXJsYXlEaXJlY3RpdmUsXG4gICAgVGlsZWRTZWxlY3RUaWxlSWNvblRwbERpcmVjdGl2ZSxcbiAgICBUaWxlZFNlbGVjdFRpbGVMYWJlbFRwbERpcmVjdGl2ZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFRoZVNlYW1UaWxlZFNlbGVjdE1vZHVsZSB7IH1cbiJdfQ==
|
package/esm2015/toggle-edit/toggle-edit-actions-container/toggle-edit-actions-container.component.js
CHANGED
|
@@ -8,7 +8,7 @@ ToggleEditActionsContainerComponent.decorators = [
|
|
|
8
8
|
{ type: Component, args: [{
|
|
9
9
|
selector: 'seam-toggle-edit-actions-container',
|
|
10
10
|
template: "<ng-content></ng-content>\n",
|
|
11
|
-
styles: [":host{display:block}"]
|
|
11
|
+
styles: [":host{display:block}\n"]
|
|
12
12
|
},] }
|
|
13
13
|
];
|
|
14
14
|
ToggleEditActionsContainerComponent.ctorParameters = () => [];
|
|
@@ -368,7 +368,7 @@ ToggleEditComponent.decorators = [
|
|
|
368
368
|
{ type: Component, args: [{
|
|
369
369
|
selector: 'seam-toggle-edit',
|
|
370
370
|
template: "<div class=\"toggle-edit-not-editing rounded\"\n [class.w-100]=\"editing\"\n [class.toggle-edit-editing]=\"editing\"\n [class.is-disabled]=\"disabled\"\n (seamElemResized)=\"resized()\">\n <div class=\"toggle-edit-content-container\">\n <div class=\"toggle-edit-content\" (click)=\"toggleEditing(true)\">\n <ng-container *ngIf=\"editing; else notEditingTpl\">\n <ng-content></ng-content>\n </ng-container>\n <ng-template #notEditingTpl>\n <ng-container *ngIf=\"displayTpl; else noDisplayTpl\">\n <ng-template [ngTemplateOutlet]=\"displayTpl.template\" [ngTemplateOutletContext]=\"{ $implicit: getValue() || placeholder }\"></ng-template>\n </ng-container>\n <ng-template #noDisplayTpl>\n <div class=\"pl-1 pr-1\">\n {{ getValue() || placeholder }}\n </div>\n </ng-template>\n </ng-template>\n </div>\n <div>\n <ng-template *ngIf=\"!editing\" [cdkPortalOutlet]=\"templatePortal\"></ng-template>\n <ng-template #templatePortalContent>\n <seam-toggle-edit-actions-container\n [class.bg-light]=\"editing\"\n tabindex=\"-1\"\n cdkMonitorSubtreeFocus\n (cdkFocusChange)=\"actionsFocusChange($event)\">\n <button *ngIf=\"!editing\"\n type=\"button\"\n class=\"toggle-edit-edit-btn btn text-secondary bg-transparent p-1 border-0\"\n (click)=\"toggleEditing(true)\">\n <fa-icon [icon]=\"faPen\"></fa-icon>\n </button>\n <button *ngIf=\"editing\"\n type=\"button\"\n [disabled]=\"!canSubmit()\"\n class=\"toggle-edit-submit-btn btn text-secondary bg-transparent p-1 border-0\"\n (click)=\"submitEdit()\">\n <fa-icon [icon]=\"faCheck\"></fa-icon>\n </button>\n <button *ngIf=\"editing\"\n type=\"button\"\n class=\"toggle-edit-cancel-btn btn text-secondary bg-transparent p-1 border-0\"\n (click)=\"cancelEdit()\">\n <fa-icon [icon]=\"faTimes\"></fa-icon>\n </button>\n </seam-toggle-edit-actions-container>\n </ng-template>\n </div>\n </div>\n</div>\n\n<seam-loading *ngIf=\"isSubmitting()\"></seam-loading>\n",
|
|
371
|
-
styles: [":host{display:block;position:relative}.toggle-edit-not-editing{transition
|
|
371
|
+
styles: [":host{display:block;position:relative}.toggle-edit-not-editing{transition:.25s ease-in-out background-color}.toggle-edit-not-editing .toggle-edit-content-container{display:flex;flex-direction:row}.toggle-edit-not-editing .toggle-edit-content-container .toggle-edit-content{flex:1 1 auto;display:flex;align-items:center}.toggle-edit-not-editing:not(.is-disabled):hover,.toggle-edit-not-editing:not(.is-disabled).toggle-edit-editing{background-color:#f8f9fa}.toggle-edit-not-editing:not(.is-disabled):hover .toggle-edit-edit-btn,.toggle-edit-not-editing:not(.is-disabled).toggle-edit-editing .toggle-edit-edit-btn{opacity:1;visibility:visible}.toggle-edit-not-editing .toggle-edit-edit-btn{opacity:0;visibility:hidden}.toggle-edit-not-editing .toggle-edit-edit-btn,.toggle-edit-not-editing .toggle-edit-submit-btn,.toggle-edit-not-editing .toggle-edit-cancel-btn{transition:.25s ease-in-out}.toggle-edit-not-editing .toggle-edit-edit-btn{border-top-left-radius:0;border-bottom-left-radius:0}.toggle-edit-not-editing .toggle-edit-submit-btn{border-radius:0}.toggle-edit-not-editing .toggle-edit-cancel-btn{border-top-left-radius:0;border-bottom-left-radius:0}\n"]
|
|
372
372
|
},] }
|
|
373
373
|
];
|
|
374
374
|
ToggleEditComponent.ctorParameters = () => [
|