@heartlandone/vega 2.73.0 → 2.74.0-RTE-table-preview
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/dist/cjs/align-left-4a76df69.js +22 -0
- package/dist/cjs/{app-globals-cc162173.js → app-globals-be2e868e.js} +18 -17
- package/dist/cjs/{code-block-823cd481.js → code-block-22ee2550.js} +35 -4
- package/dist/cjs/{component-value-history-controller-slimmer.abstract-e2e0c6f3.js → component-value-history-controller-slimmer.abstract-3486cbc0.js} +26 -5
- package/dist/cjs/{dto-renderer-manager-bd2bd447.js → content-state-0be6fda3.js} +33 -60
- package/dist/cjs/{design-token-11656685.js → design-token-505997df.js} +1 -1
- package/dist/cjs/dto-renderer-manager-ae5fcbba.js +58 -0
- package/dist/cjs/{element-appender-slimmer-12f40b8b.js → element-appender-slimmer-26420c09.js} +6 -6
- package/dist/cjs/{form-field-controller-slimmer-6e3e14fd.js → form-field-controller-slimmer-56c551ea.js} +2 -2
- package/dist/cjs/{image-annotation-action-7408a4b3.js → image-annotation-action-462fd073.js} +3 -3
- package/dist/cjs/index-58ea899e.js +4 -0
- package/dist/cjs/{index-638a0f0d.js → index-fc538f17.js} +1 -1
- package/dist/cjs/index.cjs.js +43 -38
- package/dist/cjs/{language-extension-716015a5.js → language-extension-414149c2.js} +8 -8
- package/dist/cjs/loader.cjs.js +13 -8
- package/dist/cjs/{public-rules-2950f1fc.js → public-rules-2d18cf41.js} +4 -4
- package/dist/cjs/{range-c3c48132.js → range-439a0c0c.js} +1 -1
- package/dist/cjs/{responsive-format-facade-96c5f598.js → responsive-format-facade-0ececeb3.js} +3 -3
- package/dist/cjs/{rich-text-editor-required-rule-4aab05a3.js → rich-text-editor-required-rule-5a4f3626.js} +2 -2
- package/dist/cjs/{string-input-formatter-slimmer-338bbd73.js → string-input-formatter-slimmer-a8f4a9b1.js} +2 -2
- package/dist/cjs/{style-formatter-9c42d41b.js → style-formatter-142500c0.js} +1 -1
- package/dist/cjs/styles.constants-3aff0b56.js +1306 -0
- package/dist/cjs/{sub-state-notify-slimmer-1efa69c4.js → sub-state-notify-slimmer-011866d9.js} +1 -1
- package/dist/cjs/{sub-state-observer-slimmer-6afa62f5.js → sub-state-observer-slimmer-23d43f1e.js} +1 -1
- package/dist/cjs/table-extension-2a20da57.js +6018 -0
- package/dist/cjs/vega-accordion.cjs.entry.js +10 -6
- package/dist/cjs/vega-app-header-button.cjs.entry.js +10 -6
- package/dist/cjs/vega-box.cjs.entry.js +11 -7
- package/dist/cjs/vega-button-circle.cjs.entry.js +10 -6
- package/dist/cjs/vega-button-group_2.cjs.entry.js +3 -3
- package/dist/cjs/vega-button.cjs.entry.js +9 -5
- package/dist/cjs/vega-calendar_4.cjs.entry.js +3 -3
- package/dist/cjs/vega-card.cjs.entry.js +10 -6
- package/dist/cjs/vega-carousel.cjs.entry.js +9 -5
- package/dist/cjs/vega-checkbox_2.cjs.entry.js +3 -3
- package/dist/cjs/vega-chip.cjs.entry.js +10 -6
- package/dist/cjs/vega-code-block.cjs.entry.js +4 -4
- package/dist/cjs/vega-color-picker.cjs.entry.js +3 -3
- package/dist/cjs/vega-combo-box.cjs.entry.js +3 -3
- package/dist/cjs/vega-date-picker_2.cjs.entry.js +15 -11
- package/dist/cjs/vega-dialog_2.cjs.entry.js +17 -13
- package/dist/cjs/vega-divider.cjs.entry.js +10 -6
- package/dist/cjs/vega-dropdown_5.cjs.entry.js +24 -11
- package/dist/cjs/vega-env-manager-23b8b23c.js +2 -2
- package/dist/cjs/vega-file-uploader.cjs.entry.js +3 -3
- package/dist/cjs/vega-flag-icon.cjs.entry.js +10 -6
- package/dist/cjs/vega-flex.cjs.entry.js +11 -7
- package/dist/cjs/vega-font.cjs.entry.js +10 -6
- package/dist/cjs/vega-form.cjs.entry.js +4 -4
- package/dist/cjs/vega-grid.cjs.entry.js +10 -6
- package/dist/cjs/vega-icon.cjs.entry.js +10 -6
- package/dist/cjs/vega-image-uploader.cjs.entry.js +12 -8
- package/dist/cjs/vega-input-credit-card.cjs.entry.js +3 -3
- package/dist/cjs/vega-input-numeric.cjs.entry.js +4 -4
- package/dist/cjs/vega-input-passcode.cjs.entry.js +3 -3
- package/dist/cjs/vega-input-phone-number.cjs.entry.js +10 -6
- package/dist/cjs/vega-input-range.cjs.entry.js +3 -3
- package/dist/cjs/vega-input-select.cjs.entry.js +181 -50
- package/dist/cjs/vega-input.cjs.entry.js +5 -5
- package/dist/cjs/{vega-internal-event-id-f2465f1b.js → vega-internal-event-id-73334b4b.js} +4 -0
- package/dist/cjs/vega-left-nav_5.cjs.entry.js +17 -13
- package/dist/cjs/vega-loader-wrapper_2.cjs.entry.js +11 -7
- package/dist/cjs/vega-pagination-page-selector-mobile.cjs.entry.js +1 -1
- package/dist/cjs/vega-pagination-page-size-selector-mobile.cjs.entry.js +1 -1
- package/dist/cjs/vega-pagination.cjs.entry.js +9 -5
- package/dist/cjs/vega-popover_2.cjs.entry.js +11 -7
- package/dist/cjs/vega-progress-tracker_2.cjs.entry.js +11 -7
- package/dist/cjs/vega-radio_2.cjs.entry.js +3 -3
- package/dist/cjs/vega-rich-text-content.cjs.entry.js +10 -9
- package/dist/cjs/vega-rich-text-editor_4.cjs.entry.js +70 -54
- package/dist/cjs/vega-rich-text-table-properties_3.cjs.entry.js +1313 -0
- package/dist/cjs/vega-selection-chip_2.cjs.entry.js +12 -8
- package/dist/cjs/vega-selection-tile_2.cjs.entry.js +4 -4
- package/dist/cjs/vega-sidenav_3.cjs.entry.js +15 -11
- package/dist/cjs/vega-signature-capture.cjs.entry.js +12 -8
- package/dist/cjs/vega-stepper.cjs.entry.js +3 -3
- package/dist/cjs/vega-table_11.cjs.entry.js +16 -13
- package/dist/cjs/vega-textarea.cjs.entry.js +3 -3
- package/dist/cjs/vega-time-picker_2.cjs.entry.js +12 -8
- package/dist/cjs/vega-toggle-switch.cjs.entry.js +3 -3
- package/dist/cjs/vega-tooltip_2.cjs.entry.js +10 -6
- package/dist/cjs/vega.cjs.js +13 -8
- package/dist/collection/collection-manifest.json +10 -0
- package/dist/collection/components/vega-dropdown/slimmers/renderers/vega-dropdown-list-renderer.js +6 -3
- package/dist/collection/components/vega-dropdown/vega-dropdown.js +31 -0
- package/dist/collection/components/vega-input-select/slimmers/controllers/vega-input-select-item-controller.js +89 -0
- package/dist/collection/components/vega-input-select/slimmers/controllers/vega-input-select-source-controller.js +4 -0
- package/dist/collection/components/vega-input-select/slimmers/controllers/vega-input-select-value-controller.js +4 -0
- package/dist/collection/components/vega-input-select/slimmers/renderers/vega-input-select-dropdown-renderer.js +33 -13
- package/dist/collection/components/vega-input-select/vega-input-select.js +27 -7
- package/dist/collection/components/vega-popover/slimmers/controllers/vega-popover-appender-controller.js +1 -0
- package/dist/collection/components/vega-rich-text-editor/dto/action-handle-strategies/action-handle-strategy.abstract.js +10 -0
- package/dist/collection/components/vega-rich-text-editor/dto/annotations/plain-text-annotation.js +1 -1
- package/dist/collection/components/vega-rich-text-editor/dto/blocks/block.abstract.js +24 -2
- package/dist/collection/components/vega-rich-text-editor/dto/content-state.js +18 -2
- package/dist/collection/components/vega-rich-text-editor/extensions/base-extension-renderer.js +2 -1
- package/dist/collection/components/vega-rich-text-editor/extensions/extension.abstract.js +18 -1
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-interceptors/prevent-cell-children-remove-interceptor.js +42 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-interceptors/prevent-cell-content-delete-interceptor.js +26 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-interceptors/prevent-row-insert-interceptor.js +23 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/delete-table-block-strategy.js +25 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/delete-table-column-strategy.js +57 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/delete-table-row-strategy.js +57 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/insert-table-block-strategy.js +54 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/insert-table-column-strategy.js +42 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/insert-table-row-strategy.js +117 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/select-table-column-strategy.js +22 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/table-column-strategy.abstract.js +19 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/toggle-header-row-strategy.js +133 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/toggle-header-table-column-strategy.js +99 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/update-table-cell-properties-strategy.js +23 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/action-handler-strategies/update-table-properties-strategy.js +29 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/delete-table-block-action.js +13 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/delete-table-column-action.js +13 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/delete-table-row-action.js +18 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/insert-table-block-action.js +13 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/insert-table-column-action.js +19 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/insert-table-row-action.js +26 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/select-table-column-action.js +13 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/table-annotations-action.js +18 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/table-caption-action.js +13 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/table-cell-annotations-action.js +18 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/table-head-cell-annotations-action.js +18 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/toggle-header-row-action.js +13 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/toggle-header-table-column-action.js +15 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/actions/update-table-properties-action.js +38 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/annotation-handler/table-annotation-handler-base.js +97 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/annotation-handler/table-annotation-handler.js +69 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/annotation-handler/table-cell-annotation-handler.js +82 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/annotation-handler/table-head-cell-annotation-handler.js +14 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/annotations/table-annotation.js +91 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/annotations/table-caption-annotation.js +57 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/annotations/table-cell-annotation.js +121 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/annotations/table-head-cell-annotation.js +40 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/constants/styles.constants.js +21 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/dto/table-block.js +119 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/dto/table-body-block.js +56 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/dto/table-caption-block.js +69 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/dto/table-cell-block.js +66 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/dto/table-head-block.js +60 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/dto/table-head-cell-block.js +53 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/dto/table-row-block.js +60 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/caption-to-caption-block-strategy.js +50 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/table-to-table-block-strategy.js +42 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/tbody-to-table-body-block-strategy.js +42 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/td-to-table-cell-block-strategy.js +71 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/thead-to-table-head-block-strategy.js +42 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/tr-to-table-row-block-strategy.js +42 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/renderers/table-body-renderer.js +15 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/renderers/table-caption-renderer.js +22 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/renderers/table-cell-renderer.js +74 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/renderers/table-dynamic-popover-renderer.js +254 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/renderers/table-head-cell-renderer.js +12 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/renderers/table-head-renderer.js +15 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/renderers/table-renderer.js +149 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/renderers/table-row-renderer.js +15 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/renderers/table-setting-popover-renderer.js +148 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/caption-operation.js +78 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/cell-properties-cancel-event-handler.js +17 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/cell-properties-change-event-handler.js +15 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/cell-properties-save-event-handler.js +19 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/cell-properties.js +131 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/column-operation.js +109 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/row-operation.js +132 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/setting-event-handler.abstract.js +44 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/table-properties-cancel-event-handler.js +19 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/table-properties-change-event-handler.js +20 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/table-properties-save-event-handler.js +20 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/setting-event-handlers/table-properties.js +50 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/table-extension.js +152 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/table-icon.js +3 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/table-selection.js +371 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/table-toolbar-button-renderer.js +234 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/utils/utils.js +102 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/align-bottom.js +3 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/align-middle.js +3 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/align-top.js +3 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/objects-align-center-horizontal.js +3 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/objects-align-left.js +3 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/objects-align-right.js +3 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/slimmers/controllers/vega-rich-text-table-properties-color-controller.js +27 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/slimmers/renderers/vega-rich-text-cell-properties-form-field-renderer.js +106 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/slimmers/renderers/vega-rich-text-table-properties-basic-form-field-renderer.abstract.js +259 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/slimmers/renderers/vega-rich-text-table-properties-form-field-renderer.js +58 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/slimmers/renderers/vega-rich-text-table-properties-form-renderer.js +93 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/vega-rich-text-table-properties.css +148 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/vega-rich-text-table-properties.js +241 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-selection-widget/slimmers/controllers/selection-widget-keyboard-controller.js +36 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-selection-widget/slimmers/renderers/selection-widget-renderer.js +83 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-selection-widget/vega-rich-text-table-selection-widget.css +41 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-selection-widget/vega-rich-text-table-selection-widget.js +80 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/assets/icon.js +20 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/caption-button-slimmer.js +27 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/cell-properties-button-slimmer.js +26 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/column-button-slimmer.js +86 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/row-button-slimmer.js +101 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/table-properties-button-slimmer.js +26 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/table-setting-button-slimmer.abstract.js +75 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/vega-rich-text-table-setting-renderer.js +50 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/vega-rich-text-table-setting.css +20 -0
- package/dist/collection/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/vega-rich-text-table-setting.js +215 -0
- package/dist/collection/components/vega-rich-text-editor/public-api.js +1 -0
- package/dist/collection/components/vega-rich-text-editor/slimmers/controllers/extension-controller.js +21 -1
- package/dist/collection/components/vega-rich-text-editor/slimmers/controllers/helper/element-to-dto-strategy/annotation-handler/html-element-to-annotation-generator.js +10 -0
- package/dist/collection/components/vega-rich-text-editor/slimmers/controllers/selection-controller.js +23 -2
- package/dist/collection/components/vega-rich-text-editor/slimmers/controllers/value-controller.js +6 -2
- package/dist/collection/components/vega-rich-text-editor/slimmers/renderers/tools/source-edit-toolbar-button-slimmer.js +6 -0
- package/dist/collection/components/vega-rich-text-editor/test/dto/content-state.test.js +257 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/annotation-handler/annotation-handler-registration.test.js +164 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/annotation-handler/table-annotation-handler.test.js +293 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/annotation-handler/table-cell-annotation-handler.test.js +295 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/annotation-handler/table-head-cell-annotation-handler.test.js +415 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/caption-operation.test.js +99 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/table-annotation.test.js +89 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/table-caption-annotations.test.js +79 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/table-cell-annotation.test.js +128 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/table-dto.test.js +517 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/table-element-to-dto-strategies.test.js +1450 -0
- package/dist/collection/components/vega-rich-text-editor/test/extensions/table/table-test-utils.js +172 -0
- package/dist/collection/components/vega-rich-text-editor/test/spec-utils.js +5 -2
- package/dist/collection/components/vega-rich-text-editor/vega-rich-text-editor.css +4 -0
- package/dist/collection/global/scripts/before-vega-load.js +2 -0
- package/dist/collection/helpers/event-manager/event-id/vega-internal-event-id.js +2 -0
- package/dist/collection/utils/spec-utils.js +4 -3
- package/dist/esm/align-left-7f959adf.js +17 -0
- package/dist/esm/{app-globals-949d2e18.js → app-globals-8b873b6f.js} +7 -6
- package/dist/esm/{child-nodes-event-prevent-slimmer-e6f98de5.js → child-nodes-event-prevent-slimmer-a6afdb1e.js} +1 -1
- package/dist/esm/{code-block-666674d7.js → code-block-76b29be1.js} +37 -6
- package/dist/esm/{component-value-history-controller-slimmer.abstract-171dda08.js → component-value-history-controller-slimmer.abstract-e1b0e163.js} +27 -6
- package/dist/esm/{dto-renderer-manager-49ae5d56.js → content-state-03f1d302.js} +32 -61
- package/dist/esm/{design-token-9b510e59.js → design-token-8fedb532.js} +1 -1
- package/dist/esm/{dom-node-subject-observer-factory-1aaa1159.js → dom-node-subject-observer-factory-e998eba4.js} +1 -1
- package/dist/esm/dto-renderer-manager-12bc9121.js +56 -0
- package/dist/esm/{element-appender-slimmer-b9890dcb.js → element-appender-slimmer-7b9326e2.js} +4 -4
- package/dist/esm/{event-emit-slimmer-2d791d0e.js → event-emit-slimmer-bbf6668c.js} +2 -2
- package/dist/esm/{form-field-controller-slimmer-257928c1.js → form-field-controller-slimmer-a0cff4d3.js} +3 -3
- package/dist/esm/{image-annotation-action-b3eea6a2.js → image-annotation-action-47cdc068.js} +3 -3
- package/dist/esm/index-090d31ca.js +4 -0
- package/dist/esm/{index-0d487fae.js → index-da7e5fe5.js} +2 -2
- package/dist/esm/index.js +17 -13
- package/dist/esm/{internal-vega-event-manager-fdee2a0a.js → internal-vega-event-manager-e799c54a.js} +1 -1
- package/dist/esm/{language-extension-b3f836d4.js → language-extension-de6e6caf.js} +2 -2
- package/dist/esm/loader.js +15 -10
- package/dist/esm/polyfills/core-js.js +0 -0
- package/dist/esm/polyfills/dom.js +0 -0
- package/dist/esm/polyfills/es5-html-element.js +0 -0
- package/dist/esm/polyfills/index.js +0 -0
- package/dist/esm/polyfills/system.js +0 -0
- package/dist/esm/{public-rules-b164e40e.js → public-rules-c48cc5c9.js} +5 -5
- package/dist/esm/{range-9cc1422b.js → range-af6150a8.js} +1 -1
- package/dist/esm/{responsive-format-facade-94897ae8.js → responsive-format-facade-16da4623.js} +3 -3
- package/dist/esm/{rich-text-editor-required-rule-2131f21c.js → rich-text-editor-required-rule-7255832e.js} +1 -1
- package/dist/esm/{string-input-formatter-slimmer-3a42d9b8.js → string-input-formatter-slimmer-82f85b0b.js} +3 -3
- package/dist/esm/{style-formatter-bb5aec96.js → style-formatter-6ca58f6b.js} +1 -1
- package/dist/esm/styles.constants-0dd6f7fa.js +1277 -0
- package/dist/esm/{sub-state-notify-slimmer-71b9bbd5.js → sub-state-notify-slimmer-4060c333.js} +2 -2
- package/dist/esm/{sub-state-observer-slimmer-41a1b380.js → sub-state-observer-slimmer-bfa5e63e.js} +2 -2
- package/dist/esm/table-extension-c83b7a56.js +5998 -0
- package/dist/esm/vega-accordion.entry.js +13 -9
- package/dist/esm/vega-app-header-button.entry.js +14 -10
- package/dist/esm/vega-banner.entry.js +3 -3
- package/dist/esm/vega-box.entry.js +13 -9
- package/dist/esm/vega-breadcrumb.entry.js +4 -4
- package/dist/esm/vega-button-circle.entry.js +14 -10
- package/dist/esm/vega-button-group_2.entry.js +7 -7
- package/dist/esm/vega-button-link.entry.js +4 -4
- package/dist/esm/vega-button.entry.js +13 -9
- package/dist/esm/vega-calendar_4.entry.js +7 -7
- package/dist/esm/vega-card.entry.js +12 -8
- package/dist/esm/vega-carousel.entry.js +12 -8
- package/dist/esm/vega-checkbox_2.entry.js +7 -7
- package/dist/esm/vega-chip.entry.js +14 -10
- package/dist/esm/vega-code-block.entry.js +8 -8
- package/dist/esm/vega-color-picker.entry.js +6 -6
- package/dist/esm/vega-combo-box.entry.js +7 -7
- package/dist/esm/vega-date-picker_2.entry.js +19 -15
- package/dist/esm/vega-dialog_2.entry.js +14 -10
- package/dist/esm/vega-divider.entry.js +12 -8
- package/dist/esm/vega-dropdown_5.entry.js +28 -15
- package/dist/esm/vega-env-manager-8f8dc473.js +2 -2
- package/dist/esm/vega-field-label.entry.js +3 -3
- package/dist/esm/vega-file-uploader.entry.js +6 -6
- package/dist/esm/vega-flag-icon.entry.js +12 -8
- package/dist/esm/vega-flex.entry.js +13 -9
- package/dist/esm/vega-font.entry.js +12 -8
- package/dist/esm/vega-form.entry.js +8 -8
- package/dist/esm/vega-grid.entry.js +12 -8
- package/dist/esm/vega-icon.entry.js +12 -8
- package/dist/esm/vega-image-uploader.entry.js +15 -11
- package/dist/esm/vega-input-credit-card.entry.js +7 -7
- package/dist/esm/vega-input-numeric.entry.js +8 -8
- package/dist/esm/vega-input-passcode.entry.js +7 -7
- package/dist/esm/vega-input-phone-number.entry.js +14 -10
- package/dist/esm/vega-input-range.entry.js +7 -7
- package/dist/esm/vega-input-select.entry.js +185 -54
- package/dist/esm/vega-input.entry.js +8 -8
- package/dist/esm/{vega-internal-event-id-4a06d705.js → vega-internal-event-id-3edc9b4e.js} +3 -1
- package/dist/esm/vega-item-toggle.entry.js +3 -3
- package/dist/esm/vega-left-nav_5.entry.js +16 -12
- package/dist/esm/vega-loader-wrapper_2.entry.js +11 -7
- package/dist/esm/vega-page-notification_2.entry.js +1 -1
- package/dist/esm/vega-pagination-page-selector-mobile.entry.js +4 -4
- package/dist/esm/vega-pagination-page-size-selector-mobile.entry.js +2 -2
- package/dist/esm/vega-pagination.entry.js +13 -9
- package/dist/esm/vega-popover_2.entry.js +14 -10
- package/dist/esm/vega-progress-tracker_2.entry.js +14 -10
- package/dist/esm/vega-radio_2.entry.js +7 -7
- package/dist/esm/vega-rich-text-content.entry.js +8 -7
- package/dist/esm/vega-rich-text-editor_4.entry.js +53 -37
- package/dist/esm/vega-rich-text-table-properties_3.entry.js +1307 -0
- package/dist/esm/vega-segment-control.entry.js +3 -3
- package/dist/esm/vega-selection-chip_2.entry.js +16 -12
- package/dist/esm/vega-selection-tile_2.entry.js +8 -8
- package/dist/esm/vega-sidenav_3.entry.js +14 -10
- package/dist/esm/vega-signature-capture.entry.js +15 -11
- package/dist/esm/vega-stepper.entry.js +7 -7
- package/dist/esm/vega-tab-group_2.entry.js +4 -4
- package/dist/esm/vega-table_11.entry.js +14 -11
- package/dist/esm/vega-textarea.entry.js +7 -7
- package/dist/esm/vega-time-picker_2.entry.js +16 -12
- package/dist/esm/vega-toggle-switch.entry.js +6 -6
- package/dist/esm/vega-tooltip_2.entry.js +12 -8
- package/dist/esm/vega.js +15 -10
- package/dist/sri/vega-sri-manifest.json +696 -296
- package/dist/types/components/vega-dropdown/slimmers/renderers/vega-dropdown-list-renderer.d.ts +1 -0
- package/dist/types/components/vega-dropdown/vega-dropdown.d.ts +8 -1
- package/dist/types/components/vega-input-select/slimmers/controllers/vega-input-select-item-controller.d.ts +29 -0
- package/dist/types/components/vega-input-select/slimmers/controllers/vega-input-select-source-controller.d.ts +1 -0
- package/dist/types/components/vega-input-select/slimmers/controllers/vega-input-select-value-controller.d.ts +1 -0
- package/dist/types/components/vega-input-select/slimmers/renderers/vega-input-select-dropdown-renderer.d.ts +1 -1
- package/dist/types/components/vega-input-select/types.d.ts +5 -0
- package/dist/types/components/vega-input-select/vega-input-select.d.ts +12 -4
- package/dist/types/components/vega-popover/slimmers/controllers/vega-popover-appender-controller.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/dto/action-handle-strategies/action-handle-strategy.abstract.d.ts +7 -0
- package/dist/types/components/vega-rich-text-editor/dto/annotations/annotation.abstract.d.ts +2 -5
- package/dist/types/components/vega-rich-text-editor/dto/annotations/block-annotation.abstract.d.ts +3 -3
- package/dist/types/components/vega-rich-text-editor/dto/blocks/block.abstract.d.ts +10 -6
- package/dist/types/components/vega-rich-text-editor/dto/content-state.d.ts +8 -1
- package/dist/types/components/vega-rich-text-editor/extensions/extension.abstract.d.ts +15 -2
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-interceptors/prevent-cell-children-remove-interceptor.d.ts +25 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-interceptors/prevent-cell-content-delete-interceptor.d.ts +20 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-interceptors/prevent-row-insert-interceptor.d.ts +19 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/delete-table-block-strategy.d.ts +14 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/delete-table-column-strategy.d.ts +31 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/delete-table-row-strategy.d.ts +28 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/insert-table-block-strategy.d.ts +27 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/insert-table-column-strategy.d.ts +19 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/insert-table-row-strategy.d.ts +27 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/select-table-column-strategy.d.ts +12 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/table-column-strategy.abstract.d.ts +20 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/toggle-header-row-strategy.d.ts +41 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/toggle-header-table-column-strategy.d.ts +45 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/update-table-cell-properties-strategy.d.ts +13 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/action-handler-strategies/update-table-properties-strategy.d.ts +12 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/delete-table-block-action.d.ts +12 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/delete-table-column-action.d.ts +15 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/delete-table-row-action.d.ts +17 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/insert-table-block-action.d.ts +20 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/insert-table-column-action.d.ts +23 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/insert-table-row-action.d.ts +23 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/select-table-column-action.d.ts +18 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/table-annotations-action.d.ts +16 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/table-caption-action.d.ts +14 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/table-cell-annotations-action.d.ts +14 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/table-head-cell-annotations-action.d.ts +15 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/toggle-header-row-action.d.ts +12 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/toggle-header-table-column-action.d.ts +16 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/actions/update-table-properties-action.d.ts +18 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/annotation-handler/table-annotation-handler-base.d.ts +43 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/annotation-handler/table-annotation-handler.d.ts +26 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/annotation-handler/table-cell-annotation-handler.d.ts +42 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/annotation-handler/table-head-cell-annotation-handler.d.ts +13 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/annotations/table-annotation.d.ts +64 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/annotations/table-caption-annotation.d.ts +26 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/annotations/table-cell-annotation.d.ts +67 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/annotations/table-head-cell-annotation.d.ts +22 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/constants/styles.constants.d.ts +3 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/dto/table-block.d.ts +79 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/dto/table-body-block.d.ts +42 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/dto/table-caption-block.d.ts +41 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/dto/table-cell-block.d.ts +45 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/dto/table-head-block.d.ts +42 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/dto/table-head-cell-block.d.ts +34 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/dto/table-row-block.d.ts +44 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/caption-to-caption-block-strategy.d.ts +29 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/table-to-table-block-strategy.d.ts +26 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/tbody-to-table-body-block-strategy.d.ts +26 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/td-to-table-cell-block-strategy.d.ts +27 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/thead-to-table-head-block-strategy.d.ts +26 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/element-to-dto-strategies/tr-to-table-row-block-strategy.d.ts +26 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/renderers/table-body-renderer.d.ts +12 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/renderers/table-caption-renderer.d.ts +13 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/renderers/table-cell-renderer.d.ts +37 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/renderers/table-dynamic-popover-renderer.d.ts +88 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/renderers/table-head-cell-renderer.d.ts +12 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/renderers/table-head-renderer.d.ts +12 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/renderers/table-renderer.d.ts +61 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/renderers/table-row-renderer.d.ts +12 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/renderers/table-setting-popover-renderer.d.ts +66 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/caption-operation.d.ts +36 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/cell-properties-cancel-event-handler.d.ts +17 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/cell-properties-change-event-handler.d.ts +15 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/cell-properties-save-event-handler.d.ts +17 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/cell-properties.d.ts +62 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/column-operation.d.ts +55 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/row-operation.d.ts +61 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/setting-event-handler.abstract.d.ts +47 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/table-properties-cancel-event-handler.d.ts +19 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/table-properties-change-event-handler.d.ts +17 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/table-properties-save-event-handler.d.ts +17 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/setting-event-handlers/table-properties.d.ts +33 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/table-extension.d.ts +36 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/table-icon.d.ts +3 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/table-selection.d.ts +149 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/table-toolbar-button-renderer.d.ts +86 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/utils/utils.d.ts +53 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/align-bottom.d.ts +3 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/align-middle.d.ts +3 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/align-top.d.ts +3 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/objects-align-center-horizontal.d.ts +3 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/objects-align-left.d.ts +3 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/assets/objects-align-right.d.ts +3 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/slimmers/controllers/vega-rich-text-table-properties-color-controller.d.ts +14 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/slimmers/renderers/vega-rich-text-cell-properties-form-field-renderer.d.ts +49 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/slimmers/renderers/vega-rich-text-table-properties-basic-form-field-renderer.abstract.d.ts +99 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/slimmers/renderers/vega-rich-text-table-properties-form-field-renderer.d.ts +27 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/slimmers/renderers/vega-rich-text-table-properties-form-renderer.d.ts +33 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-properties/vega-rich-text-table-properties.d.ts +57 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-selection-widget/slimmers/controllers/selection-widget-keyboard-controller.d.ts +15 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-selection-widget/slimmers/renderers/selection-widget-renderer.d.ts +31 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-selection-widget/vega-rich-text-table-selection-widget.d.ts +27 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/assets/icon.d.ts +2 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/caption-button-slimmer.d.ts +11 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/cell-properties-button-slimmer.d.ts +11 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/column-button-slimmer.d.ts +28 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/row-button-slimmer.d.ts +36 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/table-properties-button-slimmer.d.ts +11 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/table-setting-button-slimmer.abstract.d.ts +36 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/slimmers/renderers/vega-rich-text-table-setting-renderer.d.ts +11 -0
- package/dist/types/components/vega-rich-text-editor/extensions/table/vega-rich-text-table-setting/vega-rich-text-table-setting.d.ts +55 -0
- package/dist/types/components/vega-rich-text-editor/interface.d.ts +39 -2
- package/dist/types/components/vega-rich-text-editor/public-api.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/slimmers/controllers/extension-controller.d.ts +4 -0
- package/dist/types/components/vega-rich-text-editor/slimmers/controllers/helper/element-to-dto-strategy/annotation-handler/html-element-to-annotation-generator.d.ts +9 -0
- package/dist/types/components/vega-rich-text-editor/slimmers/controllers/selection-controller.d.ts +19 -6
- package/dist/types/components/vega-rich-text-editor/slimmers/controllers/value-controller.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/slimmers/renderers/tools/source-edit-toolbar-button-slimmer.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/annotation-handler/annotation-handler-registration.test.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/annotation-handler/table-annotation-handler.test.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/annotation-handler/table-cell-annotation-handler.test.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/annotation-handler/table-head-cell-annotation-handler.test.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/caption-operation.test.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/table-annotation.test.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/table-caption-annotations.test.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/table-cell-annotation.test.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/table-dto.test.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/table-element-to-dto-strategies.test.d.ts +1 -0
- package/dist/types/components/vega-rich-text-editor/test/extensions/table/table-test-utils.d.ts +11 -0
- package/dist/types/components/vega-rich-text-editor/test/spec-utils.d.ts +4 -0
- package/dist/types/components.d.ts +155 -6
- package/dist/types/helpers/event-manager/event-id/vega-internal-event-id.d.ts +2 -0
- package/dist/types/types/components.type.d.ts +5 -0
- package/dist/types/utils/spec-utils.d.ts +2 -3
- package/dist/vega/app-globals-955a2b3b.js +427 -0
- package/dist/vega/child-nodes-event-prevent-slimmer-a604a6dd.js +156 -0
- package/dist/vega/design-token-56b26205.js +402 -0
- package/dist/vega/element-appender-slimmer-8355fb28.js +1508 -0
- package/dist/vega/event-emit-slimmer-7a14f5e9.js +265 -0
- package/dist/vega/index.esm.js +57 -1
- package/dist/vega/internal-vega-event-manager-8c62c88e.js +458 -0
- package/dist/vega/p-068ee55e.entry.js +1 -0
- package/dist/vega/p-088f4613.entry.js +1 -0
- package/dist/vega/{p-3162a7fd.entry.js → p-08b4d097.entry.js} +1 -1
- package/dist/vega/p-0e4cecbd.entry.js +1 -0
- package/dist/vega/p-10ffb765.js +1 -0
- package/dist/vega/{p-ead1da57.entry.js → p-12a97dad.entry.js} +1 -1
- package/dist/vega/p-151b1deb.js +1 -0
- package/dist/vega/{p-30e7544c.js → p-16af7681.js} +1 -1
- package/dist/vega/p-1b44db34.js +1 -0
- package/dist/vega/p-1bda4016.entry.js +1 -0
- package/dist/vega/{p-6e84e451.entry.js → p-1f4a814e.entry.js} +1 -1
- package/dist/vega/{p-2ae5ad30.entry.js → p-206245d2.entry.js} +1 -1
- package/dist/vega/p-213be5e9.entry.js +1 -0
- package/dist/vega/{p-7a8c4cf8.entry.js → p-216f3436.entry.js} +1 -1
- package/dist/vega/p-224a4f3f.entry.js +1 -0
- package/dist/vega/p-22c76be7.entry.js +1 -0
- package/dist/vega/p-22da15d7.entry.js +1 -0
- package/dist/vega/{p-2409a475.entry.js → p-24766b9d.entry.js} +1 -1
- package/dist/vega/p-29a9c8f5.entry.js +1 -0
- package/dist/vega/p-34a994a1.entry.js +1 -0
- package/dist/vega/p-39d56e3d.js +1 -0
- package/dist/vega/{p-c7194674.entry.js → p-3bc7e162.entry.js} +1 -1
- package/dist/vega/p-40660c09.js +1 -0
- package/dist/vega/p-50a506ea.entry.js +1 -0
- package/dist/vega/{p-f2c8c363.js → p-5367eaab.js} +1 -1
- package/dist/vega/p-550ce71a.entry.js +1 -0
- package/dist/vega/p-5d2704c1.entry.js +1 -0
- package/dist/vega/p-5f377954.js +1 -1
- package/dist/vega/p-61ae4e9c.entry.js +1 -0
- package/dist/vega/{p-2971b17a.js → p-63246470.js} +1 -1
- package/dist/vega/p-6665d083.entry.js +1 -0
- package/dist/vega/p-69af3422.entry.js +1 -0
- package/dist/vega/p-6d9731c1.entry.js +1 -0
- package/dist/vega/p-6f08e3e1.entry.js +1 -0
- package/dist/vega/p-7172332a.entry.js +1 -0
- package/dist/vega/{p-9d8e2939.entry.js → p-73688c4e.entry.js} +1 -1
- package/dist/vega/p-73689ec0.entry.js +1 -0
- package/dist/vega/{p-9fb71d8c.entry.js → p-780cbfb0.entry.js} +1 -1
- package/dist/vega/p-79e8236a.entry.js +1 -0
- package/dist/vega/{p-8fba7f9a.js → p-7ca9f6f1.js} +1 -1
- package/dist/vega/{p-f6cd7a08.entry.js → p-813b2915.entry.js} +1 -1
- package/dist/vega/{p-e88f2dc3.js → p-8162980c.js} +1 -1
- package/dist/vega/p-82ec9721.entry.js +1 -0
- package/dist/vega/{p-7f9acdf7.entry.js → p-86caa739.entry.js} +1 -1
- package/dist/vega/p-8a4d8139.entry.js +1 -0
- package/dist/vega/{p-be0b67b8.entry.js → p-8ac453cb.entry.js} +1 -1
- package/dist/vega/p-98b78c75.entry.js +1 -0
- package/dist/vega/{p-76e6c13a.js → p-99e3dcab.js} +1 -1
- package/dist/vega/{p-44bc9ea9.entry.js → p-9aac9879.entry.js} +1 -1
- package/dist/vega/p-a007b493.entry.js +1 -0
- package/dist/vega/p-a439e59b.entry.js +1 -0
- package/dist/vega/p-a4d0ab07.js +1 -0
- package/dist/vega/{p-f38a4be2.entry.js → p-a6e03df4.entry.js} +1 -1
- package/dist/vega/{p-4957f07a.entry.js → p-a924c1e2.entry.js} +1 -1
- package/dist/vega/p-ab0e013c.entry.js +1 -0
- package/dist/vega/p-abf871cd.entry.js +1 -0
- package/dist/vega/{p-9dfe2bbc.js → p-ac4bd1f8.js} +1 -1
- package/dist/vega/{p-3566ad76.js → p-b91c2c9d.js} +1 -1
- package/dist/vega/{p-184d8443.js → p-c00adad9.js} +1 -1
- package/dist/vega/{p-697eb0e1.js → p-c335088c.js} +1 -1
- package/dist/vega/{p-623c3911.entry.js → p-c3d388b5.entry.js} +1 -1
- package/dist/vega/p-c674b07c.js +1 -0
- package/dist/vega/p-c6d98c60.entry.js +1 -0
- package/dist/vega/p-c78fe943.js +1 -0
- package/dist/vega/{p-7f86b3c8.js → p-c8ad47c9.js} +1 -1
- package/dist/vega/{p-96797fee.entry.js → p-c9541fc2.entry.js} +1 -1
- package/dist/vega/{p-a58bdbad.entry.js → p-d07d04e0.entry.js} +1 -1
- package/dist/vega/p-d1349401.entry.js +1 -0
- package/dist/vega/{p-c0036e71.js → p-d2033624.js} +1 -1
- package/dist/vega/{p-74a77cad.js → p-d466baf7.js} +1 -1
- package/dist/vega/p-d4719c14.entry.js +1 -0
- package/dist/vega/{p-82dbff54.entry.js → p-d4e35d2e.entry.js} +1 -1
- package/dist/vega/p-d55365b9.entry.js +1 -0
- package/dist/vega/p-db482ee1.js +1 -0
- package/dist/vega/p-dc2813eb.entry.js +1 -0
- package/dist/vega/{p-676eaf3f.entry.js → p-dd5d917b.entry.js} +1 -1
- package/dist/vega/{p-5be29f14.js → p-ddf81373.js} +1 -1
- package/dist/vega/p-e0cefd90.entry.js +1 -0
- package/dist/vega/p-e13c163c.entry.js +1 -0
- package/dist/vega/{p-a5d4d168.entry.js → p-e788598a.entry.js} +1 -1
- package/dist/vega/{p-6b9d2996.entry.js → p-e797bf8d.entry.js} +1 -1
- package/dist/vega/p-f4b46f6b.entry.js +1 -0
- package/dist/vega/p-f519cdc3.entry.js +1 -0
- package/dist/vega/{p-9b673fd4.entry.js → p-f6eab527.entry.js} +1 -1
- package/dist/vega/{p-c7f292dd.entry.js → p-fa34ace2.entry.js} +1 -1
- package/dist/vega/p-fbfb4c70.entry.js +1 -0
- package/dist/vega/p-fcabf0dc.js +1 -0
- package/dist/vega/{p-8bd496b4.js → p-ff57c872.js} +1 -1
- package/dist/vega/p-ff921d10.js +1 -0
- package/dist/vega/p-ff9a0e6e.js +1 -0
- package/dist/vega/public-api-8dd022fa.js +6043 -0
- package/dist/vega/public-api-baaf7593.js +4 -0
- package/dist/vega/responsive-format-facade-98596535.js +913 -0
- package/dist/vega/style-formatter-0ae102e9.js +32 -0
- package/dist/vega/vega-accordion.entry.js +291 -0
- package/dist/vega/vega-app-header-button.entry.js +452 -0
- package/dist/vega/vega-banner.entry.js +351 -0
- package/dist/vega/vega-box.entry.js +353 -0
- package/dist/vega/vega-breadcrumb.entry.js +249 -0
- package/dist/vega/vega-button-circle.entry.js +245 -0
- package/dist/vega/vega-button-group.entry.js +203 -0
- package/dist/vega/vega-button-link.entry.js +226 -0
- package/dist/vega/vega-button.entry.js +259 -0
- package/dist/vega/vega-calendar.entry.js +3884 -0
- package/dist/vega/vega-card.entry.js +226 -0
- package/dist/vega/vega-carousel.entry.js +540 -0
- package/dist/vega/vega-checkbox-group.entry.js +266 -0
- package/dist/vega/vega-checkbox.entry.js +335 -0
- package/dist/vega/vega-chip.entry.js +321 -0
- package/dist/vega/vega-code-block.entry.js +4372 -0
- package/dist/vega/vega-color-picker.entry.js +258 -0
- package/dist/vega/vega-combo-box.entry.js +748 -0
- package/dist/vega/vega-date-picker-calendar.entry.js +1381 -0
- package/dist/vega/vega-date-picker.entry.js +1646 -0
- package/dist/vega/vega-dialog.entry.js +158 -0
- package/dist/vega/vega-divider.entry.js +179 -0
- package/dist/vega/vega-dropdown-content-box.entry.js +57 -0
- package/dist/vega/vega-dropdown-item.entry.js +352 -0
- package/dist/vega/vega-dropdown.entry.js +2136 -0
- package/dist/vega/vega-field-label.entry.js +182 -0
- package/dist/vega/vega-file-uploader.entry.js +751 -0
- package/dist/vega/vega-flag-icon.entry.js +216 -0
- package/dist/vega/vega-flex.entry.js +224 -0
- package/dist/vega/vega-font.entry.js +327 -0
- package/dist/vega/vega-form.entry.js +1008 -0
- package/dist/vega/vega-grid.entry.js +129 -0
- package/dist/vega/vega-icon.entry.js +256 -0
- package/dist/vega/vega-image-uploader.entry.js +977 -0
- package/dist/vega/vega-input-credit-card.entry.js +549 -0
- package/dist/vega/vega-input-numeric.entry.js +471 -0
- package/dist/vega/vega-input-passcode.entry.js +728 -0
- package/dist/vega/vega-input-phone-number.entry.js +9143 -0
- package/dist/vega/vega-input-range.entry.js +693 -0
- package/dist/vega/vega-input-select.entry.js +1268 -0
- package/dist/vega/vega-input.entry.js +1735 -0
- package/dist/vega/vega-item-toggle.entry.js +190 -0
- package/dist/vega/vega-left-nav-group.entry.js +433 -0
- package/dist/vega/vega-left-nav-link.entry.js +317 -0
- package/dist/vega/vega-left-nav-section.entry.js +97 -0
- package/dist/vega/vega-left-nav.entry.js +654 -0
- package/dist/vega/vega-loading-indicator.entry.js +209 -0
- package/dist/vega/vega-modal.entry.js +1287 -0
- package/dist/vega/vega-nav-card.entry.js +163 -0
- package/dist/vega/vega-pagination-page-selector-mobile.entry.js +214 -0
- package/dist/vega/vega-pagination.entry.js +629 -0
- package/dist/vega/vega-popover-content-box.entry.js +101 -0
- package/dist/vega/vega-popover.entry.js +362 -0
- package/dist/vega/vega-progress-tracker.entry.js +757 -0
- package/dist/vega/vega-radio-group.entry.js +496 -0
- package/dist/vega/vega-radio.entry.js +272 -0
- package/dist/vega/vega-rich-text-editor-toolbar-button.entry.js +169 -0
- package/dist/vega/vega-rich-text-editor.entry.js +4107 -0
- package/dist/vega/vega-rich-text-image-editor.entry.js +216 -0
- package/dist/vega/vega-rich-text-link-editor.entry.js +238 -0
- package/dist/vega/vega-rich-text-table-properties.entry.js +641 -0
- package/dist/vega/vega-rich-text-table-setting.entry.js +525 -0
- package/dist/vega/vega-segment-control.entry.js +350 -0
- package/dist/vega/vega-selection-chip-group.entry.js +447 -0
- package/dist/vega/vega-selection-chip.entry.js +443 -0
- package/dist/vega/vega-selection-tile-group.entry.js +438 -0
- package/dist/vega/vega-selection-tile.entry.js +409 -0
- package/dist/vega/vega-sidenav-link.entry.js +160 -0
- package/dist/vega/vega-sidenav.entry.js +766 -0
- package/dist/vega/vega-signature-capture.entry.js +589 -0
- package/dist/vega/vega-stepper.entry.js +292 -0
- package/dist/vega/vega-tab-group-panel.entry.js +79 -0
- package/dist/vega/vega-tab-group.entry.js +1281 -0
- package/dist/vega/vega-table-body.entry.js +48 -0
- package/dist/vega/vega-table-cell.entry.js +243 -0
- package/dist/vega/vega-table-foot-cell.entry.js +169 -0
- package/dist/vega/vega-table-foot-row.entry.js +219 -0
- package/dist/vega/vega-table-foot.entry.js +136 -0
- package/dist/vega/vega-table-head-cell.entry.js +339 -0
- package/dist/vega/vega-table-head-row.entry.js +416 -0
- package/dist/vega/vega-table-head.entry.js +113 -0
- package/dist/vega/vega-table-row.entry.js +666 -0
- package/dist/vega/vega-table.entry.js +3707 -0
- package/dist/vega/vega-textarea.entry.js +329 -0
- package/dist/vega/vega-time-picker.entry.js +2039 -0
- package/dist/vega/vega-toggle-switch.entry.js +194 -0
- package/dist/vega/vega-tooltip.entry.js +339 -0
- package/dist/vega/vega.esm.js +172 -1
- package/package.json +1 -1
- package/style/vega-icons.css +17266 -0
- package/dist/cjs/function-extension-78ec27e0.js +0 -2927
- package/dist/esm/function-extension-8b06c6f8.js +0 -2908
- package/dist/vega/p-03e16a05.entry.js +0 -1
- package/dist/vega/p-0ad59141.entry.js +0 -1
- package/dist/vega/p-0ba0f83d.entry.js +0 -1
- package/dist/vega/p-114c6df8.entry.js +0 -1
- package/dist/vega/p-1e019406.js +0 -1
- package/dist/vega/p-1faef917.entry.js +0 -1
- package/dist/vega/p-21cba83b.entry.js +0 -1
- package/dist/vega/p-21e7808a.entry.js +0 -1
- package/dist/vega/p-2b20a215.entry.js +0 -1
- package/dist/vega/p-2bc4f7d9.entry.js +0 -1
- package/dist/vega/p-2e0deef6.js +0 -1
- package/dist/vega/p-2f592078.entry.js +0 -1
- package/dist/vega/p-38ed3d59.entry.js +0 -1
- package/dist/vega/p-3938880f.entry.js +0 -1
- package/dist/vega/p-398220f5.entry.js +0 -1
- package/dist/vega/p-40561fa0.entry.js +0 -1
- package/dist/vega/p-42a283b5.entry.js +0 -1
- package/dist/vega/p-524ffc12.entry.js +0 -1
- package/dist/vega/p-59fa3f68.js +0 -1
- package/dist/vega/p-5b71c85e.js +0 -1
- package/dist/vega/p-5f09868d.entry.js +0 -1
- package/dist/vega/p-6e701542.entry.js +0 -1
- package/dist/vega/p-70b2906a.entry.js +0 -1
- package/dist/vega/p-721b2981.entry.js +0 -1
- package/dist/vega/p-75d91ee9.entry.js +0 -1
- package/dist/vega/p-79a544d6.js +0 -1
- package/dist/vega/p-7b337fd4.entry.js +0 -1
- package/dist/vega/p-7be3aefc.entry.js +0 -1
- package/dist/vega/p-94cf46ca.entry.js +0 -1
- package/dist/vega/p-a125cfec.entry.js +0 -1
- package/dist/vega/p-a3c4fa30.entry.js +0 -1
- package/dist/vega/p-aab0deab.js +0 -1
- package/dist/vega/p-adc615a4.entry.js +0 -1
- package/dist/vega/p-b007d0d5.entry.js +0 -1
- package/dist/vega/p-b406a846.entry.js +0 -1
- package/dist/vega/p-bd60c72e.entry.js +0 -1
- package/dist/vega/p-bf61d136.js +0 -1
- package/dist/vega/p-c2ac6b47.entry.js +0 -1
- package/dist/vega/p-c4700277.entry.js +0 -1
- package/dist/vega/p-ce2ffff7.js +0 -1
- package/dist/vega/p-d01fe83d.entry.js +0 -1
- package/dist/vega/p-db62b038.entry.js +0 -1
- package/dist/vega/p-dd72ad9e.js +0 -1
- package/dist/vega/p-e39aa2ea.entry.js +0 -1
- package/dist/vega/p-f3831dc9.entry.js +0 -1
- package/dist/vega/p-f427d88c.entry.js +0 -1
|
@@ -0,0 +1,2039 @@
|
|
|
1
|
+
import { h, F as Fragment, r as registerInstance, e as createEvent, g as Host, i as getElement } from './index-01a2f9c9.js';
|
|
2
|
+
import { C as ComponentLoadRequired } from './component-load-required-db42032a.js';
|
|
3
|
+
import { T as TimeRangeRequiredRule, a as TimeRequiredRule } from './time-required-rule-dd0e68fc.js';
|
|
4
|
+
import { s as sanitizeVegaComponent } from './component-0cff85cf.js';
|
|
5
|
+
import { V as VegaSlimmer, b as MapToComponentField, M as MapToComponentMethod, L as LogUtility, m as methodPlaceholder, e as InjectVegaGlobalSlimmer, a as InjectVegaSlimmer } from './vega-slimmer-core-83fd0e22.js';
|
|
6
|
+
import { F as FormFieldControllerSlimmer } from './form-field-controller-slimmer-316ebdb1.js';
|
|
7
|
+
import { D as DomNodeSubjectObserverFactory } from './dom-node-subject-observer-factory-3b49c6b3.js';
|
|
8
|
+
import { h as VegaChange, F as VegaFocus, G as VegaBlur, a as VegaClick } from './vega-event-id-61c8bd9f.js';
|
|
9
|
+
import { g as getDeviceType, D as DeviceType } from './ui-5f775fd9.js';
|
|
10
|
+
import { c as createEnterKeyHandlerToTriggerClick } from './accessibility-e5fd0fab.js';
|
|
11
|
+
import { X as isTimeStr, Z as pad, i as isNonNullable, ak as convert12HourTo24HourFormat } from './type-guard-09acedc9.js';
|
|
12
|
+
import { i as isArrayEqual } from './array-a1d98264.js';
|
|
13
|
+
import { F as FORM_ELEMENT_VALUE_CHANGE } from './static-subject-title-6fdf8c8b.js';
|
|
14
|
+
import { C as ChangeManager } from './change-manager-b115783e.js';
|
|
15
|
+
import { E as ElementAppenderSlimmer } from './element-appender-slimmer-16a5ed3a.js';
|
|
16
|
+
import { K as KeyboardManagerSlimmer } from './keyboard-manager-slimmer-a7b44d74.js';
|
|
17
|
+
import { I as InternalFormFieldValidationRule } from './internal-form-field-validation-rule.abstract-f5b6bdbf.js';
|
|
18
|
+
import { C as ChildNodesEventPreventSlimmer } from './child-nodes-event-prevent-slimmer-fcfc9c8b.js';
|
|
19
|
+
import { c as createEventEmitSlimmer } from './event-emit-slimmer-61db3eef.js';
|
|
20
|
+
import { V as VegaComponentUsageRuntimeMetricsSlimmer } from './component-usage-runtime-metrics-0513698f.js';
|
|
21
|
+
import './index-9fdb7060.js';
|
|
22
|
+
import { T as TranslationSlimmer } from './translation-slimmer-3c4e2876.js';
|
|
23
|
+
import './string-a953eafc.js';
|
|
24
|
+
import './observer-3959f9dd.js';
|
|
25
|
+
import './create-public-api-runtime-metrics-slimmer-8565f08b.js';
|
|
26
|
+
import './dom-node-subject-factory-5798693b.js';
|
|
27
|
+
import './vega-internal-event-id-b65a01a3.js';
|
|
28
|
+
import './index-81ce67e2.js';
|
|
29
|
+
import './page-resize-observer-slimmer-ee8774a6.js';
|
|
30
|
+
import './ui-189dae23.js';
|
|
31
|
+
import './breakpoints-d9faf11c.js';
|
|
32
|
+
import './try-get-document-bef0f526.js';
|
|
33
|
+
import './mutation-observer-slimmer-7065c745.js';
|
|
34
|
+
import './mutation-observer-filters-6c515793.js';
|
|
35
|
+
import './sub-state-observer-slimmer-4fc8b3da.js';
|
|
36
|
+
import './typography-396de03f.js';
|
|
37
|
+
import './number-4398f2e1.js';
|
|
38
|
+
import './internal-vega-z-index-manager-f0ca0975.js';
|
|
39
|
+
import './responsive-format-facade-d4abfdb9.js';
|
|
40
|
+
import './pixel-f32c07ce.js';
|
|
41
|
+
import './public-api-a77a0b33.js';
|
|
42
|
+
import './vega-env-manager-8f8dc473.js';
|
|
43
|
+
import './internal-vega-event-manager-826279b7.js';
|
|
44
|
+
import './feature-flag-controller-24b9f956.js';
|
|
45
|
+
import './index-1f9eab8f.js';
|
|
46
|
+
import './_commonjsHelpers-2088bffa.js';
|
|
47
|
+
import './dark-mode-style-controller-e2a2f76c.js';
|
|
48
|
+
import './vega-nonce-manager-497e5eb5.js';
|
|
49
|
+
import './internal-icon-manager-9279071a.js';
|
|
50
|
+
import './valid-credit-card-number-rule-04b032a6.js';
|
|
51
|
+
import './index-b04c1ee0.js';
|
|
52
|
+
import './content-state-fc9d98e0.js';
|
|
53
|
+
import './code-block-b5f8fc8a.js';
|
|
54
|
+
import './object-66c37948.js';
|
|
55
|
+
import './dto-renderer-manager-12bc9121.js';
|
|
56
|
+
import './base-renderer-101f6d04.js';
|
|
57
|
+
import './column-operation-a1620c67.js';
|
|
58
|
+
import './remote-invocation-registry-4219120b.js';
|
|
59
|
+
import './timer-9321173b.js';
|
|
60
|
+
import './styles.constants-b320e4a7.js';
|
|
61
|
+
import './range-429fb0e2.js';
|
|
62
|
+
import './keyboard-manager-3c463777.js';
|
|
63
|
+
|
|
64
|
+
var __decorate$c = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
65
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
66
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
67
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
68
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
69
|
+
};
|
|
70
|
+
/** The VegaTimePickerLabelRenderer class is a TypeScript React component that renders a label for a time picker input field. */
|
|
71
|
+
class VegaTimePickerLabelRenderer extends VegaSlimmer {
|
|
72
|
+
constructor() {
|
|
73
|
+
super(...arguments);
|
|
74
|
+
/**
|
|
75
|
+
* The below method is e2e-test covered in
|
|
76
|
+
* @see{module:vega-time-picker-select-time-e2e}
|
|
77
|
+
*/
|
|
78
|
+
/* istanbul ignore next */
|
|
79
|
+
this.onTimePickerFocus = async () => {
|
|
80
|
+
if (this.mode === 'single') {
|
|
81
|
+
await this.singleInputRenderer.getInputRef().doFocus();
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
await this.rangeInputRenderer.getStartInputRef().doFocus();
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
render() {
|
|
89
|
+
return (h("vega-field-label", { onClick: this.onTimePickerFocus, "is-field-required": this.required, disabled: this.disabled, label: this.label }));
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
__decorate$c([
|
|
93
|
+
MapToComponentField()
|
|
94
|
+
], VegaTimePickerLabelRenderer.prototype, "label", void 0);
|
|
95
|
+
__decorate$c([
|
|
96
|
+
MapToComponentField()
|
|
97
|
+
], VegaTimePickerLabelRenderer.prototype, "mode", void 0);
|
|
98
|
+
__decorate$c([
|
|
99
|
+
MapToComponentField()
|
|
100
|
+
], VegaTimePickerLabelRenderer.prototype, "required", void 0);
|
|
101
|
+
__decorate$c([
|
|
102
|
+
MapToComponentField()
|
|
103
|
+
], VegaTimePickerLabelRenderer.prototype, "disabled", void 0);
|
|
104
|
+
__decorate$c([
|
|
105
|
+
MapToComponentField()
|
|
106
|
+
], VegaTimePickerLabelRenderer.prototype, "singleInputRenderer", void 0);
|
|
107
|
+
__decorate$c([
|
|
108
|
+
MapToComponentField()
|
|
109
|
+
], VegaTimePickerLabelRenderer.prototype, "rangeInputRenderer", void 0);
|
|
110
|
+
|
|
111
|
+
var __decorate$b = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
112
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
113
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
114
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
115
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
116
|
+
};
|
|
117
|
+
/** The `VegaTimePickerInputRenderer` class is a TypeScript React component that renders a time picker input field. */
|
|
118
|
+
class VegaTimePickerSingleInputRenderer extends VegaSlimmer {
|
|
119
|
+
constructor() {
|
|
120
|
+
super(...arguments);
|
|
121
|
+
/**
|
|
122
|
+
* It is an event handler that is called when the `vega-input` component emits a `VegaChange` event.
|
|
123
|
+
*
|
|
124
|
+
* @param {CustomEvent} e event object
|
|
125
|
+
*/
|
|
126
|
+
this.onChildVegaInputChange = (e) => {
|
|
127
|
+
this.valueController.setValue(e.detail);
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* The function returns a reference to an HTML input element.
|
|
132
|
+
*
|
|
133
|
+
* @returns {HTMLVegaInputElement} an HTMLVegaInputElement.
|
|
134
|
+
*/
|
|
135
|
+
getInputRef() {
|
|
136
|
+
return this.timeInputRef;
|
|
137
|
+
}
|
|
138
|
+
/* istanbul ignore next */
|
|
139
|
+
/**
|
|
140
|
+
* The function updates the value of a time input field in a TypeScript React component.
|
|
141
|
+
*
|
|
142
|
+
* @param {string} value - A string value that will be used to update the input value.
|
|
143
|
+
*/
|
|
144
|
+
updateInputValue(value) {
|
|
145
|
+
this.timeInputRef.value = value;
|
|
146
|
+
}
|
|
147
|
+
/* istanbul ignore next */
|
|
148
|
+
render() {
|
|
149
|
+
return (h("div", { class: "time-picker-input" },
|
|
150
|
+
h("vega-input", { "prefix-icon": "clock-face", placeholder: this.getPlaceholder(), disabled: this.disabled, size: this.size, value: typeof this.value === 'string' ? this.value : '', ref: (ref) => {
|
|
151
|
+
this.timeInputRef = ref;
|
|
152
|
+
this.handleVegaInputEvent(ref);
|
|
153
|
+
} })));
|
|
154
|
+
}
|
|
155
|
+
/*
|
|
156
|
+
* The below method is e2e-test covered in
|
|
157
|
+
* @see{module:vega-time-picker-keyboard-control-e2e}
|
|
158
|
+
* @see{module:vega-time-picker-keyboard-control-e2e}
|
|
159
|
+
*/
|
|
160
|
+
/* istanbul ignore next */
|
|
161
|
+
/**
|
|
162
|
+
* The function `handleVegaInputEvent` adds event observers to a given HTML input element for handling changes, focus, and blur events.
|
|
163
|
+
*
|
|
164
|
+
* @param {HTMLVegaInputElement} ref - The ref parameter is a reference to an HTML input element with the type "vega".
|
|
165
|
+
*/
|
|
166
|
+
handleVegaInputEvent(ref) {
|
|
167
|
+
DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaChange, (input) => {
|
|
168
|
+
this.onChildVegaInputChange(input);
|
|
169
|
+
});
|
|
170
|
+
DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaFocus, () => {
|
|
171
|
+
this.singleDropdownController.show();
|
|
172
|
+
});
|
|
173
|
+
//When the filled time format is incorrect, the value needs to be set to empty, the initial value may also be empty, so the input needs to be set to an empty value.
|
|
174
|
+
DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaBlur, (input) => {
|
|
175
|
+
this.valueController.checkValueAfterInputBlur(input);
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* get the vega input placeholder
|
|
180
|
+
*
|
|
181
|
+
* @returns {string} a string value
|
|
182
|
+
*/
|
|
183
|
+
getPlaceholder() {
|
|
184
|
+
return this.placeholder && typeof this.placeholder === 'string'
|
|
185
|
+
? this.placeholder
|
|
186
|
+
: this.translationSlimmer.t('Select Time');
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
__decorate$b([
|
|
190
|
+
MapToComponentField()
|
|
191
|
+
], VegaTimePickerSingleInputRenderer.prototype, "placeholder", void 0);
|
|
192
|
+
__decorate$b([
|
|
193
|
+
MapToComponentField()
|
|
194
|
+
], VegaTimePickerSingleInputRenderer.prototype, "size", void 0);
|
|
195
|
+
__decorate$b([
|
|
196
|
+
MapToComponentField()
|
|
197
|
+
], VegaTimePickerSingleInputRenderer.prototype, "disabled", void 0);
|
|
198
|
+
__decorate$b([
|
|
199
|
+
MapToComponentField()
|
|
200
|
+
], VegaTimePickerSingleInputRenderer.prototype, "value", void 0);
|
|
201
|
+
__decorate$b([
|
|
202
|
+
MapToComponentField()
|
|
203
|
+
], VegaTimePickerSingleInputRenderer.prototype, "valueController", void 0);
|
|
204
|
+
__decorate$b([
|
|
205
|
+
MapToComponentField()
|
|
206
|
+
], VegaTimePickerSingleInputRenderer.prototype, "singleDropdownController", void 0);
|
|
207
|
+
__decorate$b([
|
|
208
|
+
MapToComponentField()
|
|
209
|
+
], VegaTimePickerSingleInputRenderer.prototype, "translationSlimmer", void 0);
|
|
210
|
+
|
|
211
|
+
var __decorate$a = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
212
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
213
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
214
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
215
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
216
|
+
};
|
|
217
|
+
/** The `VegaTimePickerDropdownRenderer` class is a TypeScript React component that renders a dropdown menu for selecting a time value. */
|
|
218
|
+
class VegaTimePickerSingleDropdownRenderer extends VegaSlimmer {
|
|
219
|
+
constructor() {
|
|
220
|
+
super(...arguments);
|
|
221
|
+
this.isMobileDevice = getDeviceType() === DeviceType.MOBILE;
|
|
222
|
+
this.isTabletDevice = getDeviceType() === DeviceType.TABLET;
|
|
223
|
+
this.renderDropdownByTimeSource = () => {
|
|
224
|
+
return (h(Fragment, null,
|
|
225
|
+
this.renderDropdownColumn(this.dropdownSource.hours, 'hour'),
|
|
226
|
+
this.renderDropdownColumn(this.dropdownSource.minutes, 'minute'),
|
|
227
|
+
this.timeFormat === '12-hour' && this.renderDropdownColumn(['AM', 'PM'], 'amPm')));
|
|
228
|
+
};
|
|
229
|
+
/**
|
|
230
|
+
* The below method is e2e-test covered in
|
|
231
|
+
* @see{module:vega-time-picker-click-label-focus-input-e2e}
|
|
232
|
+
*/
|
|
233
|
+
/* istanbul ignore next */
|
|
234
|
+
this.onItemClick = (itemValue, sourceType) => {
|
|
235
|
+
this.dropdownSelectedItemsController.setSelectedItems(Object.assign(Object.assign({}, this.selectedTimeValue), { [sourceType]: itemValue }));
|
|
236
|
+
};
|
|
237
|
+
this.onNowButtonClick = () => {
|
|
238
|
+
this.dropdownSelectedItemsController.setSelectedItemsToCurrentTime();
|
|
239
|
+
this.singleDropdownController.hide();
|
|
240
|
+
};
|
|
241
|
+
this.onApplyButtonClick = () => {
|
|
242
|
+
this.valueController.updateValueBySelectedItems();
|
|
243
|
+
this.singleDropdownController.hide();
|
|
244
|
+
};
|
|
245
|
+
}
|
|
246
|
+
/**
|
|
247
|
+
* Component lifecycle - [componentDidRender]{@link VegaTimePicker.componentDidRender}
|
|
248
|
+
*/
|
|
249
|
+
componentDidRenderCallback() {
|
|
250
|
+
if (this.dropdownContainer && this.dropdownContainer.parentElement === this.dropdown) {
|
|
251
|
+
this.dropdown.shadowRoot.append(this.dropdownContainer);
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* The function returns a reference to the dropdown element.
|
|
256
|
+
*
|
|
257
|
+
* @returns {HTMLElement} an HTMLElement, specifically the dropdown element.
|
|
258
|
+
*/
|
|
259
|
+
getDropdownRef() {
|
|
260
|
+
return this.dropdown;
|
|
261
|
+
}
|
|
262
|
+
/**
|
|
263
|
+
* The function returns the selected elements. If elements is empty, it returns the first option by default.
|
|
264
|
+
*
|
|
265
|
+
* @returns {HTMLElement[]} an array of HTMLElements.
|
|
266
|
+
*/
|
|
267
|
+
getSelectedItem() {
|
|
268
|
+
const elements = [];
|
|
269
|
+
const dropdown = this.dropdown.shadowRoot;
|
|
270
|
+
dropdown.querySelectorAll('.vega-dropdown-item-selected').forEach((selectedItem) => {
|
|
271
|
+
elements.push(selectedItem);
|
|
272
|
+
});
|
|
273
|
+
if (elements.length === 0) {
|
|
274
|
+
dropdown
|
|
275
|
+
.querySelectorAll('.vega-time-picker-dropdown-panel li:first-child')
|
|
276
|
+
.forEach((selectedItem) => {
|
|
277
|
+
elements.push(selectedItem);
|
|
278
|
+
});
|
|
279
|
+
}
|
|
280
|
+
return elements;
|
|
281
|
+
}
|
|
282
|
+
render() {
|
|
283
|
+
return (h("vega-time-picker-dropdown", { class: {
|
|
284
|
+
'vega-time-picker-dropdown': true,
|
|
285
|
+
/* istanbul ignore next */
|
|
286
|
+
'mobile': this.isMobileDevice,
|
|
287
|
+
'tablet': this.isTabletDevice,
|
|
288
|
+
}, ref: (e) => (this.dropdown = e) },
|
|
289
|
+
h("div", { class: "vega-time-picker-dropdown-container", ref: (e) => (this.dropdownContainer = e) },
|
|
290
|
+
h("div", { class: "vega-time-picker-dropdown-panel" }, this.renderDropdownByTimeSource()),
|
|
291
|
+
h("div", { class: "horizontal-divider v-my-size-12" }),
|
|
292
|
+
this.renderDropdownFoot())));
|
|
293
|
+
}
|
|
294
|
+
renderDropdownColumn(items, sourceType) {
|
|
295
|
+
return (h("ul", { role: "menu", "aria-label": "dropdown-ul", class: {
|
|
296
|
+
'vega-time-picker-panel-column': true,
|
|
297
|
+
} }, items.map((item, index) => {
|
|
298
|
+
{
|
|
299
|
+
return this.renderDropdownItem(item, sourceType, index);
|
|
300
|
+
}
|
|
301
|
+
})));
|
|
302
|
+
}
|
|
303
|
+
/**
|
|
304
|
+
* The below method is e2e-test covered in
|
|
305
|
+
* @see{module:vega-time-picker-select-time-e2e}
|
|
306
|
+
*/
|
|
307
|
+
/* istanbul ignore next */
|
|
308
|
+
renderDropdownItem(item, sourceType, index) {
|
|
309
|
+
return (h("li", { key: item, role: "menuitem", "aria-label": item, class: {
|
|
310
|
+
'vega-dropdown-item-selected': this.isItemSelected(item, sourceType),
|
|
311
|
+
}, tabIndex: index === 0 ? 0 : -1, "data-index": index,
|
|
312
|
+
/* eslint-disable-next-line react/jsx-no-bind */
|
|
313
|
+
onClick: () => this.onItemClick(item, sourceType), onKeyDown: createEnterKeyHandlerToTriggerClick() },
|
|
314
|
+
h("span", { "data-index": index, innerHTML: item })));
|
|
315
|
+
}
|
|
316
|
+
renderDropdownFoot() {
|
|
317
|
+
return (h("div", { class: "vega-time-picker-dropdown-footer" },
|
|
318
|
+
h("div", { class: "vega-time-picker-now" },
|
|
319
|
+
h("vega-button-link", { size: "small", label: "Now", ref: (ref) => {
|
|
320
|
+
DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaClick, () => {
|
|
321
|
+
this.onNowButtonClick();
|
|
322
|
+
});
|
|
323
|
+
} })),
|
|
324
|
+
h("div", null,
|
|
325
|
+
h("vega-button-link", { size: "small", label: "Apply", ref: (ref) => {
|
|
326
|
+
DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaClick, () => {
|
|
327
|
+
this.onApplyButtonClick();
|
|
328
|
+
});
|
|
329
|
+
} }))));
|
|
330
|
+
}
|
|
331
|
+
/* If no hour, minute, etc. are currently selected,
|
|
332
|
+
* the initial value is displayed. Hour and minute initial value is 00, amPm is AM.
|
|
333
|
+
*/
|
|
334
|
+
isItemSelected(itemValue, sourceType) {
|
|
335
|
+
return this.selectedTimeValue[`${sourceType}`] === itemValue;
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
__decorate$a([
|
|
339
|
+
MapToComponentField()
|
|
340
|
+
], VegaTimePickerSingleDropdownRenderer.prototype, "timeFormat", void 0);
|
|
341
|
+
__decorate$a([
|
|
342
|
+
MapToComponentField()
|
|
343
|
+
], VegaTimePickerSingleDropdownRenderer.prototype, "dropdownSource", void 0);
|
|
344
|
+
__decorate$a([
|
|
345
|
+
MapToComponentField()
|
|
346
|
+
], VegaTimePickerSingleDropdownRenderer.prototype, "selectedTimeValue", void 0);
|
|
347
|
+
__decorate$a([
|
|
348
|
+
MapToComponentField()
|
|
349
|
+
], VegaTimePickerSingleDropdownRenderer.prototype, "valueController", void 0);
|
|
350
|
+
__decorate$a([
|
|
351
|
+
MapToComponentField()
|
|
352
|
+
], VegaTimePickerSingleDropdownRenderer.prototype, "dropdownSelectedItemsController", void 0);
|
|
353
|
+
__decorate$a([
|
|
354
|
+
MapToComponentField()
|
|
355
|
+
], VegaTimePickerSingleDropdownRenderer.prototype, "singleDropdownController", void 0);
|
|
356
|
+
__decorate$a([
|
|
357
|
+
MapToComponentMethod('componentDidRender')
|
|
358
|
+
], VegaTimePickerSingleDropdownRenderer.prototype, "componentDidRenderCallback", null);
|
|
359
|
+
|
|
360
|
+
var __decorate$9 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
361
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
362
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
363
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
364
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
365
|
+
};
|
|
366
|
+
/** The `VegaTimePickerValueController` class is responsible for managing the value and behavior of a time picker component. */
|
|
367
|
+
class VegaTimePickerValueController extends VegaSlimmer {
|
|
368
|
+
/**
|
|
369
|
+
* The function emits a change event if the new value is a valid time string or clears the time picker if the new value is not valid or empty.
|
|
370
|
+
*
|
|
371
|
+
* @param {string|string[]} newValue - The `newValue` parameter is a string representing the new value for the time picker.
|
|
372
|
+
* @param {string|string[]} oldValue - The `oldValue` parameter is a string representing the old value for the time picker.
|
|
373
|
+
*/
|
|
374
|
+
emitChangeEventOrClearTimePicker(newValue, oldValue) {
|
|
375
|
+
if (this.mode === 'range' &&
|
|
376
|
+
isArrayEqual(newValue, oldValue)) {
|
|
377
|
+
return; // avoid the value changed again by `input blur`, `dropdown item click` in range mode
|
|
378
|
+
}
|
|
379
|
+
if (this.valueGuard(newValue)) {
|
|
380
|
+
this.changeEventEmitter.emit(newValue);
|
|
381
|
+
ChangeManager.notify(FORM_ELEMENT_VALUE_CHANGE, {
|
|
382
|
+
host: this.host,
|
|
383
|
+
detail: newValue,
|
|
384
|
+
});
|
|
385
|
+
}
|
|
386
|
+
else {
|
|
387
|
+
if (this.mode === 'single') {
|
|
388
|
+
this.clearTimePicker();
|
|
389
|
+
}
|
|
390
|
+
else {
|
|
391
|
+
this.clearRangeTimePicker();
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
/**
|
|
396
|
+
* The function updates a value if there are selected items.
|
|
397
|
+
*/
|
|
398
|
+
updateValueIfSelectedItemsChange() {
|
|
399
|
+
if (this.mode === 'single') {
|
|
400
|
+
if (Object.keys(this.selectedTimeValue).length > 0) {
|
|
401
|
+
this.updateValueBySelectedItems();
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
/*
|
|
406
|
+
* The below method is e2e-test covered in
|
|
407
|
+
* @see{module:vega-time-picker-mode-change}
|
|
408
|
+
*/
|
|
409
|
+
/* istanbul ignore next */
|
|
410
|
+
/**
|
|
411
|
+
* The function resets the current value if there is a change in mode.
|
|
412
|
+
*/
|
|
413
|
+
resetCurrentValueIfModeChange() {
|
|
414
|
+
this.resetValue();
|
|
415
|
+
}
|
|
416
|
+
/**
|
|
417
|
+
* The function checks if the mode is set to 'range' and if the value is not valid, it clears the range time picker.
|
|
418
|
+
*/
|
|
419
|
+
checkTheDefaultValueForRangeMode() {
|
|
420
|
+
if (this.mode === 'range' && this.value && !this.valueGuard(this.value)) {
|
|
421
|
+
this.clearRangeTimePicker();
|
|
422
|
+
}
|
|
423
|
+
}
|
|
424
|
+
/*
|
|
425
|
+
* When the filled time format is incorrect, the value needs to be set to empty,
|
|
426
|
+
* the initial value may also be empty, so the input needs to be set to an empty value.
|
|
427
|
+
* The below method is e2e-test covered in
|
|
428
|
+
* @see{module:vega-time-picker-keyboard-control-e2e}
|
|
429
|
+
*/
|
|
430
|
+
/* istanbul ignore next */
|
|
431
|
+
/**
|
|
432
|
+
* The function checks the value of an input element after it loses focus and performs certain actions based on the value.
|
|
433
|
+
*
|
|
434
|
+
* @param {NotifyObserverPayload<unknown>} input - input#host is vega-input component
|
|
435
|
+
*/
|
|
436
|
+
checkValueAfterInputBlur(input) {
|
|
437
|
+
const vegaInput = input.host;
|
|
438
|
+
if (!this.valueGuard(vegaInput.value)) {
|
|
439
|
+
this.clearTimePicker();
|
|
440
|
+
}
|
|
441
|
+
else if (this.increments > 1 && this.value && vegaInput.value && vegaInput.value !== this.value) {
|
|
442
|
+
vegaInput.value = this.value;
|
|
443
|
+
}
|
|
444
|
+
}
|
|
445
|
+
/**
|
|
446
|
+
* The function sets the value of a variable.
|
|
447
|
+
*
|
|
448
|
+
* @param {string|string[]} value - The parameter "value" is of type string.
|
|
449
|
+
*/
|
|
450
|
+
setValue(value) {
|
|
451
|
+
if (this.valueGuard(value)) {
|
|
452
|
+
this.value = value;
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
/**
|
|
456
|
+
* The function resets the value property to an empty string or an array depending on the mode property.
|
|
457
|
+
*/
|
|
458
|
+
resetValue() {
|
|
459
|
+
this.value = this.mode === 'single' ? '' : ['', ''];
|
|
460
|
+
}
|
|
461
|
+
/**
|
|
462
|
+
* The function updates the value based on the selected time items, taking into account the time
|
|
463
|
+
* format (12-hour or 24-hour).
|
|
464
|
+
*/
|
|
465
|
+
updateValueBySelectedItems() {
|
|
466
|
+
const defaultHour = this.timeFormat === '12-hour' ? '12' : '00';
|
|
467
|
+
const hour = this.selectedTimeValue.hour ? this.selectedTimeValue.hour : defaultHour;
|
|
468
|
+
const minute = this.selectedTimeValue.minute ? this.selectedTimeValue.minute : '00';
|
|
469
|
+
const amPm = this.selectedTimeValue.amPm ? this.selectedTimeValue.amPm : 'AM';
|
|
470
|
+
this.timeFormat === '12-hour'
|
|
471
|
+
? this.setValue(`${hour}:${minute} ${amPm}`)
|
|
472
|
+
: this.setValue(`${hour}:${minute}`);
|
|
473
|
+
}
|
|
474
|
+
/**
|
|
475
|
+
* The function updates a value based on the range type. if change start value, check the end value is a time string, if not check, the start value will block by the value guard
|
|
476
|
+
*
|
|
477
|
+
* @param {string} value - A string value that needs to be updated based on the source code.
|
|
478
|
+
* @param {TimeRangeIndex} rangeIndex - The rangeIndex parameter is of type TimeRangeIndex, which is a string that can have two possible values: 'start' or 'end'.
|
|
479
|
+
*/
|
|
480
|
+
updateValueByRangeType(value, rangeIndex) {
|
|
481
|
+
if (rangeIndex === 'start') {
|
|
482
|
+
this.setValue([
|
|
483
|
+
value,
|
|
484
|
+
Array.isArray(this.value) && this.value[1] && isTimeStr(this.value[1], this.timeFormat)
|
|
485
|
+
? this.value[1]
|
|
486
|
+
: '',
|
|
487
|
+
]);
|
|
488
|
+
}
|
|
489
|
+
else {
|
|
490
|
+
this.setValue([
|
|
491
|
+
Array.isArray(this.value) && this.value[0] && isTimeStr(this.value[0], this.timeFormat)
|
|
492
|
+
? this.value[0]
|
|
493
|
+
: '',
|
|
494
|
+
value,
|
|
495
|
+
]);
|
|
496
|
+
}
|
|
497
|
+
}
|
|
498
|
+
/**
|
|
499
|
+
* This method is used to clear the selected time value in a time picker component.
|
|
500
|
+
*/
|
|
501
|
+
clearRangeTimePicker() {
|
|
502
|
+
this.value = ['', ''];
|
|
503
|
+
this.rangeInputRenderer.getStartInputRef().value = '';
|
|
504
|
+
this.rangeInputRenderer.getEndInputRef().value = '';
|
|
505
|
+
}
|
|
506
|
+
/**
|
|
507
|
+
* This method is used to clear the selected time value in a time picker component.
|
|
508
|
+
*/
|
|
509
|
+
clearTimePicker() {
|
|
510
|
+
this.value = '';
|
|
511
|
+
this.singleInputRenderer.getInputRef().value = '';
|
|
512
|
+
this.dropdownSelectedItemsController.setSelectedItems({});
|
|
513
|
+
}
|
|
514
|
+
/**
|
|
515
|
+
* The function `valueGuard` checks if the provided value is valid for the specified mode of a time picker component.
|
|
516
|
+
*
|
|
517
|
+
* @param {DatePickerValueType<DatePickerModeType>} value - The `value` parameter is of type `DatePickerValueType<DatePickerModeType>`. It
|
|
518
|
+
* represents the value of the time picker, which can be a single time or a range of times depending on
|
|
519
|
+
* the mode of the time picker.
|
|
520
|
+
* @returns {boolean} a boolean value.
|
|
521
|
+
*/
|
|
522
|
+
valueGuard(value) {
|
|
523
|
+
let isValid;
|
|
524
|
+
switch (this.mode) {
|
|
525
|
+
case 'single':
|
|
526
|
+
isValid =
|
|
527
|
+
(value && typeof value === 'string' && isTimeStr(value, this.timeFormat)) || value === '';
|
|
528
|
+
break;
|
|
529
|
+
case 'range':
|
|
530
|
+
isValid =
|
|
531
|
+
Array.isArray(value) &&
|
|
532
|
+
value.length === 2 &&
|
|
533
|
+
value.every((item) => isTimeStr(item, this.timeFormat) || item === '');
|
|
534
|
+
break;
|
|
535
|
+
}
|
|
536
|
+
if (!isValid) {
|
|
537
|
+
LogUtility.warn(`Invalid time picker value ${value} for ${this.mode} mode`);
|
|
538
|
+
}
|
|
539
|
+
return isValid;
|
|
540
|
+
}
|
|
541
|
+
}
|
|
542
|
+
__decorate$9([
|
|
543
|
+
MapToComponentField({ writable: true })
|
|
544
|
+
], VegaTimePickerValueController.prototype, "value", void 0);
|
|
545
|
+
__decorate$9([
|
|
546
|
+
MapToComponentField()
|
|
547
|
+
], VegaTimePickerValueController.prototype, "mode", void 0);
|
|
548
|
+
__decorate$9([
|
|
549
|
+
MapToComponentField()
|
|
550
|
+
], VegaTimePickerValueController.prototype, "timeFormat", void 0);
|
|
551
|
+
__decorate$9([
|
|
552
|
+
MapToComponentField()
|
|
553
|
+
], VegaTimePickerValueController.prototype, "selectedTimeValue", void 0);
|
|
554
|
+
__decorate$9([
|
|
555
|
+
MapToComponentField()
|
|
556
|
+
], VegaTimePickerValueController.prototype, "increments", void 0);
|
|
557
|
+
__decorate$9([
|
|
558
|
+
MapToComponentField()
|
|
559
|
+
], VegaTimePickerValueController.prototype, "changeEventEmitter", void 0);
|
|
560
|
+
__decorate$9([
|
|
561
|
+
MapToComponentField()
|
|
562
|
+
], VegaTimePickerValueController.prototype, "singleInputRenderer", void 0);
|
|
563
|
+
__decorate$9([
|
|
564
|
+
MapToComponentField()
|
|
565
|
+
], VegaTimePickerValueController.prototype, "rangeInputRenderer", void 0);
|
|
566
|
+
__decorate$9([
|
|
567
|
+
MapToComponentField()
|
|
568
|
+
], VegaTimePickerValueController.prototype, "dropdownSelectedItemsController", void 0);
|
|
569
|
+
__decorate$9([
|
|
570
|
+
MapToComponentField()
|
|
571
|
+
], VegaTimePickerValueController.prototype, "host", void 0);
|
|
572
|
+
__decorate$9([
|
|
573
|
+
MapToComponentMethod('watchValue')
|
|
574
|
+
], VegaTimePickerValueController.prototype, "emitChangeEventOrClearTimePicker", null);
|
|
575
|
+
__decorate$9([
|
|
576
|
+
MapToComponentMethod('watchSelectedTimeValue')
|
|
577
|
+
], VegaTimePickerValueController.prototype, "updateValueIfSelectedItemsChange", null);
|
|
578
|
+
__decorate$9([
|
|
579
|
+
MapToComponentMethod('watchMode')
|
|
580
|
+
], VegaTimePickerValueController.prototype, "resetCurrentValueIfModeChange", null);
|
|
581
|
+
__decorate$9([
|
|
582
|
+
MapToComponentMethod('componentDidLoad')
|
|
583
|
+
], VegaTimePickerValueController.prototype, "checkTheDefaultValueForRangeMode", null);
|
|
584
|
+
|
|
585
|
+
var __decorate$8 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
586
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
587
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
588
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
589
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
590
|
+
};
|
|
591
|
+
/** The `VegaTimePickerDropdownController` class is responsible for managing the dropdown functionality of the VegaTimePicker component in a TypeScript application. */
|
|
592
|
+
class VegaTimePickerSingleDropdownController extends ElementAppenderSlimmer {
|
|
593
|
+
/**
|
|
594
|
+
* The constructor initializes a custom dropdown component with specific configuration options.
|
|
595
|
+
*/
|
|
596
|
+
constructor() {
|
|
597
|
+
super(
|
|
598
|
+
/* istanbul ignore next */
|
|
599
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
600
|
+
() => ({
|
|
601
|
+
target: this.singleInputRenderer.getInputRef(),
|
|
602
|
+
appendableElement: this.singleDropdownRenderer.getDropdownRef(),
|
|
603
|
+
positionRelativeTo: this.positionRelativeTo,
|
|
604
|
+
translocation: { X: 0, Y: 8 },
|
|
605
|
+
placement: ['bottom', 'top'],
|
|
606
|
+
}), () => 'custom');
|
|
607
|
+
}
|
|
608
|
+
/**
|
|
609
|
+
* The function initializes a value controller and dropdown source.
|
|
610
|
+
*/
|
|
611
|
+
initValueAndDropdownSource() {
|
|
612
|
+
this.valueController.resetValue();
|
|
613
|
+
this.initDropdownSource();
|
|
614
|
+
}
|
|
615
|
+
/**
|
|
616
|
+
* The function initializes the dropdown source and input mask configuration, resetting the value
|
|
617
|
+
* controller, initializing the dropdown source, and initializing the input mask configuration.
|
|
618
|
+
*/
|
|
619
|
+
initDropdownSourceAndInputMaskConfig() {
|
|
620
|
+
this.valueController.resetValue();
|
|
621
|
+
this.initDropdownSource();
|
|
622
|
+
this.inputMaskController.initInputMask();
|
|
623
|
+
}
|
|
624
|
+
/**
|
|
625
|
+
* The function initializes the dropdown source and sets the selected items based on a given value.
|
|
626
|
+
*/
|
|
627
|
+
initDropdownSourceAndSelectedItems() {
|
|
628
|
+
this.initDropdownSource();
|
|
629
|
+
if (this.mode === 'single') {
|
|
630
|
+
this.dropdownSelectedItemsController.initSelectedItemsByString(this.value);
|
|
631
|
+
}
|
|
632
|
+
}
|
|
633
|
+
/**
|
|
634
|
+
* The function hides a dropdown when it is disabled.
|
|
635
|
+
*/
|
|
636
|
+
hideDropdownWhenDisabled() {
|
|
637
|
+
if (this.mode === 'single') {
|
|
638
|
+
this.hide();
|
|
639
|
+
}
|
|
640
|
+
}
|
|
641
|
+
/**
|
|
642
|
+
* The function initializes the dropdownSource object with hours and minutes strings.
|
|
643
|
+
*/
|
|
644
|
+
initDropdownSource() {
|
|
645
|
+
this.dropdownSource = {
|
|
646
|
+
hours: this.getSourceHoursStrings(),
|
|
647
|
+
minutes: this.getSourceMinutesStrings(),
|
|
648
|
+
};
|
|
649
|
+
}
|
|
650
|
+
/**
|
|
651
|
+
* The function `getSourceMinutesStrings` generates an array of strings representing minutes in increments specified by the `increments` variable.
|
|
652
|
+
*
|
|
653
|
+
* @returns {string[]} an array of strings.
|
|
654
|
+
*/
|
|
655
|
+
getSourceMinutesStrings() {
|
|
656
|
+
if (this.increments < 1 || this.increments > 59 || isNaN(Number(this.increments))) {
|
|
657
|
+
LogUtility.warn('The increments should be between 1 and 59.');
|
|
658
|
+
this.increments = 1;
|
|
659
|
+
}
|
|
660
|
+
const sourceMinutesStrings = [];
|
|
661
|
+
for (let i = 0; i < 60; i = i + this.increments) {
|
|
662
|
+
sourceMinutesStrings.push(pad(i));
|
|
663
|
+
}
|
|
664
|
+
return sourceMinutesStrings;
|
|
665
|
+
}
|
|
666
|
+
/**
|
|
667
|
+
* The function `getSourceHoursStrings` returns an array of strings representing the hours in either 12-hour or 24-hour format.
|
|
668
|
+
*
|
|
669
|
+
* @returns {string[]} The function `getSourceHoursStrings` returns an array of strings.
|
|
670
|
+
*/
|
|
671
|
+
getSourceHoursStrings() {
|
|
672
|
+
const sourceHoursStrings = [];
|
|
673
|
+
if (this.timeFormat === '12-hour') {
|
|
674
|
+
sourceHoursStrings.push('12');
|
|
675
|
+
for (let i = 1; i < 12; i++) {
|
|
676
|
+
sourceHoursStrings.push(pad(i));
|
|
677
|
+
}
|
|
678
|
+
}
|
|
679
|
+
else {
|
|
680
|
+
for (let i = 0; i < 24; i++) {
|
|
681
|
+
sourceHoursStrings.push(pad(i));
|
|
682
|
+
}
|
|
683
|
+
}
|
|
684
|
+
return sourceHoursStrings;
|
|
685
|
+
}
|
|
686
|
+
}
|
|
687
|
+
__decorate$8([
|
|
688
|
+
MapToComponentField({ writable: true })
|
|
689
|
+
], VegaTimePickerSingleDropdownController.prototype, "isDropdownShow", void 0);
|
|
690
|
+
__decorate$8([
|
|
691
|
+
MapToComponentField({ writable: true })
|
|
692
|
+
], VegaTimePickerSingleDropdownController.prototype, "dropdownSource", void 0);
|
|
693
|
+
__decorate$8([
|
|
694
|
+
MapToComponentField()
|
|
695
|
+
], VegaTimePickerSingleDropdownController.prototype, "mode", void 0);
|
|
696
|
+
__decorate$8([
|
|
697
|
+
MapToComponentField({ writable: true })
|
|
698
|
+
], VegaTimePickerSingleDropdownController.prototype, "increments", void 0);
|
|
699
|
+
__decorate$8([
|
|
700
|
+
MapToComponentField()
|
|
701
|
+
], VegaTimePickerSingleDropdownController.prototype, "timeFormat", void 0);
|
|
702
|
+
__decorate$8([
|
|
703
|
+
MapToComponentField()
|
|
704
|
+
], VegaTimePickerSingleDropdownController.prototype, "value", void 0);
|
|
705
|
+
__decorate$8([
|
|
706
|
+
MapToComponentField()
|
|
707
|
+
], VegaTimePickerSingleDropdownController.prototype, "positionRelativeTo", void 0);
|
|
708
|
+
__decorate$8([
|
|
709
|
+
MapToComponentField()
|
|
710
|
+
], VegaTimePickerSingleDropdownController.prototype, "selectedTimeValue", void 0);
|
|
711
|
+
__decorate$8([
|
|
712
|
+
MapToComponentField()
|
|
713
|
+
], VegaTimePickerSingleDropdownController.prototype, "singleInputRenderer", void 0);
|
|
714
|
+
__decorate$8([
|
|
715
|
+
MapToComponentField()
|
|
716
|
+
], VegaTimePickerSingleDropdownController.prototype, "rangeInputRenderer", void 0);
|
|
717
|
+
__decorate$8([
|
|
718
|
+
MapToComponentField()
|
|
719
|
+
], VegaTimePickerSingleDropdownController.prototype, "singleDropdownRenderer", void 0);
|
|
720
|
+
__decorate$8([
|
|
721
|
+
MapToComponentField()
|
|
722
|
+
], VegaTimePickerSingleDropdownController.prototype, "valueController", void 0);
|
|
723
|
+
__decorate$8([
|
|
724
|
+
MapToComponentField()
|
|
725
|
+
], VegaTimePickerSingleDropdownController.prototype, "dropdownSelectedItemsController", void 0);
|
|
726
|
+
__decorate$8([
|
|
727
|
+
MapToComponentField()
|
|
728
|
+
], VegaTimePickerSingleDropdownController.prototype, "inputMaskController", void 0);
|
|
729
|
+
__decorate$8([
|
|
730
|
+
MapToComponentMethod('watchIncrements')
|
|
731
|
+
], VegaTimePickerSingleDropdownController.prototype, "initValueAndDropdownSource", null);
|
|
732
|
+
__decorate$8([
|
|
733
|
+
MapToComponentMethod('watchTimeFormat')
|
|
734
|
+
], VegaTimePickerSingleDropdownController.prototype, "initDropdownSourceAndInputMaskConfig", null);
|
|
735
|
+
__decorate$8([
|
|
736
|
+
MapToComponentMethod('componentWillLoad')
|
|
737
|
+
], VegaTimePickerSingleDropdownController.prototype, "initDropdownSourceAndSelectedItems", null);
|
|
738
|
+
__decorate$8([
|
|
739
|
+
MapToComponentMethod('watchDisabled')
|
|
740
|
+
], VegaTimePickerSingleDropdownController.prototype, "hideDropdownWhenDisabled", null);
|
|
741
|
+
|
|
742
|
+
var __decorate$7 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
743
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
744
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
745
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
746
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
747
|
+
};
|
|
748
|
+
/** The `VegaTimePickerDropdownSelectedItemsController` class is responsible for managing the selected items in the dropdown of a time picker component. */
|
|
749
|
+
class VegaTimePickerDropdownSelectedItemsController extends VegaSlimmer {
|
|
750
|
+
constructor() {
|
|
751
|
+
super(...arguments);
|
|
752
|
+
this.DROPDOWN_ITEM_DEFAULT_HEIGHT = 32;
|
|
753
|
+
/**
|
|
754
|
+
* The selected fill time is displayed in the dropdown, increments is set to handle the filled minute mismatch option.
|
|
755
|
+
*
|
|
756
|
+
* @param {string} value time picker value
|
|
757
|
+
*/
|
|
758
|
+
this.initSelectedItemsByString = (value) => {
|
|
759
|
+
if (value === '' || !isTimeStr(value, this.timeFormat)) {
|
|
760
|
+
this.selectedTimeValue = {};
|
|
761
|
+
}
|
|
762
|
+
else {
|
|
763
|
+
this.selectedTimeValue = this.getClosetTimeValue(value);
|
|
764
|
+
}
|
|
765
|
+
};
|
|
766
|
+
/*
|
|
767
|
+
* The height of the scroll is based on the default height of the current element 32 * the index of the element.
|
|
768
|
+
* The below method is e2e-test covered in
|
|
769
|
+
* @see{module:vega-time-picker-select-time-e2e}
|
|
770
|
+
* @see{module:vega-time-picker-scroll-top-e2e}
|
|
771
|
+
*/
|
|
772
|
+
/* istanbul ignore next */
|
|
773
|
+
/**
|
|
774
|
+
* scroll the selected item to top
|
|
775
|
+
*
|
|
776
|
+
* @param {HTMLElement} element the element which should scroll to top
|
|
777
|
+
*/
|
|
778
|
+
this.scrollToSelectedElement = (element) => {
|
|
779
|
+
const parentElement = element.closest('ul');
|
|
780
|
+
const scrollTop = Number(element.dataset['index']) * this.DROPDOWN_ITEM_DEFAULT_HEIGHT;
|
|
781
|
+
parentElement.scrollTop = scrollTop;
|
|
782
|
+
};
|
|
783
|
+
/**
|
|
784
|
+
* It is responsible for finding the closest minute value in the dropdown source that is less than or equal to the current minute value.
|
|
785
|
+
*
|
|
786
|
+
* @param {string} currentMinute minute string
|
|
787
|
+
* @returns {string} the minute string which find in list
|
|
788
|
+
*/
|
|
789
|
+
this.getClosestMinuteForCurrent = (currentMinute) => {
|
|
790
|
+
const lessCurrentMinuteStrings = this.dropdownSource.minutes.filter((minute) => Number(minute) <= Number(currentMinute));
|
|
791
|
+
return lessCurrentMinuteStrings[lessCurrentMinuteStrings.length - 1];
|
|
792
|
+
};
|
|
793
|
+
/**
|
|
794
|
+
* It is responsible for getting the current time based on the specified time format (either '12-hour' or '24-hour').
|
|
795
|
+
*
|
|
796
|
+
* @param {TimeFormat} timeFormat time format string
|
|
797
|
+
* @returns {TimeValue} time value object
|
|
798
|
+
*/
|
|
799
|
+
this.getCurrentTime = (timeFormat) => {
|
|
800
|
+
const curHour = new Date(Date.now()).getHours();
|
|
801
|
+
const minute = pad(new Date(Date.now()).getMinutes());
|
|
802
|
+
if (timeFormat === '12-hour') {
|
|
803
|
+
return {
|
|
804
|
+
hour: curHour > 12
|
|
805
|
+
? pad(curHour - 12)
|
|
806
|
+
: pad(curHour === 0 ? 12 : curHour),
|
|
807
|
+
minute: minute,
|
|
808
|
+
amPm: curHour >= 12 ? 'PM' : 'AM',
|
|
809
|
+
};
|
|
810
|
+
}
|
|
811
|
+
else {
|
|
812
|
+
return {
|
|
813
|
+
hour: pad(curHour),
|
|
814
|
+
minute: minute,
|
|
815
|
+
};
|
|
816
|
+
}
|
|
817
|
+
};
|
|
818
|
+
/*
|
|
819
|
+
* The selected element scrolls to the top by default.
|
|
820
|
+
* The below method is e2e-test covered in
|
|
821
|
+
* @see{module:vega-time-picker-select-time-e2e}
|
|
822
|
+
* @see{module:vega-time-picker-scroll-top-e2e}
|
|
823
|
+
*/
|
|
824
|
+
/* istanbul ignore next */
|
|
825
|
+
/** The `selectedElementScrollTop` method is responsible for scrolling the selected element to the top of the dropdown list. */
|
|
826
|
+
this.selectedElementScrollTop = () => {
|
|
827
|
+
const elements = this.mode === 'single'
|
|
828
|
+
? this.singleDropdownRenderer.getSelectedItem()
|
|
829
|
+
: this.rangeDropdownRenderer.getSelectedItem();
|
|
830
|
+
elements.forEach((element) => {
|
|
831
|
+
this.scrollToSelectedElement(element);
|
|
832
|
+
});
|
|
833
|
+
};
|
|
834
|
+
}
|
|
835
|
+
/**
|
|
836
|
+
* The function syncSelectedItemsByValueChange updates the selected items based on a new value, if the value is a valid time string or empty.
|
|
837
|
+
*
|
|
838
|
+
* @param {string} newValue - The `newValue` parameter is a string value that represents the new value that needs to be synchronized with the selected items.
|
|
839
|
+
*/
|
|
840
|
+
syncSelectedItemsByValueChange(newValue) {
|
|
841
|
+
if (this.mode === 'single') {
|
|
842
|
+
if (isTimeStr(newValue, this.timeFormat) || !newValue) {
|
|
843
|
+
this.initSelectedItemsByString(newValue);
|
|
844
|
+
}
|
|
845
|
+
}
|
|
846
|
+
}
|
|
847
|
+
/*
|
|
848
|
+
* The below method is e2e-test covered in
|
|
849
|
+
* @see{module:vega-time-picker-keyboard-control-e2e}
|
|
850
|
+
*/
|
|
851
|
+
/* istanbul ignore next */
|
|
852
|
+
/**
|
|
853
|
+
* The function syncSelectedItemsPositionWhenDropdownShow scrolls the selected element to the top when the dropdown is shown, but only if the dropdown is not disabled.
|
|
854
|
+
*
|
|
855
|
+
* @param {boolean} newValue - A boolean value indicating whether the dropdown is being shown or hidden.
|
|
856
|
+
*/
|
|
857
|
+
syncSelectedItemsPositionWhenDropdownShow(newValue) {
|
|
858
|
+
if (newValue) {
|
|
859
|
+
if (!this.disabled) {
|
|
860
|
+
this.selectedElementScrollTop();
|
|
861
|
+
}
|
|
862
|
+
}
|
|
863
|
+
}
|
|
864
|
+
/**
|
|
865
|
+
* The function syncSelectedItemsPosition checks if there are selected items and scrolls to the
|
|
866
|
+
* selected element if necessary.
|
|
867
|
+
*/
|
|
868
|
+
syncSelectedItemsPosition() {
|
|
869
|
+
if ((this.mode === 'single' && Object.keys(this.selectedTimeValue).length > 0) ||
|
|
870
|
+
(this.mode === 'range' && Array.isArray(this.value) && (this.value[0] || this.value[1]))) {
|
|
871
|
+
this.selectedElementScrollTop();
|
|
872
|
+
}
|
|
873
|
+
}
|
|
874
|
+
/**
|
|
875
|
+
* The function setSelectedItems sets the selectedTimeValue to the provided value.
|
|
876
|
+
*
|
|
877
|
+
* @param {TimeValue} value - The value parameter is of type TimeValue.
|
|
878
|
+
*/
|
|
879
|
+
setSelectedItems(value) {
|
|
880
|
+
this.selectedTimeValue = value;
|
|
881
|
+
}
|
|
882
|
+
/**
|
|
883
|
+
* The function "setSelectedItemsToCurrentTime" sets the selectedTimeValue to the current time in the specified time format.
|
|
884
|
+
*/
|
|
885
|
+
setSelectedItemsToCurrentTime() {
|
|
886
|
+
this.selectedTimeValue = this.getCurrentTime(this.timeFormat);
|
|
887
|
+
}
|
|
888
|
+
/**
|
|
889
|
+
* The getClosetTimeValue function takes a current time string and returns an object with the hour, minute, and amPm values.
|
|
890
|
+
*
|
|
891
|
+
* @param {string} currentTime - The `currentTime` parameter is a string representing the current time. It should be in the format "HH:mm" for 24-hour format or "HH:mm AM/PM" for 12-hour format.
|
|
892
|
+
* @returns {TimeValue} an object of type TimeValue.
|
|
893
|
+
*/
|
|
894
|
+
getClosetTimeValue(currentTime) {
|
|
895
|
+
const timeArray = currentTime.replace(' ', ':').split(':');
|
|
896
|
+
return {
|
|
897
|
+
hour: timeArray[0],
|
|
898
|
+
minute: this.increments > 1 ? this.getClosestMinuteForCurrent(timeArray[1]) : timeArray[1],
|
|
899
|
+
amPm: this.timeFormat === '12-hour' ? timeArray[2] : undefined,
|
|
900
|
+
};
|
|
901
|
+
}
|
|
902
|
+
}
|
|
903
|
+
__decorate$7([
|
|
904
|
+
MapToComponentField({ writable: true })
|
|
905
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "selectedTimeValue", void 0);
|
|
906
|
+
__decorate$7([
|
|
907
|
+
MapToComponentField()
|
|
908
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "mode", void 0);
|
|
909
|
+
__decorate$7([
|
|
910
|
+
MapToComponentField()
|
|
911
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "value", void 0);
|
|
912
|
+
__decorate$7([
|
|
913
|
+
MapToComponentField()
|
|
914
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "timeFormat", void 0);
|
|
915
|
+
__decorate$7([
|
|
916
|
+
MapToComponentField()
|
|
917
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "dropdownSource", void 0);
|
|
918
|
+
__decorate$7([
|
|
919
|
+
MapToComponentField()
|
|
920
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "increments", void 0);
|
|
921
|
+
__decorate$7([
|
|
922
|
+
MapToComponentField()
|
|
923
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "disabled", void 0);
|
|
924
|
+
__decorate$7([
|
|
925
|
+
MapToComponentField()
|
|
926
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "singleDropdownRenderer", void 0);
|
|
927
|
+
__decorate$7([
|
|
928
|
+
MapToComponentField()
|
|
929
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "rangeDropdownRenderer", void 0);
|
|
930
|
+
__decorate$7([
|
|
931
|
+
MapToComponentMethod('watchValue')
|
|
932
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "syncSelectedItemsByValueChange", null);
|
|
933
|
+
__decorate$7([
|
|
934
|
+
MapToComponentMethod('watchIsDropdownShow')
|
|
935
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "syncSelectedItemsPositionWhenDropdownShow", null);
|
|
936
|
+
__decorate$7([
|
|
937
|
+
MapToComponentMethod('componentDidRender')
|
|
938
|
+
], VegaTimePickerDropdownSelectedItemsController.prototype, "syncSelectedItemsPosition", null);
|
|
939
|
+
|
|
940
|
+
var __decorate$6 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
941
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
942
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
943
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
944
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
945
|
+
};
|
|
946
|
+
/** The `VegaTimePickerKeyboardController` class is a TypeScript class that extends the `KeyboardManagerSlimmer` class and provides keyboard control functionality for a time picker component. */
|
|
947
|
+
class VegaTimePickerKeyboardController extends KeyboardManagerSlimmer {
|
|
948
|
+
/**
|
|
949
|
+
* The constructor function sets up keyboard event listeners for a time picker component.
|
|
950
|
+
*/
|
|
951
|
+
constructor() {
|
|
952
|
+
/*
|
|
953
|
+
* The below method is e2e-test covered in
|
|
954
|
+
* @see{module:vega-time-picker-keyboard-control-e2e}
|
|
955
|
+
*/
|
|
956
|
+
/* istanbul ignore next */
|
|
957
|
+
super((target) => {
|
|
958
|
+
const dropdownRef = target.singleDropdownRenderer.getDropdownRef();
|
|
959
|
+
const startDropdownRef = target.rangeDropdownRenderer.getStartDropdownRef();
|
|
960
|
+
const endDropdownRef = target.rangeDropdownRenderer.getEndDropdownRef();
|
|
961
|
+
return [
|
|
962
|
+
{
|
|
963
|
+
keyCode: 'Enter',
|
|
964
|
+
activeElementInScope: [target.host],
|
|
965
|
+
callback: target.componentBlurAndHideDropdown,
|
|
966
|
+
},
|
|
967
|
+
{
|
|
968
|
+
keyCode: ['ArrowUp', 'ArrowDown'],
|
|
969
|
+
activeElementInScope: [dropdownRef, startDropdownRef, endDropdownRef],
|
|
970
|
+
/**
|
|
971
|
+
* switch the element focus when keyboard press
|
|
972
|
+
*
|
|
973
|
+
* @param {KeyboardEvent} event event object
|
|
974
|
+
*/
|
|
975
|
+
callback: /* istanbul ignore next */ (event) => {
|
|
976
|
+
target.switchHourOrMinuteFocus(event);
|
|
977
|
+
},
|
|
978
|
+
},
|
|
979
|
+
{
|
|
980
|
+
keyCode: 'Escape',
|
|
981
|
+
activeElementInScope: [target.host, dropdownRef, startDropdownRef, endDropdownRef],
|
|
982
|
+
callback: target.componentBlurAndHideDropdown,
|
|
983
|
+
},
|
|
984
|
+
];
|
|
985
|
+
});
|
|
986
|
+
/* istanbul ignore next */
|
|
987
|
+
/**
|
|
988
|
+
* It is an asynchronous method that is used to blur the input field and hide the dropdown of the time picker component.
|
|
989
|
+
*/
|
|
990
|
+
this.componentBlurAndHideDropdown = async () => {
|
|
991
|
+
if (this.mode === 'single') {
|
|
992
|
+
await this.singleInputRenderer.getInputRef().doBlur();
|
|
993
|
+
this.singleDropdownController.hide();
|
|
994
|
+
}
|
|
995
|
+
else {
|
|
996
|
+
await this.rangeInputRenderer.getStartInputRef().doBlur();
|
|
997
|
+
await this.rangeInputRenderer.getEndInputRef().doBlur();
|
|
998
|
+
this.startDropdownController.hide();
|
|
999
|
+
this.endDropdownController.hide();
|
|
1000
|
+
}
|
|
1001
|
+
};
|
|
1002
|
+
}
|
|
1003
|
+
/*
|
|
1004
|
+
* The below method is e2e-test covered in
|
|
1005
|
+
* @see{module:vega-time-picker-keyboard-up-down-control-e2e}
|
|
1006
|
+
*/
|
|
1007
|
+
/* istanbul ignore next */
|
|
1008
|
+
/**
|
|
1009
|
+
* It is used to switch the focus between different elements based on the arrow key pressed.
|
|
1010
|
+
*
|
|
1011
|
+
* @param {KeyboardEvent} event the event of target
|
|
1012
|
+
*/
|
|
1013
|
+
switchHourOrMinuteFocus(event) {
|
|
1014
|
+
const keyCode = event.key;
|
|
1015
|
+
const activeElement = event.composedPath()[0];
|
|
1016
|
+
let nextActiveElement = null;
|
|
1017
|
+
if (activeElement.tagName === 'LI' && activeElement.getAttribute('role') === 'menuitem') {
|
|
1018
|
+
nextActiveElement =
|
|
1019
|
+
keyCode === 'ArrowDown'
|
|
1020
|
+
? activeElement.nextElementSibling
|
|
1021
|
+
: activeElement.previousElementSibling;
|
|
1022
|
+
}
|
|
1023
|
+
if (nextActiveElement) {
|
|
1024
|
+
nextActiveElement.focus();
|
|
1025
|
+
}
|
|
1026
|
+
}
|
|
1027
|
+
}
|
|
1028
|
+
__decorate$6([
|
|
1029
|
+
MapToComponentField()
|
|
1030
|
+
], VegaTimePickerKeyboardController.prototype, "host", void 0);
|
|
1031
|
+
__decorate$6([
|
|
1032
|
+
MapToComponentField()
|
|
1033
|
+
], VegaTimePickerKeyboardController.prototype, "mode", void 0);
|
|
1034
|
+
__decorate$6([
|
|
1035
|
+
MapToComponentField()
|
|
1036
|
+
], VegaTimePickerKeyboardController.prototype, "singleInputRenderer", void 0);
|
|
1037
|
+
__decorate$6([
|
|
1038
|
+
MapToComponentField()
|
|
1039
|
+
], VegaTimePickerKeyboardController.prototype, "singleDropdownRenderer", void 0);
|
|
1040
|
+
__decorate$6([
|
|
1041
|
+
MapToComponentField()
|
|
1042
|
+
], VegaTimePickerKeyboardController.prototype, "rangeDropdownRenderer", void 0);
|
|
1043
|
+
__decorate$6([
|
|
1044
|
+
MapToComponentField()
|
|
1045
|
+
], VegaTimePickerKeyboardController.prototype, "rangeInputRenderer", void 0);
|
|
1046
|
+
__decorate$6([
|
|
1047
|
+
MapToComponentField()
|
|
1048
|
+
], VegaTimePickerKeyboardController.prototype, "singleDropdownController", void 0);
|
|
1049
|
+
__decorate$6([
|
|
1050
|
+
MapToComponentField()
|
|
1051
|
+
], VegaTimePickerKeyboardController.prototype, "startDropdownController", void 0);
|
|
1052
|
+
__decorate$6([
|
|
1053
|
+
MapToComponentField()
|
|
1054
|
+
], VegaTimePickerKeyboardController.prototype, "endDropdownController", void 0);
|
|
1055
|
+
|
|
1056
|
+
var __decorate$5 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
1057
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
1058
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
1059
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
1060
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
1061
|
+
};
|
|
1062
|
+
/** The `VegaTimePickerRangeInputRenderer` class is a TypeScript React component that renders a range input for selecting start and end times. */
|
|
1063
|
+
class VegaTimePickerRangeInputRenderer extends VegaSlimmer {
|
|
1064
|
+
constructor() {
|
|
1065
|
+
super(...arguments);
|
|
1066
|
+
this.isMobileDevice = getDeviceType() === DeviceType.MOBILE;
|
|
1067
|
+
this.onInputChange = (e) => {
|
|
1068
|
+
const target = e.host;
|
|
1069
|
+
if (target.parentElement.classList.contains('time-picker-input-start')) {
|
|
1070
|
+
this.valueController.updateValueByRangeType(e.detail, 'start');
|
|
1071
|
+
}
|
|
1072
|
+
else {
|
|
1073
|
+
this.valueController.updateValueByRangeType(e.detail, 'end');
|
|
1074
|
+
}
|
|
1075
|
+
};
|
|
1076
|
+
/*
|
|
1077
|
+
* The below method is e2e-test covered in
|
|
1078
|
+
* @see{module:vega-time-picker-range-input-focus}
|
|
1079
|
+
*/
|
|
1080
|
+
/* istanbul ignore next */
|
|
1081
|
+
/**
|
|
1082
|
+
* an event handler that is triggered when the input field of the time picker component receives focus.
|
|
1083
|
+
*
|
|
1084
|
+
* @param {CustomEvent} e event object
|
|
1085
|
+
*/
|
|
1086
|
+
this.timePickerInputFocus = (e) => {
|
|
1087
|
+
const target = e.host;
|
|
1088
|
+
const value = Array.isArray(this.value) ? this.value : ['', ''];
|
|
1089
|
+
if (target.parentElement.classList.contains('time-picker-input-start')) {
|
|
1090
|
+
this.startDropdownController.showAndScrollPosition(value[0]);
|
|
1091
|
+
}
|
|
1092
|
+
else {
|
|
1093
|
+
this.endDropdownController.showAndScrollPosition(value[1] ? value[1] : value[0]);
|
|
1094
|
+
}
|
|
1095
|
+
};
|
|
1096
|
+
/* istanbul ignore next */
|
|
1097
|
+
/**
|
|
1098
|
+
* an event handler that is triggered when the input field of the time picker component receives blur.
|
|
1099
|
+
*
|
|
1100
|
+
* @param {CustomEvent} e event object
|
|
1101
|
+
*/
|
|
1102
|
+
this.timePickerInputBlur = (e) => {
|
|
1103
|
+
const target = e.host;
|
|
1104
|
+
const rangeIndex = target.parentElement.classList.contains('time-picker-input-start')
|
|
1105
|
+
? 'start'
|
|
1106
|
+
: 'end';
|
|
1107
|
+
if (!isTimeStr(target.value, this.timeFormat)) {
|
|
1108
|
+
target.value = '';
|
|
1109
|
+
this.valueController.updateValueByRangeType('', rangeIndex);
|
|
1110
|
+
}
|
|
1111
|
+
else if (target.value && this.increments > 1) {
|
|
1112
|
+
const { hour, minute, amPm } = this.dropdownSelectedItemsController.getClosetTimeValue(target.value);
|
|
1113
|
+
target.value = `${hour}:${minute}${amPm ? ' ' + amPm : ''}`;
|
|
1114
|
+
}
|
|
1115
|
+
};
|
|
1116
|
+
}
|
|
1117
|
+
/**
|
|
1118
|
+
* The function returns a reference to the start time input element.
|
|
1119
|
+
*
|
|
1120
|
+
* @returns {HTMLVegaInputElement} The method is returning an HTMLVegaInputElement.
|
|
1121
|
+
*/
|
|
1122
|
+
getStartInputRef() {
|
|
1123
|
+
return this.startTimeInputRef;
|
|
1124
|
+
}
|
|
1125
|
+
/**
|
|
1126
|
+
* The function returns a reference to the end time input element.
|
|
1127
|
+
*
|
|
1128
|
+
* @returns {HTMLVegaInputElement} The method is returning an HTMLVegaInputElement.
|
|
1129
|
+
*/
|
|
1130
|
+
getEndInputRef() {
|
|
1131
|
+
return this.endTimeInputRef;
|
|
1132
|
+
}
|
|
1133
|
+
/* istanbul ignore next */
|
|
1134
|
+
render() {
|
|
1135
|
+
const startValue = Array.isArray(this.value) ? this.value[0] : '';
|
|
1136
|
+
const endValue = Array.isArray(this.value) ? this.value[1] : '';
|
|
1137
|
+
return (h(Fragment, null,
|
|
1138
|
+
h("vega-flex", { class: "v-w-full", gap: "0", "align-items": "center", direction: this.isMobileDevice ? 'col' : 'row' },
|
|
1139
|
+
h("div", { class: "time-picker-input time-picker-input-start vega-flex-basis-0 vega-flex-grow" },
|
|
1140
|
+
h("vega-input", { "prefix-icon": "clock-face", placeholder: this.getPlaceholderBySourceType('start'), disabled: this.disabled, size: this.size, value: startValue, ref: (ref) => {
|
|
1141
|
+
this.handlerEvent(ref);
|
|
1142
|
+
return (this.startTimeInputRef = ref);
|
|
1143
|
+
}, "show-clear-icon": "false" })),
|
|
1144
|
+
h("span", { class: "range-input-divider v-min-w-min vega-flex-shrink-0" }),
|
|
1145
|
+
h("div", { class: "time-picker-input time-picker-input-end vega-flex-basis-0 vega-flex-grow" },
|
|
1146
|
+
h("vega-input", { placeholder: this.getPlaceholderBySourceType('end'), disabled: this.disabled, size: this.size, value: endValue, ref: (ref) => {
|
|
1147
|
+
this.handlerEvent(ref);
|
|
1148
|
+
return (this.endTimeInputRef = ref);
|
|
1149
|
+
}, "show-clear-icon": "false" }))),
|
|
1150
|
+
this.rangeClearButtonRenderer.render()));
|
|
1151
|
+
}
|
|
1152
|
+
handlerEvent(ref) {
|
|
1153
|
+
DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaBlur, (input) => {
|
|
1154
|
+
this.timePickerInputBlur(input);
|
|
1155
|
+
});
|
|
1156
|
+
DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaChange, (input) => {
|
|
1157
|
+
this.onInputChange(input);
|
|
1158
|
+
});
|
|
1159
|
+
DomNodeSubjectObserverFactory.addUniqueObserverToNode(ref, VegaFocus, (input) => {
|
|
1160
|
+
this.timePickerInputFocus(input);
|
|
1161
|
+
});
|
|
1162
|
+
}
|
|
1163
|
+
/**
|
|
1164
|
+
* get input placeholder by input source type
|
|
1165
|
+
*
|
|
1166
|
+
* @param {TimeRangeIndex} rangeIndex start or end input
|
|
1167
|
+
* @returns {string} a string value
|
|
1168
|
+
*/
|
|
1169
|
+
getPlaceholderBySourceType(rangeIndex) {
|
|
1170
|
+
if (rangeIndex === 'start') {
|
|
1171
|
+
return Array.isArray(this.placeholder) && this.placeholder[0]
|
|
1172
|
+
? this.placeholder[0]
|
|
1173
|
+
: this.translationSlimmer.t('Start Time');
|
|
1174
|
+
}
|
|
1175
|
+
else {
|
|
1176
|
+
return Array.isArray(this.placeholder) && this.placeholder[1]
|
|
1177
|
+
? this.placeholder[1]
|
|
1178
|
+
: this.translationSlimmer.t('End Time');
|
|
1179
|
+
}
|
|
1180
|
+
}
|
|
1181
|
+
}
|
|
1182
|
+
__decorate$5([
|
|
1183
|
+
MapToComponentField()
|
|
1184
|
+
], VegaTimePickerRangeInputRenderer.prototype, "mode", void 0);
|
|
1185
|
+
__decorate$5([
|
|
1186
|
+
MapToComponentField()
|
|
1187
|
+
], VegaTimePickerRangeInputRenderer.prototype, "placeholder", void 0);
|
|
1188
|
+
__decorate$5([
|
|
1189
|
+
MapToComponentField()
|
|
1190
|
+
], VegaTimePickerRangeInputRenderer.prototype, "disabled", void 0);
|
|
1191
|
+
__decorate$5([
|
|
1192
|
+
MapToComponentField()
|
|
1193
|
+
], VegaTimePickerRangeInputRenderer.prototype, "size", void 0);
|
|
1194
|
+
__decorate$5([
|
|
1195
|
+
MapToComponentField()
|
|
1196
|
+
], VegaTimePickerRangeInputRenderer.prototype, "positionRelativeTo", void 0);
|
|
1197
|
+
__decorate$5([
|
|
1198
|
+
MapToComponentField()
|
|
1199
|
+
], VegaTimePickerRangeInputRenderer.prototype, "timeFormat", void 0);
|
|
1200
|
+
__decorate$5([
|
|
1201
|
+
MapToComponentField()
|
|
1202
|
+
], VegaTimePickerRangeInputRenderer.prototype, "increments", void 0);
|
|
1203
|
+
__decorate$5([
|
|
1204
|
+
MapToComponentField()
|
|
1205
|
+
], VegaTimePickerRangeInputRenderer.prototype, "value", void 0);
|
|
1206
|
+
__decorate$5([
|
|
1207
|
+
MapToComponentField()
|
|
1208
|
+
], VegaTimePickerRangeInputRenderer.prototype, "startDropdownController", void 0);
|
|
1209
|
+
__decorate$5([
|
|
1210
|
+
MapToComponentField()
|
|
1211
|
+
], VegaTimePickerRangeInputRenderer.prototype, "endDropdownController", void 0);
|
|
1212
|
+
__decorate$5([
|
|
1213
|
+
MapToComponentField()
|
|
1214
|
+
], VegaTimePickerRangeInputRenderer.prototype, "valueController", void 0);
|
|
1215
|
+
__decorate$5([
|
|
1216
|
+
MapToComponentField()
|
|
1217
|
+
], VegaTimePickerRangeInputRenderer.prototype, "rangeClearButtonRenderer", void 0);
|
|
1218
|
+
__decorate$5([
|
|
1219
|
+
MapToComponentField()
|
|
1220
|
+
], VegaTimePickerRangeInputRenderer.prototype, "rangeDropdownRenderer", void 0);
|
|
1221
|
+
__decorate$5([
|
|
1222
|
+
MapToComponentField()
|
|
1223
|
+
], VegaTimePickerRangeInputRenderer.prototype, "dropdownSelectedItemsController", void 0);
|
|
1224
|
+
__decorate$5([
|
|
1225
|
+
MapToComponentField()
|
|
1226
|
+
], VegaTimePickerRangeInputRenderer.prototype, "translationSlimmer", void 0);
|
|
1227
|
+
|
|
1228
|
+
var __decorate$4 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
1229
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
1230
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
1231
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
1232
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
1233
|
+
};
|
|
1234
|
+
/** The `VegaTimePickerRangeDropdownRenderer` class is a TypeScript React component that renders a dropdown for selecting a range of time values. */
|
|
1235
|
+
class VegaTimePickerRangeDropdownRenderer extends VegaSlimmer {
|
|
1236
|
+
constructor() {
|
|
1237
|
+
super(...arguments);
|
|
1238
|
+
this.isMobileDevice = getDeviceType() === DeviceType.MOBILE;
|
|
1239
|
+
this.isTabletDevice = getDeviceType() === DeviceType.TABLET;
|
|
1240
|
+
/** The `renderStartDropdown` method is a private method of the `VegaTimePickerRangeDropdownRenderer` class. It is responsible for rendering the start dropdown element in the component's JSX. */
|
|
1241
|
+
this.renderStartDropdown = () => {
|
|
1242
|
+
return (h("vega-time-picker-dropdown", { class: {
|
|
1243
|
+
'vega-time-picker-dropdown start-dropdown': true,
|
|
1244
|
+
/* istanbul ignore next */
|
|
1245
|
+
'mobile': this.isMobileDevice,
|
|
1246
|
+
'tablet': this.isTabletDevice,
|
|
1247
|
+
}, ref: (e) => (this.startDropdown = e) },
|
|
1248
|
+
h("div", { class: "vega-time-picker-dropdown-container", ref: (e) => (this.startDropdownContainer = e) },
|
|
1249
|
+
h("div", { class: "vega-time-picker-dropdown-panel" }, this.renderDropdownList('start')))));
|
|
1250
|
+
};
|
|
1251
|
+
/** The `renderEndDropdown` method is a private method of the `VegaTimePickerRangeDropdownRenderer` class. It is responsible for rendering the end dropdown element in the component's JSX. */
|
|
1252
|
+
this.renderEndDropdown = () => {
|
|
1253
|
+
return (h("vega-time-picker-dropdown", { class: {
|
|
1254
|
+
'vega-time-picker-dropdown end-dropdown': true,
|
|
1255
|
+
/* istanbul ignore next */
|
|
1256
|
+
'mobile': this.isMobileDevice,
|
|
1257
|
+
'tablet': this.isTabletDevice,
|
|
1258
|
+
}, ref: (e) => (this.endDropdown = e) },
|
|
1259
|
+
h("div", { class: "vega-time-picker-dropdown-container", ref: (e) => (this.endDropdownContainer = e) },
|
|
1260
|
+
h("div", { class: "vega-time-picker-dropdown-panel" }, this.renderDropdownList('end')))));
|
|
1261
|
+
};
|
|
1262
|
+
/** The `renderDropdownList` method is a private method of the `VegaTimePickerRangeDropdownRenderer` class. It is responsible for rendering the dropdown list of time values in the component's JSX. */
|
|
1263
|
+
this.renderDropdownList = (rangeIndex) => {
|
|
1264
|
+
const source = this.getTimeArray();
|
|
1265
|
+
return (h("ul", { role: "menu", "aria-label": "dropdown-ul", class: {
|
|
1266
|
+
'vega-time-picker-panel-column': true,
|
|
1267
|
+
} }, source.map((item, index) => {
|
|
1268
|
+
{
|
|
1269
|
+
return this.renderDropdownItem(item, rangeIndex, index);
|
|
1270
|
+
}
|
|
1271
|
+
})));
|
|
1272
|
+
};
|
|
1273
|
+
}
|
|
1274
|
+
/**
|
|
1275
|
+
* Component lifecycle - [componentDidRender]{@link VegaTimePicker.componentDidRender}
|
|
1276
|
+
*/
|
|
1277
|
+
componentDidRenderCallback() {
|
|
1278
|
+
if (this.startDropdownContainer && this.startDropdownContainer.parentElement === this.startDropdown) {
|
|
1279
|
+
this.startDropdown.shadowRoot.append(this.startDropdownContainer);
|
|
1280
|
+
}
|
|
1281
|
+
if (this.endDropdownContainer && this.endDropdownContainer.parentElement === this.endDropdown) {
|
|
1282
|
+
this.endDropdown.shadowRoot.append(this.endDropdownContainer);
|
|
1283
|
+
}
|
|
1284
|
+
}
|
|
1285
|
+
/**
|
|
1286
|
+
* The function returns a reference to the startDropdown element.
|
|
1287
|
+
*
|
|
1288
|
+
* @returns {HTMLElement} the startDropdown element, which is of type HTMLElement.
|
|
1289
|
+
*/
|
|
1290
|
+
getStartDropdownRef() {
|
|
1291
|
+
return this.startDropdown;
|
|
1292
|
+
}
|
|
1293
|
+
/**
|
|
1294
|
+
* The function returns a reference to the endDropdown element.
|
|
1295
|
+
*
|
|
1296
|
+
* @returns {HTMLElement} the startDropdown element, which is of type HTMLElement.
|
|
1297
|
+
*/
|
|
1298
|
+
getEndDropdownRef() {
|
|
1299
|
+
return this.endDropdown;
|
|
1300
|
+
}
|
|
1301
|
+
/**
|
|
1302
|
+
* The function returns the selected elements. If elements is empty, it returns the first option by default.
|
|
1303
|
+
*
|
|
1304
|
+
* @returns {HTMLElement[]} returns an array of HTMLElements.
|
|
1305
|
+
*/
|
|
1306
|
+
getSelectedItem() {
|
|
1307
|
+
const startDropdown = this.startDropdown.shadowRoot;
|
|
1308
|
+
const endDropdown = this.endDropdown.shadowRoot;
|
|
1309
|
+
let elements = [
|
|
1310
|
+
startDropdown.querySelector('.vega-dropdown-item-selected'),
|
|
1311
|
+
endDropdown.querySelector('.vega-dropdown-item-selected'),
|
|
1312
|
+
].filter(isNonNullable);
|
|
1313
|
+
if (elements.length === 0) {
|
|
1314
|
+
elements = [
|
|
1315
|
+
startDropdown.querySelector('.vega-time-picker-dropdown-panel li:first-child'),
|
|
1316
|
+
endDropdown.querySelector('.vega-time-picker-dropdown-panel li:first-child'),
|
|
1317
|
+
].filter(isNonNullable);
|
|
1318
|
+
}
|
|
1319
|
+
return elements;
|
|
1320
|
+
}
|
|
1321
|
+
render() {
|
|
1322
|
+
return (h(Fragment, null,
|
|
1323
|
+
this.renderStartDropdown(),
|
|
1324
|
+
this.renderEndDropdown()));
|
|
1325
|
+
}
|
|
1326
|
+
/*
|
|
1327
|
+
* The below method is e2e-test covered in
|
|
1328
|
+
* @see{module:vega-time-picker-range-dropdown-item-click}
|
|
1329
|
+
*/
|
|
1330
|
+
/* istanbul ignore next */
|
|
1331
|
+
/** The `renderDropdownItem` method is responsible for rendering each item in the dropdown list of time values. It creates an `<li>` element with the following attributes and event handlers: */
|
|
1332
|
+
renderDropdownItem(item, rangeIndex, index) {
|
|
1333
|
+
return (h("li", { key: item, role: "menuitem", "aria-label": item, class: {
|
|
1334
|
+
'vega-dropdown-item-selected': this.isItemSelected(item, rangeIndex),
|
|
1335
|
+
}, tabIndex: index === 0 ? 0 : -1, "data-index": index,
|
|
1336
|
+
/* eslint-disable-next-line react/jsx-no-bind */
|
|
1337
|
+
onClick: () => this.onItemClick(item, rangeIndex), onKeyDown: createEnterKeyHandlerToTriggerClick() },
|
|
1338
|
+
h("span", { "data-index": index, innerHTML: item })));
|
|
1339
|
+
}
|
|
1340
|
+
/*
|
|
1341
|
+
* The below method is e2e-test covered in
|
|
1342
|
+
* @see{module:vega-time-picker-range-dropdown-item-click}
|
|
1343
|
+
*/
|
|
1344
|
+
/* istanbul ignore next */
|
|
1345
|
+
/**
|
|
1346
|
+
* It is called when a dropdown item is clicked.
|
|
1347
|
+
*
|
|
1348
|
+
* @param {string} item time string
|
|
1349
|
+
* @param {TimeRangeIndex} rangeIndex start or end
|
|
1350
|
+
*/
|
|
1351
|
+
onItemClick(item, rangeIndex) {
|
|
1352
|
+
this.valueController.updateValueByRangeType(item, rangeIndex);
|
|
1353
|
+
if (rangeIndex === 'start') {
|
|
1354
|
+
this.startDropdownController.hide();
|
|
1355
|
+
void this.rangeInputRenderer.getEndInputRef().doFocus();
|
|
1356
|
+
}
|
|
1357
|
+
else {
|
|
1358
|
+
this.endDropdownController.hide();
|
|
1359
|
+
}
|
|
1360
|
+
}
|
|
1361
|
+
/**
|
|
1362
|
+
* It is used to determine if a dropdown item is currently selected or not.
|
|
1363
|
+
*
|
|
1364
|
+
* @param {string} item time string
|
|
1365
|
+
* @param {TimeRangeIndex} rangeIndex start or end
|
|
1366
|
+
* @returns {boolean} a boolean value
|
|
1367
|
+
*/
|
|
1368
|
+
isItemSelected(item, rangeIndex) {
|
|
1369
|
+
/* istanbul ignore next */
|
|
1370
|
+
const valueArr = this.value && Array.isArray(this.value) ? this.value : ['', ''];
|
|
1371
|
+
if (rangeIndex === 'start' && valueArr[0] === item) {
|
|
1372
|
+
return true;
|
|
1373
|
+
}
|
|
1374
|
+
else if (rangeIndex === 'end' && valueArr[1] === item) {
|
|
1375
|
+
return true;
|
|
1376
|
+
}
|
|
1377
|
+
return false;
|
|
1378
|
+
}
|
|
1379
|
+
/**
|
|
1380
|
+
* The `getTimeArray` method is a private method of the `VegaTimePickerRangeDropdownRenderer` class.
|
|
1381
|
+
* It is responsible for generating an array of time values based on the `hours` and `minutes` provided in the `dropdownSource` property.
|
|
1382
|
+
*
|
|
1383
|
+
* @returns {string[]} all selectable time list
|
|
1384
|
+
*/
|
|
1385
|
+
getTimeArray() {
|
|
1386
|
+
const result = [];
|
|
1387
|
+
const resultWithPM = [];
|
|
1388
|
+
const resultWithAM = [];
|
|
1389
|
+
const timeFormat = this.timeFormat;
|
|
1390
|
+
const { hours, minutes } = this.dropdownSource;
|
|
1391
|
+
if (this.dropdownSource) {
|
|
1392
|
+
for (let i = 0; i < hours.length; i++) {
|
|
1393
|
+
for (let j = 0; j < minutes.length; j++) {
|
|
1394
|
+
const item = `${hours[i]}:${minutes[j]}`;
|
|
1395
|
+
result.push(item);
|
|
1396
|
+
if (timeFormat === '12-hour') {
|
|
1397
|
+
resultWithAM.push(item + ' AM');
|
|
1398
|
+
resultWithPM.push(item + ' PM');
|
|
1399
|
+
}
|
|
1400
|
+
}
|
|
1401
|
+
}
|
|
1402
|
+
}
|
|
1403
|
+
if (timeFormat === '12-hour') {
|
|
1404
|
+
return resultWithAM.concat(resultWithPM);
|
|
1405
|
+
}
|
|
1406
|
+
return result;
|
|
1407
|
+
}
|
|
1408
|
+
}
|
|
1409
|
+
__decorate$4([
|
|
1410
|
+
MapToComponentField()
|
|
1411
|
+
], VegaTimePickerRangeDropdownRenderer.prototype, "timeFormat", void 0);
|
|
1412
|
+
__decorate$4([
|
|
1413
|
+
MapToComponentField()
|
|
1414
|
+
], VegaTimePickerRangeDropdownRenderer.prototype, "value", void 0);
|
|
1415
|
+
__decorate$4([
|
|
1416
|
+
MapToComponentField()
|
|
1417
|
+
], VegaTimePickerRangeDropdownRenderer.prototype, "dropdownSource", void 0);
|
|
1418
|
+
__decorate$4([
|
|
1419
|
+
MapToComponentField()
|
|
1420
|
+
], VegaTimePickerRangeDropdownRenderer.prototype, "valueController", void 0);
|
|
1421
|
+
__decorate$4([
|
|
1422
|
+
MapToComponentField()
|
|
1423
|
+
], VegaTimePickerRangeDropdownRenderer.prototype, "rangeInputRenderer", void 0);
|
|
1424
|
+
__decorate$4([
|
|
1425
|
+
MapToComponentField()
|
|
1426
|
+
], VegaTimePickerRangeDropdownRenderer.prototype, "startDropdownController", void 0);
|
|
1427
|
+
__decorate$4([
|
|
1428
|
+
MapToComponentField()
|
|
1429
|
+
], VegaTimePickerRangeDropdownRenderer.prototype, "endDropdownController", void 0);
|
|
1430
|
+
__decorate$4([
|
|
1431
|
+
MapToComponentMethod('componentDidRender')
|
|
1432
|
+
], VegaTimePickerRangeDropdownRenderer.prototype, "componentDidRenderCallback", null);
|
|
1433
|
+
|
|
1434
|
+
var __decorate$3 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
1435
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
1436
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
1437
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
1438
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
1439
|
+
};
|
|
1440
|
+
/* The code is defining a class called `VegaTimePickerRangeClearButtonRenderer` that extends the `VegaSlimmer` class. This class is used to render a clear button for a time picker range component. */
|
|
1441
|
+
class VegaTimePickerRangeClearButtonRenderer extends VegaSlimmer {
|
|
1442
|
+
constructor() {
|
|
1443
|
+
super(...arguments);
|
|
1444
|
+
/** The `onClickClearIcon` function is a private method that is called when the clear icon is clicked. It performs the following actions: */
|
|
1445
|
+
this.onClickClearIcon = () => {
|
|
1446
|
+
this.valueController.clearRangeTimePicker();
|
|
1447
|
+
this.endDropdownController.hide();
|
|
1448
|
+
void this.rangeInputRenderer.getStartInputRef().doFocus();
|
|
1449
|
+
};
|
|
1450
|
+
}
|
|
1451
|
+
render() {
|
|
1452
|
+
return (h("div", { class: {
|
|
1453
|
+
'vega-time-picker-range-clear-icon': true,
|
|
1454
|
+
'invisible': !this.isInvisible(),
|
|
1455
|
+
}, "aria-label": "clear input", role: "button", tabindex: !this.disabled ? 0 : -1, onClick: this.onClickClearIcon, onKeyDown: createEnterKeyHandlerToTriggerClick() },
|
|
1456
|
+
h("vega-icon", { icon: "close", class: "v-min-w-min vega-flex-shrink-0" })));
|
|
1457
|
+
}
|
|
1458
|
+
/**
|
|
1459
|
+
* The function checks if the value is an array and if either of the elements in the array is truthy, returning true if so.
|
|
1460
|
+
*
|
|
1461
|
+
* @returns {boolean} a boolean value.
|
|
1462
|
+
*/
|
|
1463
|
+
isInvisible() {
|
|
1464
|
+
return (!this.disabled && Array.isArray(this.value) && (Boolean(this.value[0]) || Boolean(this.value[1])));
|
|
1465
|
+
}
|
|
1466
|
+
}
|
|
1467
|
+
__decorate$3([
|
|
1468
|
+
MapToComponentField()
|
|
1469
|
+
], VegaTimePickerRangeClearButtonRenderer.prototype, "disabled", void 0);
|
|
1470
|
+
__decorate$3([
|
|
1471
|
+
MapToComponentField()
|
|
1472
|
+
], VegaTimePickerRangeClearButtonRenderer.prototype, "value", void 0);
|
|
1473
|
+
__decorate$3([
|
|
1474
|
+
MapToComponentField()
|
|
1475
|
+
], VegaTimePickerRangeClearButtonRenderer.prototype, "valueController", void 0);
|
|
1476
|
+
__decorate$3([
|
|
1477
|
+
MapToComponentField()
|
|
1478
|
+
], VegaTimePickerRangeClearButtonRenderer.prototype, "endDropdownController", void 0);
|
|
1479
|
+
__decorate$3([
|
|
1480
|
+
MapToComponentField()
|
|
1481
|
+
], VegaTimePickerRangeClearButtonRenderer.prototype, "rangeInputRenderer", void 0);
|
|
1482
|
+
|
|
1483
|
+
/**
|
|
1484
|
+
* A rule that checks if start time is before than end time
|
|
1485
|
+
*/
|
|
1486
|
+
class TimeRangeRule extends InternalFormFieldValidationRule {
|
|
1487
|
+
/**
|
|
1488
|
+
* It creates a new instance of the class with the given config.
|
|
1489
|
+
*
|
|
1490
|
+
* @param {{ timeFormat: TimeFormat }} config - config including the timeFormat for time value
|
|
1491
|
+
* @param {TimeFormat} config.timeFormat - The timeFormat for time value
|
|
1492
|
+
*/
|
|
1493
|
+
constructor(config) {
|
|
1494
|
+
super();
|
|
1495
|
+
this.config = config;
|
|
1496
|
+
}
|
|
1497
|
+
/**
|
|
1498
|
+
* If the input is accepted and the status is not disabled and visible, then return true
|
|
1499
|
+
*
|
|
1500
|
+
* @param {unknown} input - The input to be evaluated.
|
|
1501
|
+
* @param {FormFieldStatusMeta} [status] - FormFieldStatusMeta
|
|
1502
|
+
* @returns {boolean} A boolean value.
|
|
1503
|
+
*/
|
|
1504
|
+
canEvaluate(input, status) {
|
|
1505
|
+
return status
|
|
1506
|
+
? this.isAcceptedInputType(input) && !status.disabled && status.visible
|
|
1507
|
+
: this.isAcceptedInputType(input);
|
|
1508
|
+
}
|
|
1509
|
+
/**
|
|
1510
|
+
* If the field is not disabled, visible, and has been touched or modified, then show the error
|
|
1511
|
+
*
|
|
1512
|
+
* @param {FormFieldStatusMeta} status - FormFieldStatusMeta
|
|
1513
|
+
* @returns {boolean} A boolean value.
|
|
1514
|
+
*/
|
|
1515
|
+
shouldShowError(status) {
|
|
1516
|
+
return !status.disabled && status.visible && (status.touched || status.modified);
|
|
1517
|
+
}
|
|
1518
|
+
/**
|
|
1519
|
+
* Check if the start time is before than end time
|
|
1520
|
+
*
|
|
1521
|
+
* @param {string | string[]} input - The value of the time picker.
|
|
1522
|
+
* @returns {EvaluateResultTranslation} - The result of the evaluation.
|
|
1523
|
+
*/
|
|
1524
|
+
evaluate(input) {
|
|
1525
|
+
if (!this.isAcceptedInputType(input)) {
|
|
1526
|
+
throw new Error(`Unexpected type of input: ${typeof input}: ${input}`);
|
|
1527
|
+
}
|
|
1528
|
+
const isValid = this.isStartTimeBeforeEndTime(input[0], input[1]);
|
|
1529
|
+
return {
|
|
1530
|
+
isValid: isValid,
|
|
1531
|
+
message: isValid ? '' : 'The end time should be later than start time',
|
|
1532
|
+
};
|
|
1533
|
+
}
|
|
1534
|
+
/**
|
|
1535
|
+
* If the input is an array of two strings, and each string is a valid date, then return true.
|
|
1536
|
+
*
|
|
1537
|
+
* @param {unknown} input - The input value to be validated.
|
|
1538
|
+
* @returns {boolean} A boolean value.
|
|
1539
|
+
*/
|
|
1540
|
+
isAcceptedInputType(input) {
|
|
1541
|
+
return (Array.isArray(input) &&
|
|
1542
|
+
input.length === 2 &&
|
|
1543
|
+
input.every((item) => isTimeStr(item, this.config.timeFormat)));
|
|
1544
|
+
}
|
|
1545
|
+
/**
|
|
1546
|
+
* check if start time before end time, the 12-hour time should convert to 24-hour time format, the safari, 'fire fox' do not support 12-hour
|
|
1547
|
+
*
|
|
1548
|
+
* @param {string} startTime time string
|
|
1549
|
+
* @param {string} endTime time string
|
|
1550
|
+
* @returns {boolean} boolean value
|
|
1551
|
+
*/
|
|
1552
|
+
isStartTimeBeforeEndTime(startTime, endTime) {
|
|
1553
|
+
const date = new Date();
|
|
1554
|
+
const year = date.getFullYear();
|
|
1555
|
+
const month = String(date.getMonth() + 1).padStart(2, '0');
|
|
1556
|
+
const day = String(date.getDate()).padStart(2, '0');
|
|
1557
|
+
const baseDate = `${year}-${month}-${day}`;
|
|
1558
|
+
return (new Date(`${baseDate}T${convert12HourTo24HourFormat(endTime)}`) >
|
|
1559
|
+
new Date(`${baseDate}T${convert12HourTo24HourFormat(startTime)}`));
|
|
1560
|
+
}
|
|
1561
|
+
}
|
|
1562
|
+
|
|
1563
|
+
var __decorate$2 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
1564
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
1565
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
1566
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
1567
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
1568
|
+
};
|
|
1569
|
+
/** The `VegaTimePickerInputMaskController` class is responsible for initializing an input mask based on the time format and mode. */
|
|
1570
|
+
class VegaTimePickerInputMaskController extends VegaSlimmer {
|
|
1571
|
+
/**
|
|
1572
|
+
* The function initializes an input mask based on the time format and mode.
|
|
1573
|
+
*/
|
|
1574
|
+
initInputMask() {
|
|
1575
|
+
const maskConfig = {
|
|
1576
|
+
type: 'custom',
|
|
1577
|
+
options: {
|
|
1578
|
+
mask: this.timeFormat === '12-hour' ? 'xx:xx xx' : 'xx:xx',
|
|
1579
|
+
slot: 'x',
|
|
1580
|
+
accept: this.timeFormat === '12-hour' ? /[0-9|A|P|M]/ : /\d/,
|
|
1581
|
+
},
|
|
1582
|
+
};
|
|
1583
|
+
if (this.mode === 'range') {
|
|
1584
|
+
this.rangeInputRenderer.getStartInputRef().maskConfig = maskConfig;
|
|
1585
|
+
this.rangeInputRenderer.getEndInputRef().maskConfig = maskConfig;
|
|
1586
|
+
}
|
|
1587
|
+
else {
|
|
1588
|
+
this.singleInputRenderer.getInputRef().maskConfig = maskConfig;
|
|
1589
|
+
}
|
|
1590
|
+
}
|
|
1591
|
+
}
|
|
1592
|
+
__decorate$2([
|
|
1593
|
+
MapToComponentField()
|
|
1594
|
+
], VegaTimePickerInputMaskController.prototype, "timeFormat", void 0);
|
|
1595
|
+
__decorate$2([
|
|
1596
|
+
MapToComponentField()
|
|
1597
|
+
], VegaTimePickerInputMaskController.prototype, "mode", void 0);
|
|
1598
|
+
__decorate$2([
|
|
1599
|
+
MapToComponentField()
|
|
1600
|
+
], VegaTimePickerInputMaskController.prototype, "singleInputRenderer", void 0);
|
|
1601
|
+
__decorate$2([
|
|
1602
|
+
MapToComponentField()
|
|
1603
|
+
], VegaTimePickerInputMaskController.prototype, "rangeInputRenderer", void 0);
|
|
1604
|
+
__decorate$2([
|
|
1605
|
+
MapToComponentMethod('componentDidLoad')
|
|
1606
|
+
], VegaTimePickerInputMaskController.prototype, "initInputMask", null);
|
|
1607
|
+
|
|
1608
|
+
var __decorate$1 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
1609
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
1610
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
1611
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
1612
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
1613
|
+
};
|
|
1614
|
+
/** The `VegaTimePickerRangeDropdownController` class is responsible for managing the dropdown menu for selecting a range of time in the VegaTimePicker component. */
|
|
1615
|
+
class VegaTimePickerRangeDropdownController extends ElementAppenderSlimmer {
|
|
1616
|
+
/**
|
|
1617
|
+
* The constructor function sets up the configuration for a dropdown menu that is shown when a specific condition is met.
|
|
1618
|
+
*
|
|
1619
|
+
* @param {TimeRangeIndex} rangeIndex start or end
|
|
1620
|
+
*/
|
|
1621
|
+
constructor(rangeIndex) {
|
|
1622
|
+
super(() => {
|
|
1623
|
+
const target = rangeIndex === 'start'
|
|
1624
|
+
? this.rangeInputRenderer.getStartInputRef()
|
|
1625
|
+
: this.rangeInputRenderer.getEndInputRef();
|
|
1626
|
+
const appendableElement = rangeIndex === 'start'
|
|
1627
|
+
? this.rangeDropdownRenderer.getStartDropdownRef()
|
|
1628
|
+
: this.rangeDropdownRenderer.getEndDropdownRef();
|
|
1629
|
+
return {
|
|
1630
|
+
target,
|
|
1631
|
+
appendableElement,
|
|
1632
|
+
positionRelativeTo: this.positionRelativeTo,
|
|
1633
|
+
translocation: { X: 0, Y: 8 },
|
|
1634
|
+
placement: ['bottom', 'top'],
|
|
1635
|
+
matchTargetWidth: true,
|
|
1636
|
+
};
|
|
1637
|
+
}, () => 'custom', 'isRangeDropdownShow');
|
|
1638
|
+
this.isRangeDropdownShow = false;
|
|
1639
|
+
this.rangeDropdownType = 'start';
|
|
1640
|
+
/*
|
|
1641
|
+
* The below method is e2e-test covered in
|
|
1642
|
+
* @see{module:vega-time-picker-range-input-focus}
|
|
1643
|
+
*/
|
|
1644
|
+
/* istanbul ignore next */
|
|
1645
|
+
/**
|
|
1646
|
+
* The function shows a dropdown and scrolls to a selected element if a value is provided.
|
|
1647
|
+
*
|
|
1648
|
+
* @param {string} value - The `value` parameter is a string that represents the value to be scrolled to in the dropdown list.
|
|
1649
|
+
*/
|
|
1650
|
+
this.showAndScrollPosition = (value) => {
|
|
1651
|
+
this.show();
|
|
1652
|
+
if (value) {
|
|
1653
|
+
const dropdownRef = this.rangeDropdownType === 'start'
|
|
1654
|
+
? this.rangeDropdownRenderer.getStartDropdownRef()
|
|
1655
|
+
: this.rangeDropdownRenderer.getEndDropdownRef();
|
|
1656
|
+
const selectedItem = dropdownRef.shadowRoot.querySelector(`[aria-label="${value}"]`);
|
|
1657
|
+
if (selectedItem) {
|
|
1658
|
+
this.dropdownSelectedItemsController.scrollToSelectedElement(selectedItem);
|
|
1659
|
+
}
|
|
1660
|
+
}
|
|
1661
|
+
};
|
|
1662
|
+
this.rangeDropdownType = rangeIndex;
|
|
1663
|
+
}
|
|
1664
|
+
/*
|
|
1665
|
+
* The below method is e2e-test covered in
|
|
1666
|
+
* @see{module:vega-time-picker-range-disabled-change}
|
|
1667
|
+
*/
|
|
1668
|
+
/* istanbul ignore next */
|
|
1669
|
+
/**
|
|
1670
|
+
* The function hides a dropdown when it is disabled.
|
|
1671
|
+
*/
|
|
1672
|
+
hideDropdownWhenDisabled() {
|
|
1673
|
+
if (this.mode === 'range' && this.isRangeDropdownShow) {
|
|
1674
|
+
this.hide();
|
|
1675
|
+
}
|
|
1676
|
+
}
|
|
1677
|
+
}
|
|
1678
|
+
__decorate$1([
|
|
1679
|
+
MapToComponentField()
|
|
1680
|
+
], VegaTimePickerRangeDropdownController.prototype, "positionRelativeTo", void 0);
|
|
1681
|
+
__decorate$1([
|
|
1682
|
+
MapToComponentField()
|
|
1683
|
+
], VegaTimePickerRangeDropdownController.prototype, "mode", void 0);
|
|
1684
|
+
__decorate$1([
|
|
1685
|
+
MapToComponentField()
|
|
1686
|
+
], VegaTimePickerRangeDropdownController.prototype, "rangeDropdownRenderer", void 0);
|
|
1687
|
+
__decorate$1([
|
|
1688
|
+
MapToComponentField()
|
|
1689
|
+
], VegaTimePickerRangeDropdownController.prototype, "rangeInputRenderer", void 0);
|
|
1690
|
+
__decorate$1([
|
|
1691
|
+
MapToComponentField()
|
|
1692
|
+
], VegaTimePickerRangeDropdownController.prototype, "dropdownSelectedItemsController", void 0);
|
|
1693
|
+
__decorate$1([
|
|
1694
|
+
MapToComponentMethod('watchDisabled')
|
|
1695
|
+
], VegaTimePickerRangeDropdownController.prototype, "hideDropdownWhenDisabled", null);
|
|
1696
|
+
|
|
1697
|
+
const VegaTimePickerRuntimeMetricsPayloadDefinition = [
|
|
1698
|
+
{
|
|
1699
|
+
payloadKey: 'AUTO_VALIDATION_IS_TRUE',
|
|
1700
|
+
payloadDescription: 'Determines whether automatic validation should be implemented for the time picker during user input',
|
|
1701
|
+
/**
|
|
1702
|
+
* The function checks if the `autoValidation` property of the `host` element is equal to 'true'.
|
|
1703
|
+
* If it is, the function will return `true`.
|
|
1704
|
+
*
|
|
1705
|
+
* @param {HTMLElement} host - The element to check
|
|
1706
|
+
* @returns {boolean} A boolean value
|
|
1707
|
+
*/
|
|
1708
|
+
payloadValue: (host) => host.autoValidation === true,
|
|
1709
|
+
},
|
|
1710
|
+
{
|
|
1711
|
+
payloadKey: 'AUTO_VALIDATION_IS_FALSE',
|
|
1712
|
+
payloadDescription: 'Determines whether automatic validation should be implemented for the time picker during user input',
|
|
1713
|
+
/**
|
|
1714
|
+
* The function checks if the `autoValidation` property of the `host` element is equal to 'false'.
|
|
1715
|
+
* If it is, the function will return `true`.
|
|
1716
|
+
*
|
|
1717
|
+
* @param {HTMLElement} host - The element to check
|
|
1718
|
+
* @returns {boolean} A boolean value
|
|
1719
|
+
*/
|
|
1720
|
+
payloadValue: (host) => host.autoValidation === false,
|
|
1721
|
+
},
|
|
1722
|
+
{
|
|
1723
|
+
payloadKey: 'MODE_IS_SINGLE',
|
|
1724
|
+
payloadDescription: 'Specifies the mode for selecting time in the time picker, `single` indicates the ability to select a single time.',
|
|
1725
|
+
/**
|
|
1726
|
+
* The function checks if the `mode` property of the `host` element is equal to 'single'.
|
|
1727
|
+
* If it is, the function will return `true`.
|
|
1728
|
+
*
|
|
1729
|
+
* @param {HTMLElement} host - The element to check
|
|
1730
|
+
* @returns {boolean} A boolean value
|
|
1731
|
+
*/
|
|
1732
|
+
payloadValue: (host) => host.mode === 'single',
|
|
1733
|
+
},
|
|
1734
|
+
{
|
|
1735
|
+
payloadKey: 'MODE_IS_RANGE',
|
|
1736
|
+
payloadDescription: 'Specifies the mode for selecting time in the time picker, `range` indicates the ability to select a time range',
|
|
1737
|
+
/**
|
|
1738
|
+
* The function checks if the `mode` property of the `host` element is equal to 'range'.
|
|
1739
|
+
* If it is, the function will return `true`.
|
|
1740
|
+
*
|
|
1741
|
+
* @param {HTMLElement} host - The element to check
|
|
1742
|
+
* @returns {boolean} A boolean value
|
|
1743
|
+
*/
|
|
1744
|
+
payloadValue: (host) => host.mode === 'range',
|
|
1745
|
+
},
|
|
1746
|
+
];
|
|
1747
|
+
|
|
1748
|
+
const vegaTimePickerCss = ":host{display:inline-block;text-align:left;line-height:normal;width:100%}vega-field-label{margin-bottom:8px}vega-input::part(field-error-message){display:none}.vega-error{font-family:\"Inter\", sans-serif;font-size:14px;font-weight:400;line-height:18px;letter-spacing:0px;color:rgba(var(--v-text-error, 189, 41, 71, 1));display:block;padding-top:12px;padding-right:8px;padding-left:8px}@media screen and (min-width: 768px) and (max-width: 1023px){.vega-error{font-family:\"Inter\", sans-serif;font-size:14px;font-weight:400;line-height:18px;letter-spacing:0px}}@media screen and (min-width: 1024px) and (max-width: 1439px){.vega-error{font-family:\"Inter\", sans-serif;font-size:14px;font-weight:400;line-height:18px;letter-spacing:0px}}@media screen and (min-width: 1440px) and (max-width: 9999px){.vega-error{font-family:\"Inter\", sans-serif;font-size:14px;font-weight:400;line-height:18px;letter-spacing:0px}}.vega-time-picker-input-container.error vega-input::part(input-container){border-width:0px}.vega-time-picker-input-container.error vega-input::part(input-container):hover{border-width:0px}.vega-time-picker-input-container.error vega-input::part(input-container):focus-within{outline:none}.vega-time-picker-input-container.error{border-radius:8px;border:1px solid rgba(var(--v-border-input-field-danger, 230, 50, 87, 1))}.vega-time-picker-input-container.error .vega-time-picker-range-clear-icon:focus-within{outline:2px solid rgba(var(--v-border-color-danger, 230, 50, 87, 1));outline-offset:2px}.vega-time-picker-input-container.error:hover{border:1px solid rgba(var(--v-border-input-field-danger-hover, 255, 87, 114, 1))}.vega-time-picker-input-container.error:focus-within{outline:2px solid rgba(var(--v-border-color-danger, 230, 50, 87, 1));outline-offset:3px;border:1px solid rgba(var(--v-border-color-input-field-danger-focus, 233, 71, 104, 1))}.vega-hidden{display:none}.range-input-divider{width:1px;height:24px;border-style:solid;border-right-width:1px;border-top-width:0px;border-bottom-width:0px;border-left-width:0px;border-color:rgba(var(--v-border-color-divider, 171, 198, 216, 1))}.mobile .range-input-divider{width:100%;height:1px;border-style:solid;border-right-width:0px;border-top-width:1px;border-bottom-width:0px;border-left-width:0px}.mobile .time-picker-input-end vega-input::part(input){padding-left:26px}.range-mode{position:relative;background-color:rgba(var(--v-bg-primary, 252, 252, 252, 1));border-radius:8px;border:1px solid rgba(var(--v-border-input-field, 171, 198, 216, 1))}:host(.disabled) .range-mode{background-color:rgba(var(--v-bg-secondary, 245, 247, 247, 1))}:host:not(.disabled) .range-mode:not(.error):hover{border:1px solid rgba(var(--v-border-input-field-hover, 115, 160, 190, 1))}.range-mode vega-input::part(input-container),:host(.disabled) .range-mode vega-input::part(input-container):hover{border-width:0px}.range-mode:not(.error) .time-picker-input-start vega-input::part(input-container):focus-within,.range-mode:not(.error) .time-picker-input-end vega-input::part(input-container):focus-within{outline:2px solid rgba(var(--v-border-color-action, 19, 98, 226, 1));outline-offset:3px;border:1px solid rgba(var(--v-border-color-input-field-focus, 19, 98, 226, 1));margin:-1px}.range-mode .vega-time-picker-range-clear-icon{position:absolute;width:16px;height:16px;cursor:pointer;color:rgba(var(--v-text-secondary, 107, 116, 125, 1));top:50%;right:16px;transform:translateY(-50%)}.range-mode .vega-time-picker-range-clear-icon:focus-within{outline:2px solid rgba(var(--v-border-color-action, 19, 98, 226, 1));outline-offset:2px;border-radius:4px;padding:2px}.range-mode.mobile .vega-time-picker-range-clear-icon{top:75%}.range-mode.mobile .time-picker-input{width:100%}vega-time-picker-dropdown.vega-force-hidden{display:none !important}.vega-time-picker-range-clear-icon.invisible{visibility:hidden}";
|
|
1749
|
+
|
|
1750
|
+
var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
1751
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
1752
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
|
|
1753
|
+
r = Reflect.decorate(decorators, target, key, desc);
|
|
1754
|
+
else
|
|
1755
|
+
for (var i = decorators.length - 1; i >= 0; i--)
|
|
1756
|
+
if (d = decorators[i])
|
|
1757
|
+
r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
1758
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
1759
|
+
};
|
|
1760
|
+
const VegaTimePicker = class {
|
|
1761
|
+
constructor(hostRef) {
|
|
1762
|
+
registerInstance(this, hostRef);
|
|
1763
|
+
this.vegaChange = createEvent(this, "vegaChange", 7);
|
|
1764
|
+
this.change = createEvent(this, "change", 7);
|
|
1765
|
+
this.globalSlimmers = {};
|
|
1766
|
+
this.translationSlimmer = new TranslationSlimmer();
|
|
1767
|
+
this.labelRenderer = new VegaTimePickerLabelRenderer();
|
|
1768
|
+
this.singleInputRenderer = new VegaTimePickerSingleInputRenderer();
|
|
1769
|
+
this.singleDropdownRenderer = new VegaTimePickerSingleDropdownRenderer();
|
|
1770
|
+
this.valueController = new VegaTimePickerValueController();
|
|
1771
|
+
this.singleDropdownController = new VegaTimePickerSingleDropdownController();
|
|
1772
|
+
this.dropdownSelectedItemsController = new VegaTimePickerDropdownSelectedItemsController();
|
|
1773
|
+
this.keyboardController = new VegaTimePickerKeyboardController();
|
|
1774
|
+
this.formFieldController = new FormFieldControllerSlimmer({
|
|
1775
|
+
propertyRules: [
|
|
1776
|
+
{
|
|
1777
|
+
propertyName: 'required',
|
|
1778
|
+
ruleFactory: (isRequired, timeFormat, mode) => isRequired
|
|
1779
|
+
? mode === 'range'
|
|
1780
|
+
? new TimeRangeRequiredRule({ timeFormat })
|
|
1781
|
+
: new TimeRequiredRule({ timeFormat })
|
|
1782
|
+
: null,
|
|
1783
|
+
dependence: ['timeFormat', 'mode'],
|
|
1784
|
+
},
|
|
1785
|
+
{
|
|
1786
|
+
propertyName: 'timeFormat',
|
|
1787
|
+
ruleFactory: (timeFormat, required, mode) => timeFormat && required
|
|
1788
|
+
? mode === 'range'
|
|
1789
|
+
? new TimeRangeRequiredRule({ timeFormat })
|
|
1790
|
+
: new TimeRequiredRule({ timeFormat })
|
|
1791
|
+
: null,
|
|
1792
|
+
dependence: ['required', 'mode'],
|
|
1793
|
+
},
|
|
1794
|
+
{
|
|
1795
|
+
propertyName: 'mode',
|
|
1796
|
+
ruleFactory: (mode, timeFormat) => mode === 'range' ? new TimeRangeRule({ timeFormat }) : null,
|
|
1797
|
+
dependence: 'timeFormat',
|
|
1798
|
+
},
|
|
1799
|
+
],
|
|
1800
|
+
validationRulesName: 'validationRules',
|
|
1801
|
+
defaultValue: (target) => (target.mode === 'range' ? ['', ''] : ''),
|
|
1802
|
+
attributeGetter: (propertyName) => this[propertyName],
|
|
1803
|
+
inputContainerGetter: () => this.inputContainerRef,
|
|
1804
|
+
touchableAreaGetter: () => this.mode === 'single'
|
|
1805
|
+
? [this.singleInputRenderer.getInputRef()]
|
|
1806
|
+
: [this.rangeInputRenderer.getStartInputRef(), this.rangeInputRenderer.getEndInputRef()],
|
|
1807
|
+
});
|
|
1808
|
+
this.rangeInputRenderer = new VegaTimePickerRangeInputRenderer();
|
|
1809
|
+
this.rangeClearButtonRenderer = new VegaTimePickerRangeClearButtonRenderer();
|
|
1810
|
+
this.rangeDropdownRenderer = new VegaTimePickerRangeDropdownRenderer();
|
|
1811
|
+
this.startDropdownController = new VegaTimePickerRangeDropdownController('start');
|
|
1812
|
+
this.endDropdownController = new VegaTimePickerRangeDropdownController('end');
|
|
1813
|
+
this.inputMaskController = new VegaTimePickerInputMaskController();
|
|
1814
|
+
this.inputEventPrevent = new ChildNodesEventPreventSlimmer([VegaChange], () => this.inputContainerRef);
|
|
1815
|
+
this.changeEventEmitter = createEventEmitSlimmer(VegaTimePicker, VegaChange);
|
|
1816
|
+
this.vegaComponentUsageRuntimeMetricsSlimmer = new VegaComponentUsageRuntimeMetricsSlimmer(VegaTimePickerRuntimeMetricsPayloadDefinition);
|
|
1817
|
+
this.isMobileDevice = getDeviceType() === DeviceType.MOBILE;
|
|
1818
|
+
this.isTabletDevice = getDeviceType() === DeviceType.TABLET;
|
|
1819
|
+
/** dropdown source */
|
|
1820
|
+
this.dropdownSource = {
|
|
1821
|
+
hours: [],
|
|
1822
|
+
minutes: [],
|
|
1823
|
+
};
|
|
1824
|
+
/* Selected hour, minute and amPm */
|
|
1825
|
+
this.isDropdownShow = false;
|
|
1826
|
+
this.selectedTimeValue = {};
|
|
1827
|
+
/**
|
|
1828
|
+
* Specifies the mode for selecting time in the time picker.
|
|
1829
|
+
*
|
|
1830
|
+
* - `single` indicates the ability to select a single time.
|
|
1831
|
+
* - `range` indicates the ability to select a time range.
|
|
1832
|
+
*
|
|
1833
|
+
* @vegaVersion 1.48.0
|
|
1834
|
+
*/
|
|
1835
|
+
this.mode = 'single';
|
|
1836
|
+
/**
|
|
1837
|
+
* Specifies whether selecting a time in the time picker
|
|
1838
|
+
* is required for passing form validation.
|
|
1839
|
+
*
|
|
1840
|
+
* @vegaVersion 1.12.0
|
|
1841
|
+
*/
|
|
1842
|
+
this.required = false;
|
|
1843
|
+
/**
|
|
1844
|
+
* Determines the interval between each selectable minute value
|
|
1845
|
+
* in the time picker.
|
|
1846
|
+
*
|
|
1847
|
+
* @vegaVersion 1.12.0
|
|
1848
|
+
*/
|
|
1849
|
+
this.increments = 1;
|
|
1850
|
+
/**
|
|
1851
|
+
* Specifies the format in which the time is displayed
|
|
1852
|
+
* in the time picker.
|
|
1853
|
+
* - `24-hour` displays time as "HH:mm".
|
|
1854
|
+
* - `12-hour` displays time as "hh:mm a".
|
|
1855
|
+
*
|
|
1856
|
+
* @vegaVersion 1.12.0
|
|
1857
|
+
*/
|
|
1858
|
+
this.timeFormat = '24-hour';
|
|
1859
|
+
/**
|
|
1860
|
+
* Specifies the initial value or selected time
|
|
1861
|
+
* for the time picker.
|
|
1862
|
+
* - In `single` mode, the value is a string:
|
|
1863
|
+
* - `24-hour` format: "HH:mm".
|
|
1864
|
+
* - `12-hour` format: "hh:mm a".
|
|
1865
|
+
* - In `range` mode, the value is an array of two strings:
|
|
1866
|
+
* - `24-hour` format: ["HH:mm", "HH:mm"].
|
|
1867
|
+
* - `12-hour` format: ["hh:mm a", "hh:mm a"]
|
|
1868
|
+
*
|
|
1869
|
+
* @vegaVersion 1.12.0
|
|
1870
|
+
*/
|
|
1871
|
+
/* eslint-disable-next-line @stencil/strict-mutable */
|
|
1872
|
+
this.value = this.mode === 'range' ? ['', ''] : '';
|
|
1873
|
+
/**
|
|
1874
|
+
* Determines the size or dimensions of the time picker component.
|
|
1875
|
+
*
|
|
1876
|
+
* @vegaVersion 1.12.0
|
|
1877
|
+
*/
|
|
1878
|
+
this.size = 'default';
|
|
1879
|
+
/**
|
|
1880
|
+
* Determines whether the time picker component is disabled.
|
|
1881
|
+
*
|
|
1882
|
+
* @vegaVersion 1.12.0
|
|
1883
|
+
*/
|
|
1884
|
+
this.disabled = false;
|
|
1885
|
+
/**
|
|
1886
|
+
* Specifies the validation status of the time picker component.
|
|
1887
|
+
*
|
|
1888
|
+
* @vegaVersion 1.12.0
|
|
1889
|
+
*/
|
|
1890
|
+
/* eslint-disable-next-line @stencil/strict-mutable */
|
|
1891
|
+
this.isValid = null;
|
|
1892
|
+
/**
|
|
1893
|
+
* Determines whether automatic validation should be implemented
|
|
1894
|
+
* for the time picker during user input.
|
|
1895
|
+
*
|
|
1896
|
+
* @vegaVersion 1.12.0
|
|
1897
|
+
*/
|
|
1898
|
+
this.autoValidation = true;
|
|
1899
|
+
/**
|
|
1900
|
+
* Specifies custom validation rules for the
|
|
1901
|
+
* time picker input field.
|
|
1902
|
+
*
|
|
1903
|
+
* @vegaVersion 1.12.0
|
|
1904
|
+
*/
|
|
1905
|
+
this.validationRules = [];
|
|
1906
|
+
}
|
|
1907
|
+
/**
|
|
1908
|
+
* The below method is e2e-test covered in
|
|
1909
|
+
* @see{module:vega-time-picker-keyboard-control-e2e}
|
|
1910
|
+
*/
|
|
1911
|
+
/* istanbul ignore next */
|
|
1912
|
+
async watchIsDropdownShow(newValue) {
|
|
1913
|
+
methodPlaceholder(newValue);
|
|
1914
|
+
}
|
|
1915
|
+
watchSelectedTimeValue() {
|
|
1916
|
+
methodPlaceholder();
|
|
1917
|
+
}
|
|
1918
|
+
/*
|
|
1919
|
+
* The below method is e2e-test covered in
|
|
1920
|
+
* @see{module:vega-time-picker-mode-change}
|
|
1921
|
+
*/
|
|
1922
|
+
/* istanbul ignore next */
|
|
1923
|
+
/** Update timePicker settings property of mode is changed */
|
|
1924
|
+
watchMode() {
|
|
1925
|
+
methodPlaceholder();
|
|
1926
|
+
}
|
|
1927
|
+
watchIncrements() {
|
|
1928
|
+
methodPlaceholder();
|
|
1929
|
+
}
|
|
1930
|
+
watchTimeFormat() {
|
|
1931
|
+
methodPlaceholder();
|
|
1932
|
+
}
|
|
1933
|
+
watchValue(newValue, oldValue) {
|
|
1934
|
+
methodPlaceholder(newValue, oldValue);
|
|
1935
|
+
}
|
|
1936
|
+
watchDisabled() {
|
|
1937
|
+
methodPlaceholder();
|
|
1938
|
+
}
|
|
1939
|
+
watchValidationRules() {
|
|
1940
|
+
methodPlaceholder();
|
|
1941
|
+
}
|
|
1942
|
+
componentWillLoad() {
|
|
1943
|
+
methodPlaceholder();
|
|
1944
|
+
}
|
|
1945
|
+
componentDidLoad() {
|
|
1946
|
+
methodPlaceholder();
|
|
1947
|
+
}
|
|
1948
|
+
componentDidRender() {
|
|
1949
|
+
methodPlaceholder();
|
|
1950
|
+
}
|
|
1951
|
+
render() {
|
|
1952
|
+
const isRangeMode = this.mode === 'range';
|
|
1953
|
+
return sanitizeVegaComponent(h(Host, { class: {
|
|
1954
|
+
disabled: this.disabled,
|
|
1955
|
+
} }, this.labelRenderer.render(), h("div", { class: this.getTimePickerClass(isRangeMode), ref: (node) => (this.inputContainerRef = node) }, isRangeMode ? this.rangeInputRenderer.render() : this.singleInputRenderer.render()), isRangeMode ? this.rangeDropdownRenderer.render() : this.singleDropdownRenderer.render()), this.host);
|
|
1956
|
+
}
|
|
1957
|
+
getTimePickerClass(isRangeMode) {
|
|
1958
|
+
return {
|
|
1959
|
+
'vega-time-picker-input-container': true,
|
|
1960
|
+
'range-mode': isRangeMode,
|
|
1961
|
+
'mobile': isRangeMode && this.isMobileDevice,
|
|
1962
|
+
'tablet': isRangeMode && this.isTabletDevice,
|
|
1963
|
+
};
|
|
1964
|
+
}
|
|
1965
|
+
get host() { return getElement(this); }
|
|
1966
|
+
static get watchers() { return {
|
|
1967
|
+
"isDropdownShow": ["watchIsDropdownShow"],
|
|
1968
|
+
"selectedTimeValue": ["watchSelectedTimeValue"],
|
|
1969
|
+
"mode": ["watchMode"],
|
|
1970
|
+
"increments": ["watchIncrements"],
|
|
1971
|
+
"timeFormat": ["watchTimeFormat"],
|
|
1972
|
+
"value": ["watchValue"],
|
|
1973
|
+
"disabled": ["watchDisabled"],
|
|
1974
|
+
"validationRules": ["watchValidationRules"]
|
|
1975
|
+
}; }
|
|
1976
|
+
};
|
|
1977
|
+
__decorate([
|
|
1978
|
+
InjectVegaGlobalSlimmer()
|
|
1979
|
+
], VegaTimePicker.prototype, "globalSlimmers", void 0);
|
|
1980
|
+
__decorate([
|
|
1981
|
+
InjectVegaSlimmer()
|
|
1982
|
+
], VegaTimePicker.prototype, "translationSlimmer", void 0);
|
|
1983
|
+
__decorate([
|
|
1984
|
+
InjectVegaSlimmer()
|
|
1985
|
+
], VegaTimePicker.prototype, "labelRenderer", void 0);
|
|
1986
|
+
__decorate([
|
|
1987
|
+
InjectVegaSlimmer()
|
|
1988
|
+
], VegaTimePicker.prototype, "singleInputRenderer", void 0);
|
|
1989
|
+
__decorate([
|
|
1990
|
+
InjectVegaSlimmer()
|
|
1991
|
+
], VegaTimePicker.prototype, "singleDropdownRenderer", void 0);
|
|
1992
|
+
__decorate([
|
|
1993
|
+
InjectVegaSlimmer()
|
|
1994
|
+
], VegaTimePicker.prototype, "valueController", void 0);
|
|
1995
|
+
__decorate([
|
|
1996
|
+
InjectVegaSlimmer()
|
|
1997
|
+
], VegaTimePicker.prototype, "singleDropdownController", void 0);
|
|
1998
|
+
__decorate([
|
|
1999
|
+
InjectVegaSlimmer()
|
|
2000
|
+
], VegaTimePicker.prototype, "dropdownSelectedItemsController", void 0);
|
|
2001
|
+
__decorate([
|
|
2002
|
+
InjectVegaSlimmer()
|
|
2003
|
+
], VegaTimePicker.prototype, "keyboardController", void 0);
|
|
2004
|
+
__decorate([
|
|
2005
|
+
InjectVegaSlimmer()
|
|
2006
|
+
], VegaTimePicker.prototype, "formFieldController", void 0);
|
|
2007
|
+
__decorate([
|
|
2008
|
+
InjectVegaSlimmer()
|
|
2009
|
+
], VegaTimePicker.prototype, "rangeInputRenderer", void 0);
|
|
2010
|
+
__decorate([
|
|
2011
|
+
InjectVegaSlimmer()
|
|
2012
|
+
], VegaTimePicker.prototype, "rangeClearButtonRenderer", void 0);
|
|
2013
|
+
__decorate([
|
|
2014
|
+
InjectVegaSlimmer()
|
|
2015
|
+
], VegaTimePicker.prototype, "rangeDropdownRenderer", void 0);
|
|
2016
|
+
__decorate([
|
|
2017
|
+
InjectVegaSlimmer()
|
|
2018
|
+
], VegaTimePicker.prototype, "startDropdownController", void 0);
|
|
2019
|
+
__decorate([
|
|
2020
|
+
InjectVegaSlimmer()
|
|
2021
|
+
], VegaTimePicker.prototype, "endDropdownController", void 0);
|
|
2022
|
+
__decorate([
|
|
2023
|
+
InjectVegaSlimmer()
|
|
2024
|
+
], VegaTimePicker.prototype, "inputMaskController", void 0);
|
|
2025
|
+
__decorate([
|
|
2026
|
+
InjectVegaSlimmer()
|
|
2027
|
+
], VegaTimePicker.prototype, "inputEventPrevent", void 0);
|
|
2028
|
+
__decorate([
|
|
2029
|
+
InjectVegaSlimmer()
|
|
2030
|
+
], VegaTimePicker.prototype, "changeEventEmitter", void 0);
|
|
2031
|
+
__decorate([
|
|
2032
|
+
InjectVegaSlimmer()
|
|
2033
|
+
], VegaTimePicker.prototype, "vegaComponentUsageRuntimeMetricsSlimmer", void 0);
|
|
2034
|
+
__decorate([
|
|
2035
|
+
ComponentLoadRequired()
|
|
2036
|
+
], VegaTimePicker.prototype, "watchValue", null);
|
|
2037
|
+
VegaTimePicker.style = vegaTimePickerCss;
|
|
2038
|
+
|
|
2039
|
+
export { VegaTimePicker as vega_time_picker };
|