@heartlandone/vega 2.63.1 → 2.65.0
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/{app-globals-2d0b157e.js → app-globals-681a0ed4.js} +10 -10
- package/dist/cjs/{brand-switch-state-controller-slimmer-b83a4596.js → brand-switch-state-controller-slimmer-3d41b2a4.js} +1 -1
- package/dist/cjs/{child-nodes-event-prevent-slimmer-4e96270e.js → child-nodes-event-prevent-slimmer-feb072c4.js} +1 -1
- package/dist/cjs/{child-nodes-notify-observer-slimmer-34ac3bfc.js → child-nodes-notify-observer-slimmer-257fedb3.js} +1 -1
- package/dist/cjs/{code-block-cc740807.js → code-block-961d54e8.js} +13 -17
- package/dist/cjs/{component-value-history-controller-slimmer.abstract-0bb81172.js → component-value-history-controller-slimmer.abstract-c5b8b47b.js} +6 -6
- package/dist/cjs/{dark-mode-state-controller-slimmer-17022f93.js → dark-mode-state-controller-slimmer-8a87ec08.js} +1 -1
- package/dist/cjs/{dark-mode-style-controller-b1e9ec82.js → dark-mode-style-controller-27809ff8.js} +1 -1
- package/dist/cjs/{design-token-bf913c86.js → design-token-98652b67.js} +1 -1
- package/dist/cjs/{dom-node-subject-observer-factory-58e3c010.js → dom-node-subject-observer-factory-56609e5a.js} +1 -1
- package/dist/cjs/{dto-renderer-manager-424c5031.js → dto-renderer-manager-4b9d2560.js} +11 -6
- package/dist/cjs/{element-appender-slimmer-1d035b1f.js → element-appender-slimmer-1f46981b.js} +6 -6
- package/dist/cjs/{event-emit-slimmer-428d8802.js → event-emit-slimmer-3cefb326.js} +2 -2
- package/dist/cjs/{form-field-controller-slimmer-cc6e53a4.js → form-field-controller-slimmer-1e1123ea.js} +16 -8
- package/dist/cjs/{image-annotation-action-f831e09b.js → image-annotation-action-03b36f68.js} +5 -5
- package/dist/cjs/{index-00ba6623.js → index-58ea899e.js} +1 -0
- package/dist/cjs/{index-5505e8dd.js → index-f2fe26a0.js} +2 -2
- package/dist/cjs/index.cjs.js +16 -16
- package/dist/cjs/{inject-keyboard-manager-ad865c95.js → inject-keyboard-manager-51033b3f.js} +1 -1
- package/dist/cjs/{internal-vega-event-manager-28b957c8.js → internal-vega-event-manager-9b503f1a.js} +1 -1
- package/dist/cjs/{keyboard-manager-7f4e1f43.js → keyboard-manager-144907d7.js} +1 -1
- package/dist/cjs/{keyboard-manager-slimmer-138a90e5.js → keyboard-manager-slimmer-04c48756.js} +1 -1
- package/dist/cjs/{language-extension-cfe0eabd.js → language-extension-059d62f6.js} +2 -2
- package/dist/cjs/loader.cjs.js +15 -15
- package/dist/cjs/{public-rules-7e9b633d.js → public-rules-58e0218b.js} +8 -8
- package/dist/cjs/{range-44f08955.js → range-42732973.js} +2 -2
- package/dist/cjs/{responsive-format-facade-a7fbefc4.js → responsive-format-facade-29070d00.js} +5 -5
- package/dist/cjs/{rich-text-editor-required-rule-a0618c85.js → rich-text-editor-required-rule-ce4dd5fb.js} +1 -1
- package/dist/cjs/{static-subject-title-85732e0f.js → static-subject-title-5829a298.js} +0 -8
- package/dist/cjs/{string-input-formatter-slimmer-f6c7a255.js → string-input-formatter-slimmer-0d69ea76.js} +3 -3
- package/dist/cjs/{style-formatter-795451f2.js → style-formatter-f6723cb3.js} +1 -1
- package/dist/cjs/{sub-state-notify-slimmer-bb64fcfc.js → sub-state-notify-slimmer-066f2aa9.js} +2 -2
- package/dist/cjs/{sub-state-observer-slimmer-84175d61.js → sub-state-observer-slimmer-569e3297.js} +3 -3
- package/dist/cjs/{token-extension-4764d5f3.js → token-extension-260adb8a.js} +6 -6
- package/dist/cjs/{translation-cde4dce3.js → translation-f5adcb9f.js} +1 -1
- package/dist/cjs/{translation-slimmer-af399096.js → translation-slimmer-4b6239d1.js} +1 -1
- package/dist/cjs/{ui-4ce1fa08.js → ui-9e181079.js} +16 -3
- package/dist/cjs/vega-accordion.cjs.entry.js +14 -14
- package/dist/cjs/vega-app-footer.cjs.entry.js +4 -4
- package/dist/cjs/vega-app-header-button.cjs.entry.js +15 -15
- package/dist/cjs/vega-backdrop.cjs.entry.js +2 -2
- package/dist/cjs/vega-banner.cjs.entry.js +5 -5
- package/dist/cjs/vega-bar-chart.cjs.entry.js +1 -1
- package/dist/cjs/vega-box.cjs.entry.js +14 -14
- package/dist/cjs/vega-brand-logo.cjs.entry.js +4 -4
- package/dist/cjs/vega-breadcrumb.cjs.entry.js +6 -6
- package/dist/cjs/vega-button-circle.cjs.entry.js +20 -17
- package/dist/cjs/vega-button-group_2.cjs.entry.js +9 -9
- package/dist/cjs/vega-button-link.cjs.entry.js +6 -6
- package/dist/cjs/vega-button.cjs.entry.js +20 -15
- package/dist/cjs/vega-calendar_4.cjs.entry.js +528 -226
- package/dist/cjs/vega-card.cjs.entry.js +13 -13
- package/dist/cjs/vega-carousel.cjs.entry.js +13 -13
- package/dist/cjs/vega-checkbox_2.cjs.entry.js +12 -12
- package/dist/cjs/vega-chip.cjs.entry.js +15 -15
- package/dist/cjs/vega-code-block.cjs.entry.js +16 -16
- package/dist/cjs/vega-color-picker.cjs.entry.js +10 -10
- package/dist/cjs/vega-combo-box.cjs.entry.js +13 -13
- package/dist/cjs/vega-counter-badge.cjs.entry.js +1 -1
- package/dist/cjs/vega-date-picker_2.cjs.entry.js +63 -26
- package/dist/cjs/vega-dialog_2.cjs.entry.js +16 -16
- package/dist/cjs/vega-divider.cjs.entry.js +13 -13
- package/dist/cjs/vega-dropdown_5.cjs.entry.js +24 -23
- package/dist/cjs/vega-env-manager-23b8b23c.js +2 -2
- package/dist/cjs/vega-field-error.cjs.entry.js +2 -2
- package/dist/cjs/vega-field-label.cjs.entry.js +5 -5
- package/dist/cjs/vega-file-uploader.cjs.entry.js +11 -11
- package/dist/cjs/vega-flag-icon.cjs.entry.js +13 -13
- package/dist/cjs/vega-flex.cjs.entry.js +14 -14
- package/dist/cjs/vega-font.cjs.entry.js +13 -13
- package/dist/cjs/vega-form.cjs.entry.js +636 -323
- package/dist/cjs/vega-grid.cjs.entry.js +13 -13
- package/dist/cjs/vega-hint.cjs.entry.js +1 -1
- package/dist/cjs/vega-icon.cjs.entry.js +13 -13
- package/dist/cjs/vega-image-uploader.cjs.entry.js +18 -18
- package/dist/cjs/vega-input-credit-card.cjs.entry.js +11 -11
- package/dist/cjs/vega-input-numeric.cjs.entry.js +14 -14
- package/dist/cjs/vega-input-phone-number.cjs.entry.js +15 -15
- package/dist/cjs/vega-input-range.cjs.entry.js +12 -12
- package/dist/cjs/vega-input-select.cjs.entry.js +17 -17
- package/dist/cjs/vega-input.cjs.entry.js +12 -12
- package/dist/cjs/{vega-internal-event-id-9647aaf8.js → vega-internal-event-id-6d4a2c53.js} +8 -0
- package/dist/cjs/vega-item-toggle.cjs.entry.js +5 -5
- package/dist/cjs/vega-left-nav_5.cjs.entry.js +45 -21
- package/dist/cjs/vega-line-chart.cjs.entry.js +1 -1
- package/dist/cjs/vega-loader-wrapper_2.cjs.entry.js +12 -12
- package/dist/cjs/vega-page-notification_2.cjs.entry.js +3 -3
- package/dist/cjs/vega-pagination-page-selector-mobile.cjs.entry.js +6 -6
- package/dist/cjs/vega-pagination-page-size-selector-mobile.cjs.entry.js +7 -7
- package/dist/cjs/vega-pagination.cjs.entry.js +15 -15
- package/dist/cjs/vega-pie-chart.cjs.entry.js +1 -1
- package/dist/cjs/vega-popover_2.cjs.entry.js +17 -17
- package/dist/cjs/vega-progress-tracker.cjs.entry.js +5 -5
- package/dist/cjs/vega-radio_2.cjs.entry.js +14 -14
- package/dist/cjs/vega-rich-text-content.cjs.entry.js +11 -11
- package/dist/cjs/vega-rich-text-editor_4.cjs.entry.js +25 -29
- package/dist/cjs/vega-section-title.cjs.entry.js +1 -1
- package/dist/cjs/vega-segment-control.cjs.entry.js +5 -5
- package/dist/cjs/vega-selection-chip_2.cjs.entry.js +17 -17
- package/dist/cjs/vega-selection-tile_2.cjs.entry.js +13 -13
- package/dist/cjs/vega-sidenav_3.cjs.entry.js +15 -15
- package/dist/cjs/vega-signature-capture.cjs.entry.js +17 -17
- package/dist/cjs/vega-skeleton.cjs.entry.js +1 -1
- package/dist/cjs/vega-slot-container.cjs.entry.js +1 -1
- package/dist/cjs/vega-stepper.cjs.entry.js +11 -11
- package/dist/cjs/vega-tab-group_2.cjs.entry.js +7 -7
- package/dist/cjs/vega-table_8.cjs.entry.js +17 -17
- package/dist/cjs/vega-text.cjs.entry.js +2 -2
- package/dist/cjs/vega-textarea.cjs.entry.js +11 -11
- package/dist/cjs/vega-time-picker_2.cjs.entry.js +20 -20
- package/dist/cjs/vega-toggle-switch.cjs.entry.js +10 -10
- package/dist/cjs/vega-tooltip_2.cjs.entry.js +15 -15
- package/dist/cjs/vega.cjs.js +15 -15
- package/dist/collection/components/vega-button/vega-button.js +9 -2
- package/dist/collection/components/vega-button-circle/vega-button-circle.js +8 -3
- package/dist/collection/components/vega-calendar/slimmers/common/controllers/vega-calendar-current-period-controller.js +7 -4
- package/dist/collection/components/vega-calendar/slimmers/common/controllers/vega-calendar-event-controller.js +21 -1
- package/dist/collection/components/vega-calendar/slimmers/common/controllers/vega-calendar-event-preivew-popover-controller.js +18 -1
- package/dist/collection/components/vega-calendar/slimmers/common/controllers/vega-calendar-post-operation-date-controller.js +14 -1
- package/dist/collection/components/vega-calendar/slimmers/common/helpers/repeat-pattern/calendar-event-repeat-pattern-factory.js +8 -9
- package/dist/collection/components/vega-calendar/slimmers/common/helpers/repeat-pattern/calendar-event-weekly-repeat-pattern.js +3 -1
- package/dist/collection/components/vega-calendar/slimmers/common/helpers/test/calendar-event-repeat-pattern-factory.test.js +34 -0
- package/dist/collection/components/vega-calendar/slimmers/common/renderers/vega-calendar-event-item-renderer.js +1 -1
- package/dist/collection/components/vega-calendar/slimmers/common/renderers/vega-calendar-event-preview-popover-renderer.js +7 -6
- package/dist/collection/components/vega-calendar/slimmers/day-view/renderers/vega-calendar-time-marker-renderer.js +31 -5
- package/dist/collection/components/vega-calendar/slimmers/day-view/renderers/vega-calendar-view-with-time-renderer.js +4 -1
- package/dist/collection/components/vega-calendar/slimmers/month-view/renderers/vega-calendar-month-event-renderer.js +11 -10
- package/dist/collection/components/vega-calendar/slimmers/month-view/renderers/vega-calendar-month-view-renderer.js +4 -1
- package/dist/collection/components/vega-calendar/vega-calendar-event-preview/slimmers/renderers/vega-calendar-event-preview-detail-renderer.js +15 -5
- package/dist/collection/components/vega-calendar/vega-calendar.js +47 -1
- package/dist/collection/components/vega-date-picker/slimmers/renderers/vega-date-picker-calendar-renderer.js +37 -3
- package/dist/collection/components/vega-date-picker/vega-date-picker.js +6 -0
- package/dist/collection/components/vega-dropdown/vega-dropdown-item/slimmers/renderers/vega-dropdown-item-renderer.js +1 -1
- package/dist/collection/components/vega-dropdown/vega-dropdown-item/vega-dropdown-item.css +4 -8
- package/dist/collection/components/vega-dropdown/vega-dropdown.js +4 -0
- package/dist/collection/components/vega-form/slimmers/controllers/vega-form-field-controller.js +351 -0
- package/dist/collection/components/vega-form/slimmers/controllers/vega-form-reset-controller.js +99 -0
- package/dist/collection/components/vega-form/slimmers/controllers/vega-form-submit-controller.js +122 -0
- package/dist/collection/components/vega-form/slimmers/renderers/native-form-renderer.js +30 -0
- package/dist/collection/components/vega-form/vega-form.js +97 -335
- package/dist/collection/components/vega-modal/vega-modal.css +4 -1
- package/dist/collection/components/vega-nav/slimmers/vega-nav-observer-slimmer.js +8 -3
- package/dist/collection/components/vega-nav/vega-left-nav-link/slimmers/controllers/vega-left-nav-link-controller.js +21 -4
- package/dist/collection/components/vega-rich-text-editor/dto/annotations/link-annotation.js +1 -1
- package/dist/collection/components/vega-rich-text-editor/dto/annotations/link-group-annotation.js +5 -7
- package/dist/collection/components/vega-rich-text-editor/dto/blocks/text-block.js +3 -5
- package/dist/collection/components/vega-rich-text-editor/dto/content-state.js +7 -2
- package/dist/collection/components/vega-rich-text-editor/slimmers/renderers/vega-rich-text-editor-renderer.js +1 -5
- package/dist/collection/components/vega-rich-text-editor/test/dto/annotations.test.js +9 -1
- package/dist/collection/components/vega-rich-text-editor/test/dto/blocks/text-block.test.js +1 -1
- package/dist/collection/components/vega-rich-text-editor/test/dto/content-state.test.js +51 -40
- package/dist/collection/helpers/calendar/calendar-date.js +10 -8
- package/dist/collection/helpers/calendar/calendar-event.js +152 -16
- package/dist/collection/helpers/calendar/calendar-period/calendar-period.abstract.js +13 -4
- package/dist/collection/helpers/calendar/calendar-period/day-period.js +4 -4
- package/dist/collection/helpers/calendar/calendar-period/month-period.js +7 -6
- package/dist/collection/helpers/calendar/calendar-period/week-period.js +3 -3
- package/dist/collection/helpers/calendar/calendar-view-generator/week-view-generator.js +1 -1
- package/dist/collection/helpers/calendar/test/calendar-date.test.js +24 -0
- package/dist/collection/helpers/calendar/test/calendar-event.test.js +71 -0
- package/dist/collection/helpers/calendar/test/calendar-period/day-period.test.js +28 -0
- package/dist/collection/helpers/calendar/test/calendar-period/month-period.test.js +35 -0
- package/dist/collection/helpers/calendar/test/calendar-period/week-period.test.js +43 -0
- package/dist/collection/helpers/calendar/test/utils.test.js +29 -1
- package/dist/collection/helpers/calendar/utils.js +46 -0
- package/dist/collection/helpers/change-manager/subject/static-subject/static-subject-title.js +0 -3
- package/dist/collection/helpers/event-manager/event-id/vega-internal-event-id.js +4 -0
- package/dist/collection/helpers/validator/form-field-controller.js +13 -3
- package/dist/collection/utils/test/ui.test.js +55 -0
- package/dist/collection/utils/ui.js +16 -3
- package/dist/esm/{app-globals-2623304e.js → app-globals-1bacb762.js} +10 -10
- package/dist/esm/{brand-switch-state-controller-slimmer-d6e4d217.js → brand-switch-state-controller-slimmer-60249013.js} +1 -1
- package/dist/esm/{child-nodes-event-prevent-slimmer-7fe3dc57.js → child-nodes-event-prevent-slimmer-f32efdee.js} +1 -1
- package/dist/esm/{child-nodes-notify-observer-slimmer-78f77c2c.js → child-nodes-notify-observer-slimmer-b676cd2b.js} +1 -1
- package/dist/esm/{code-block-23e7f8d0.js → code-block-cb657afd.js} +13 -17
- package/dist/esm/{component-value-history-controller-slimmer.abstract-df25e4a1.js → component-value-history-controller-slimmer.abstract-65a83eaf.js} +6 -6
- package/dist/esm/{dark-mode-state-controller-slimmer-0c7d1c77.js → dark-mode-state-controller-slimmer-f2b4f8ed.js} +1 -1
- package/dist/esm/{dark-mode-style-controller-972e1f06.js → dark-mode-style-controller-b7e85b6a.js} +1 -1
- package/dist/esm/{design-token-0f439510.js → design-token-3889675a.js} +1 -1
- package/dist/esm/{dom-node-subject-observer-factory-c7bc3035.js → dom-node-subject-observer-factory-ed4b89f4.js} +1 -1
- package/dist/esm/{dto-renderer-manager-65b7b1b1.js → dto-renderer-manager-8cac8f0f.js} +11 -6
- package/dist/esm/{element-appender-slimmer-bf5ca501.js → element-appender-slimmer-31b21e1b.js} +6 -6
- package/dist/esm/{event-emit-slimmer-3922d816.js → event-emit-slimmer-000ca6a7.js} +2 -2
- package/dist/esm/{form-field-controller-slimmer-f7e8845b.js → form-field-controller-slimmer-24dbc255.js} +16 -8
- package/dist/esm/{image-annotation-action-af21ea8f.js → image-annotation-action-59ea166c.js} +5 -5
- package/dist/esm/{index-057d0f70.js → index-090d31ca.js} +1 -0
- package/dist/esm/{index-7fe93427.js → index-50b32f3d.js} +2 -2
- package/dist/esm/index.js +16 -16
- package/dist/esm/{inject-keyboard-manager-109817bf.js → inject-keyboard-manager-f7d92809.js} +1 -1
- package/dist/esm/{internal-vega-event-manager-cb06e987.js → internal-vega-event-manager-13e3ed3d.js} +1 -1
- package/dist/esm/{keyboard-manager-ab521d22.js → keyboard-manager-f4bbc452.js} +1 -1
- package/dist/esm/{keyboard-manager-slimmer-cae3a002.js → keyboard-manager-slimmer-a02cbc5f.js} +1 -1
- package/dist/esm/{language-extension-d355f9aa.js → language-extension-038014ac.js} +2 -2
- package/dist/esm/loader.js +15 -15
- package/dist/esm/{public-rules-1a5da7bf.js → public-rules-a42e6f59.js} +8 -8
- package/dist/esm/{range-fac2962c.js → range-c08d8de1.js} +2 -2
- package/dist/esm/{responsive-format-facade-2904b456.js → responsive-format-facade-d8ccc742.js} +5 -5
- package/dist/esm/{rich-text-editor-required-rule-bb94d680.js → rich-text-editor-required-rule-3a8f319c.js} +1 -1
- package/dist/esm/{static-subject-title-633b3474.js → static-subject-title-52f93124.js} +1 -5
- package/dist/esm/{string-input-formatter-slimmer-69117deb.js → string-input-formatter-slimmer-c64c7855.js} +3 -3
- package/dist/esm/{style-formatter-a724e38d.js → style-formatter-ab6a9248.js} +1 -1
- package/dist/esm/{sub-state-notify-slimmer-4252a90e.js → sub-state-notify-slimmer-8b3b15ee.js} +2 -2
- package/dist/esm/{sub-state-observer-slimmer-baa8853a.js → sub-state-observer-slimmer-2b98e2c9.js} +3 -3
- package/dist/esm/{token-extension-89eeef74.js → token-extension-f5bf06a5.js} +6 -6
- package/dist/esm/{translation-833d9ef4.js → translation-f10b1e19.js} +1 -1
- package/dist/esm/{translation-slimmer-c83b52c1.js → translation-slimmer-984c9ce6.js} +1 -1
- package/dist/esm/{ui-c20be16d.js → ui-bb99c0c2.js} +16 -3
- package/dist/esm/vega-accordion.entry.js +14 -14
- package/dist/esm/vega-app-footer.entry.js +4 -4
- package/dist/esm/vega-app-header-button.entry.js +15 -15
- package/dist/esm/vega-backdrop.entry.js +2 -2
- package/dist/esm/vega-banner.entry.js +5 -5
- package/dist/esm/vega-bar-chart.entry.js +1 -1
- package/dist/esm/vega-box.entry.js +14 -14
- package/dist/esm/vega-brand-logo.entry.js +4 -4
- package/dist/esm/vega-breadcrumb.entry.js +6 -6
- package/dist/esm/vega-button-circle.entry.js +20 -17
- package/dist/esm/vega-button-group_2.entry.js +9 -9
- package/dist/esm/vega-button-link.entry.js +6 -6
- package/dist/esm/vega-button.entry.js +20 -15
- package/dist/esm/vega-calendar_4.entry.js +529 -227
- package/dist/esm/vega-card.entry.js +13 -13
- package/dist/esm/vega-carousel.entry.js +13 -13
- package/dist/esm/vega-checkbox_2.entry.js +12 -12
- package/dist/esm/vega-chip.entry.js +15 -15
- package/dist/esm/vega-code-block.entry.js +16 -16
- package/dist/esm/vega-color-picker.entry.js +10 -10
- package/dist/esm/vega-combo-box.entry.js +13 -13
- package/dist/esm/vega-counter-badge.entry.js +1 -1
- package/dist/esm/vega-date-picker_2.entry.js +63 -26
- package/dist/esm/vega-dialog_2.entry.js +16 -16
- package/dist/esm/vega-divider.entry.js +13 -13
- package/dist/esm/vega-dropdown_5.entry.js +24 -23
- package/dist/esm/vega-env-manager-8f8dc473.js +2 -2
- package/dist/esm/vega-field-error.entry.js +2 -2
- package/dist/esm/vega-field-label.entry.js +5 -5
- package/dist/esm/vega-file-uploader.entry.js +11 -11
- package/dist/esm/vega-flag-icon.entry.js +13 -13
- package/dist/esm/vega-flex.entry.js +14 -14
- package/dist/esm/vega-font.entry.js +13 -13
- package/dist/esm/vega-form.entry.js +636 -323
- package/dist/esm/vega-grid.entry.js +13 -13
- package/dist/esm/vega-hint.entry.js +1 -1
- package/dist/esm/vega-icon.entry.js +13 -13
- package/dist/esm/vega-image-uploader.entry.js +18 -18
- package/dist/esm/vega-input-credit-card.entry.js +11 -11
- package/dist/esm/vega-input-numeric.entry.js +14 -14
- package/dist/esm/vega-input-phone-number.entry.js +15 -15
- package/dist/esm/vega-input-range.entry.js +12 -12
- package/dist/esm/vega-input-select.entry.js +17 -17
- package/dist/esm/vega-input.entry.js +12 -12
- package/dist/esm/{vega-internal-event-id-5a143cd2.js → vega-internal-event-id-5c3e5f7f.js} +5 -1
- package/dist/esm/vega-item-toggle.entry.js +5 -5
- package/dist/esm/vega-left-nav_5.entry.js +45 -21
- package/dist/esm/vega-line-chart.entry.js +1 -1
- package/dist/esm/vega-loader-wrapper_2.entry.js +12 -12
- package/dist/esm/vega-page-notification_2.entry.js +3 -3
- package/dist/esm/vega-pagination-page-selector-mobile.entry.js +6 -6
- package/dist/esm/vega-pagination-page-size-selector-mobile.entry.js +7 -7
- package/dist/esm/vega-pagination.entry.js +15 -15
- package/dist/esm/vega-pie-chart.entry.js +1 -1
- package/dist/esm/vega-popover_2.entry.js +17 -17
- package/dist/esm/vega-progress-tracker.entry.js +5 -5
- package/dist/esm/vega-radio_2.entry.js +14 -14
- package/dist/esm/vega-rich-text-content.entry.js +11 -11
- package/dist/esm/vega-rich-text-editor_4.entry.js +25 -29
- package/dist/esm/vega-section-title.entry.js +1 -1
- package/dist/esm/vega-segment-control.entry.js +5 -5
- package/dist/esm/vega-selection-chip_2.entry.js +17 -17
- package/dist/esm/vega-selection-tile_2.entry.js +13 -13
- package/dist/esm/vega-sidenav_3.entry.js +15 -15
- package/dist/esm/vega-signature-capture.entry.js +17 -17
- package/dist/esm/vega-skeleton.entry.js +1 -1
- package/dist/esm/vega-slot-container.entry.js +1 -1
- package/dist/esm/vega-stepper.entry.js +11 -11
- package/dist/esm/vega-tab-group_2.entry.js +7 -7
- package/dist/esm/vega-table_8.entry.js +17 -17
- package/dist/esm/vega-text.entry.js +2 -2
- package/dist/esm/vega-textarea.entry.js +11 -11
- package/dist/esm/vega-time-picker_2.entry.js +20 -20
- package/dist/esm/vega-toggle-switch.entry.js +10 -10
- package/dist/esm/vega-tooltip_2.entry.js +15 -15
- package/dist/esm/vega.js +15 -15
- package/dist/sri/vega-sri-loader.js +147 -0
- package/dist/sri/vega-sri-manifest.json +698 -0
- package/dist/types/components/vega-calendar/slimmers/common/controllers/vega-calendar-current-period-controller.d.ts +1 -0
- package/dist/types/components/vega-calendar/slimmers/common/controllers/vega-calendar-event-controller.d.ts +6 -0
- package/dist/types/components/vega-calendar/slimmers/common/controllers/vega-calendar-event-preivew-popover-controller.d.ts +5 -0
- package/dist/types/components/vega-calendar/slimmers/common/controllers/vega-calendar-post-operation-date-controller.d.ts +6 -0
- package/dist/types/components/vega-calendar/slimmers/common/helpers/repeat-pattern/calendar-event-repeat-pattern-factory.d.ts +3 -1
- package/dist/types/components/vega-calendar/slimmers/day-view/renderers/vega-calendar-time-marker-renderer.d.ts +1 -0
- package/dist/types/components/vega-calendar/slimmers/day-view/renderers/vega-calendar-view-with-time-renderer.d.ts +1 -0
- package/dist/types/components/vega-calendar/slimmers/month-view/renderers/vega-calendar-month-view-renderer.d.ts +1 -0
- package/dist/types/components/vega-calendar/types.d.ts +5 -0
- package/dist/types/components/vega-calendar/vega-calendar-event-preview/slimmers/renderers/vega-calendar-event-preview-detail-renderer.d.ts +3 -0
- package/dist/types/components/vega-calendar/vega-calendar.d.ts +17 -0
- package/dist/types/components/vega-date-picker/slimmers/renderers/vega-date-picker-calendar-renderer.d.ts +13 -0
- package/dist/types/components/vega-date-picker/vega-date-picker.d.ts +1 -0
- package/dist/types/components/vega-dropdown/vega-dropdown.d.ts +1 -0
- package/dist/types/components/vega-form/slimmers/controllers/vega-form-field-controller.d.ts +158 -0
- package/dist/types/components/vega-form/slimmers/controllers/vega-form-reset-controller.d.ts +43 -0
- package/dist/types/components/vega-form/slimmers/controllers/vega-form-submit-controller.d.ts +55 -0
- package/dist/types/components/vega-form/slimmers/renderers/native-form-renderer.d.ts +12 -0
- package/dist/types/components/vega-form/types.d.ts +13 -0
- package/dist/types/components/vega-form/vega-form.d.ts +28 -97
- package/dist/types/components/vega-nav/slimmers/vega-nav-observer-slimmer.d.ts +3 -0
- package/dist/types/components/vega-nav/vega-left-nav-link/slimmers/controllers/vega-left-nav-link-controller.d.ts +8 -0
- package/dist/types/components/vega-rich-text-editor/dto/annotations/link-group-annotation.d.ts +0 -1
- package/dist/types/components/vega-rich-text-editor/dto/blocks/text-block.d.ts +1 -2
- package/dist/types/components/vega-rich-text-editor/dto/content-state.d.ts +2 -1
- package/dist/types/components.d.ts +42 -1
- package/dist/types/helpers/calendar/calendar-date.d.ts +5 -3
- package/dist/types/helpers/calendar/calendar-event.d.ts +50 -1
- package/dist/types/helpers/calendar/calendar-period/calendar-period.abstract.d.ts +8 -1
- package/dist/types/helpers/calendar/calendar-period/day-period.d.ts +1 -1
- package/dist/types/helpers/calendar/calendar-period/month-period.d.ts +4 -3
- package/dist/types/helpers/calendar/calendar-period/week-period.d.ts +1 -1
- package/dist/types/helpers/calendar/utils.d.ts +22 -0
- package/dist/types/helpers/change-manager/subject/static-subject/static-subject-title.d.ts +1 -4
- package/dist/types/helpers/event-manager/event-id/vega-internal-event-id.d.ts +4 -0
- package/dist/types/types/components.type.d.ts +0 -1
- package/dist/types/utils/ui.d.ts +5 -1
- package/dist/vega/index.esm.js +1 -1
- package/dist/vega/p-050bb2ad.entry.js +1 -0
- package/dist/vega/{p-3cdbee7e.js → p-053eb64a.js} +1 -1
- package/dist/vega/{p-76c7538a.entry.js → p-0685cba6.entry.js} +1 -1
- package/dist/vega/{p-476cc642.entry.js → p-0b38a01f.entry.js} +1 -1
- package/dist/vega/{p-5e4fb663.entry.js → p-0bb3be0b.entry.js} +1 -1
- package/dist/vega/{p-e74c275a.entry.js → p-12d4488b.entry.js} +1 -1
- package/dist/vega/{p-5397648b.entry.js → p-13c6a04c.entry.js} +1 -1
- package/dist/vega/{p-b6c51409.entry.js → p-185dfdd4.entry.js} +1 -1
- package/dist/vega/{p-942fc9b9.js → p-199dc74b.js} +1 -1
- package/dist/vega/p-1bd5d806.entry.js +1 -0
- package/dist/vega/p-1eb5b772.entry.js +1 -0
- package/dist/vega/{p-2591f217.entry.js → p-1f061725.entry.js} +1 -1
- package/dist/vega/{p-64c281ec.entry.js → p-1f43f551.entry.js} +1 -1
- package/dist/vega/{p-1da54ff3.js → p-2033f86e.js} +1 -1
- package/dist/vega/{p-e513f041.js → p-228de113.js} +1 -1
- package/dist/vega/{p-f1436035.js → p-24cb0a7e.js} +1 -1
- package/dist/vega/{p-f92fc49b.entry.js → p-299e14b4.entry.js} +1 -1
- package/dist/vega/{p-da6369d4.entry.js → p-2d91799a.entry.js} +1 -1
- package/dist/vega/{p-0bc93777.entry.js → p-2f4f3744.entry.js} +1 -1
- package/dist/vega/{p-b32f7aac.entry.js → p-303efbfe.entry.js} +1 -1
- package/dist/vega/p-308aa2e3.js +1 -0
- package/dist/vega/{p-d15e70d7.entry.js → p-33837794.entry.js} +1 -1
- package/dist/vega/p-33c6fb3f.entry.js +1 -0
- package/dist/vega/{p-9b2d8516.entry.js → p-3494a5f1.entry.js} +1 -1
- package/dist/vega/{p-66199d68.js → p-378e5881.js} +1 -1
- package/dist/vega/{p-bf0ced3c.js → p-39482a1a.js} +1 -1
- package/dist/vega/p-39b4c838.js +1 -0
- package/dist/vega/{p-3be7bfee.entry.js → p-3b953a24.entry.js} +1 -1
- package/dist/vega/{p-2ee4def0.js → p-3c21b875.js} +1 -1
- package/dist/vega/p-43257678.js +1 -0
- package/dist/vega/{p-4c3075ef.js → p-45ead9fe.js} +1 -1
- package/dist/vega/{p-351405f2.entry.js → p-4897bedd.entry.js} +1 -1
- package/dist/vega/{p-02a4732a.js → p-4c192985.js} +1 -1
- package/dist/vega/{p-cc5a3a1b.entry.js → p-4dd6554e.entry.js} +1 -1
- package/dist/vega/{p-d4564bfd.js → p-521d1d07.js} +1 -1
- package/dist/vega/{p-57257de0.entry.js → p-5910be31.entry.js} +1 -1
- package/dist/vega/{p-9c309b85.entry.js → p-59d70a67.entry.js} +1 -1
- package/dist/vega/{p-20223e8e.entry.js → p-5cdcd08f.entry.js} +1 -1
- package/dist/vega/{p-589b7ea3.entry.js → p-5d36cc3f.entry.js} +1 -1
- package/dist/vega/{p-09cb98f3.entry.js → p-5e1c913d.entry.js} +1 -1
- package/dist/vega/p-5e2ef0b8.entry.js +1 -0
- package/dist/vega/p-5f377954.js +1 -1
- package/dist/vega/{p-81fbf18f.entry.js → p-5f854901.entry.js} +1 -1
- package/dist/vega/p-5fec05a2.js +1 -0
- package/dist/vega/p-63596567.entry.js +1 -0
- package/dist/vega/{p-92469fa1.entry.js → p-63a5bbf4.entry.js} +1 -1
- package/dist/vega/{p-89d2cf34.js → p-64c3d021.js} +1 -1
- package/dist/vega/{p-0b36f4ce.js → p-651fe4fc.js} +1 -1
- package/dist/vega/{p-26ef2066.entry.js → p-671afda4.entry.js} +1 -1
- package/dist/vega/{p-5970369e.entry.js → p-676bee73.entry.js} +1 -1
- package/dist/vega/{p-6180c1af.entry.js → p-6a4db686.entry.js} +1 -1
- package/dist/vega/{p-614e450a.entry.js → p-6ce1e9d4.entry.js} +1 -1
- package/dist/vega/{p-460429da.entry.js → p-6d371296.entry.js} +1 -1
- package/dist/vega/{p-bc0ae89a.entry.js → p-6f96dd01.entry.js} +1 -1
- package/dist/vega/{p-2d58cf34.entry.js → p-719354e7.entry.js} +1 -1
- package/dist/vega/{p-134ed822.entry.js → p-74e684fc.entry.js} +1 -1
- package/dist/vega/{p-969066d3.entry.js → p-78d607ca.entry.js} +1 -1
- package/dist/vega/p-7c594a9f.js +1 -0
- package/dist/vega/p-7cd2b93b.js +1 -0
- package/dist/vega/{p-8a484812.entry.js → p-833d81d0.entry.js} +1 -1
- package/dist/vega/{p-4f21faf1.js → p-840c09c7.js} +1 -1
- package/dist/vega/p-852fa2d2.entry.js +1 -0
- package/dist/vega/{p-4f5a2b0c.entry.js → p-85ad1c21.entry.js} +1 -1
- package/dist/vega/{p-b4d88fce.entry.js → p-8a5c123f.entry.js} +1 -1
- package/dist/vega/{p-5313d0bc.js → p-901ff5d3.js} +1 -1
- package/dist/vega/{p-2f88ba36.entry.js → p-9439077d.entry.js} +1 -1
- package/dist/vega/{p-c2377afa.js → p-99b1492c.js} +1 -1
- package/dist/vega/{p-40924882.entry.js → p-9d492a46.entry.js} +1 -1
- package/dist/vega/p-9e6db93d.entry.js +1 -0
- package/dist/vega/{p-427b2b55.entry.js → p-a082d41b.entry.js} +1 -1
- package/dist/vega/{p-27dfa896.js → p-a4912b85.js} +1 -1
- package/dist/vega/p-a528714c.js +1 -0
- package/dist/vega/{p-521ace2d.js → p-a5713178.js} +1 -1
- package/dist/vega/{p-7cd2fac8.entry.js → p-a6010b93.entry.js} +1 -1
- package/dist/vega/{p-b110b7bd.entry.js → p-a61e2108.entry.js} +1 -1
- package/dist/vega/{p-3fba9e77.entry.js → p-a69c9e42.entry.js} +1 -1
- package/dist/vega/{p-cfb2af9c.entry.js → p-ab3c4b43.entry.js} +1 -1
- package/dist/vega/{p-8175d8de.entry.js → p-ad2055f4.entry.js} +1 -1
- package/dist/vega/{p-0717073b.entry.js → p-ae598946.entry.js} +1 -1
- package/dist/vega/{p-743c5baf.js → p-b4c25109.js} +1 -1
- package/dist/vega/{p-2608b9fe.js → p-b510e4d7.js} +1 -1
- package/dist/vega/{p-2a1b3108.entry.js → p-b68a13df.entry.js} +1 -1
- package/dist/vega/{p-320cccc5.entry.js → p-ba24f7b9.entry.js} +1 -1
- package/dist/vega/{p-2b90fae6.js → p-bc9484a6.js} +1 -1
- package/dist/vega/{p-dcae53cf.entry.js → p-c12000ee.entry.js} +1 -1
- package/dist/vega/{p-25c831a4.entry.js → p-c1fa6088.entry.js} +2 -2
- package/dist/vega/{p-ab29f968.js → p-c241f615.js} +1 -1
- package/dist/vega/{p-6244b0ad.entry.js → p-c682d53c.entry.js} +1 -1
- package/dist/vega/{p-c61f8ca6.entry.js → p-c8a3fb7f.entry.js} +1 -1
- package/dist/vega/{p-0ec14fbc.entry.js → p-c96d28dc.entry.js} +1 -1
- package/dist/vega/p-cef9f638.js +1 -0
- package/dist/vega/{p-648134d2.entry.js → p-cf211582.entry.js} +1 -1
- package/dist/vega/p-d3137a6e.entry.js +1 -0
- package/dist/vega/p-d418ecc1.entry.js +1 -0
- package/dist/vega/p-d5d6dae6.js +1 -0
- package/dist/vega/p-d5ff8b7f.js +1 -0
- package/dist/vega/p-d9671d27.js +1 -0
- package/dist/vega/{p-7bad6577.entry.js → p-dabba918.entry.js} +1 -1
- package/dist/vega/{p-dadc6ab3.js → p-dc92fec6.js} +1 -1
- package/dist/vega/{p-36ae2dd3.entry.js → p-e5af5a4d.entry.js} +1 -1
- package/dist/vega/{p-b1054e18.entry.js → p-e853105a.entry.js} +1 -1
- package/dist/vega/{p-d72abacd.entry.js → p-e9b86dac.entry.js} +1 -1
- package/dist/vega/p-ebfc4323.entry.js +1 -0
- package/dist/vega/{p-81765b4b.entry.js → p-f83739d0.entry.js} +1 -1
- package/dist/vega/{p-6585cfd5.entry.js → p-fbc85265.entry.js} +1 -1
- package/dist/vega/{p-3ab20f9e.entry.js → p-fbd38139.entry.js} +1 -1
- package/dist/vega/{p-bdd9ef3b.js → p-fddca002.js} +1 -1
- package/dist/vega/{p-de1ee131.entry.js → p-fee972e6.entry.js} +1 -1
- package/dist/vega/{p-b73532c0.entry.js → p-fff13ed1.entry.js} +1 -1
- package/dist/vega/vega.esm.js +1 -1
- package/package.json +3 -2
- package/dist/vega/p-02b29c18.js +0 -1
- package/dist/vega/p-079f5d94.entry.js +0 -1
- package/dist/vega/p-0e3cd270.entry.js +0 -1
- package/dist/vega/p-0e954b9b.js +0 -1
- package/dist/vega/p-10454aa5.entry.js +0 -1
- package/dist/vega/p-258f9603.js +0 -1
- package/dist/vega/p-51d40b0d.entry.js +0 -1
- package/dist/vega/p-56ff8559.entry.js +0 -1
- package/dist/vega/p-575235c8.js +0 -1
- package/dist/vega/p-657446a3.entry.js +0 -1
- package/dist/vega/p-6908117a.js +0 -1
- package/dist/vega/p-846ae5fb.js +0 -1
- package/dist/vega/p-893d5dfa.js +0 -1
- package/dist/vega/p-8a6b820a.entry.js +0 -1
- package/dist/vega/p-8a877e12.js +0 -1
- package/dist/vega/p-9ffd2a96.entry.js +0 -1
- package/dist/vega/p-bb61f015.js +0 -1
- package/dist/vega/p-c7726252.js +0 -1
- package/dist/vega/p-d85b0bfa.entry.js +0 -1
- package/dist/vega/p-d87c3058.entry.js +0 -1
- package/dist/vega/p-e0729c4d.entry.js +0 -1
- package/dist/vega/p-e5cd6521.js +0 -1
- /package/dist/vega/{p-48a58baf.js → p-6b2342e0.js} +0 -0
|
@@ -262,6 +262,9 @@ export class VegaDatePicker {
|
|
|
262
262
|
watchDisabled() {
|
|
263
263
|
methodPlaceholder();
|
|
264
264
|
}
|
|
265
|
+
watchIsDateDisabled() {
|
|
266
|
+
methodPlaceholder();
|
|
267
|
+
}
|
|
265
268
|
/**
|
|
266
269
|
* Invoke this method to close the calendar dropdown
|
|
267
270
|
* associated with the date picker.
|
|
@@ -925,6 +928,9 @@ export class VegaDatePicker {
|
|
|
925
928
|
}, {
|
|
926
929
|
"propName": "disabled",
|
|
927
930
|
"methodName": "watchDisabled"
|
|
931
|
+
}, {
|
|
932
|
+
"propName": "isDateDisabled",
|
|
933
|
+
"methodName": "watchIsDateDisabled"
|
|
928
934
|
}]; }
|
|
929
935
|
}
|
|
930
936
|
__decorate([
|
|
@@ -24,7 +24,7 @@ export class VegaDropdownItemRenderer extends VegaSlimmer {
|
|
|
24
24
|
'danger': this.danger && this.selectType === 'none',
|
|
25
25
|
}, tabIndex: this.disabled ? -1 : 0,
|
|
26
26
|
/* eslint-disable-next-line react/jsx-no-bind */
|
|
27
|
-
onClick: (e) => this.onSelect(e), onKeyDown: createEnterKeyHandlerToTriggerClick(), style: this.height > 0 && {
|
|
27
|
+
onClick: this.disabled ? undefined : (e) => this.onSelect(e), onKeyDown: createEnterKeyHandlerToTriggerClick(), style: this.height > 0 && {
|
|
28
28
|
height: `${this.height}px`,
|
|
29
29
|
boxSizing: 'border-box',
|
|
30
30
|
overflow: 'hidden',
|
|
@@ -20,11 +20,6 @@
|
|
|
20
20
|
gap: 8px;
|
|
21
21
|
}
|
|
22
22
|
|
|
23
|
-
:host li:focus {
|
|
24
|
-
background-color: rgba(var(--v-bg-quaternary, 241, 248, 251, 1));
|
|
25
|
-
outline: 0;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
23
|
:host li,
|
|
29
24
|
:host li a {
|
|
30
25
|
color: rgba(var(--v-text-primary, 32, 54, 69, 1));
|
|
@@ -66,17 +61,18 @@
|
|
|
66
61
|
}
|
|
67
62
|
}
|
|
68
63
|
|
|
69
|
-
:host li:hover {
|
|
64
|
+
:host li:not(.vega-dropdown-item-disabled):hover {
|
|
70
65
|
background-color: rgba(var(--v-bg-quaternary, 241, 248, 251, 1));
|
|
71
66
|
}
|
|
72
67
|
|
|
73
|
-
:host li:focus {
|
|
68
|
+
:host li:not(.vega-dropdown-item-disabled):focus {
|
|
74
69
|
background-color: rgba(var(--v-bg-quaternary, 241, 248, 251, 1));
|
|
70
|
+
outline: 0;
|
|
75
71
|
}
|
|
76
72
|
|
|
77
73
|
:host li.vega-dropdown-item-disabled {
|
|
78
74
|
color: rgba(var(--v-text-disabled, 176, 180, 181, 1));
|
|
79
|
-
|
|
75
|
+
cursor: default;
|
|
80
76
|
}
|
|
81
77
|
|
|
82
78
|
:host li.vega-dropdown-item-disabled .item-prefix,
|
|
@@ -153,6 +153,7 @@ export class VegaDropdown {
|
|
|
153
153
|
/**
|
|
154
154
|
* Specifies the display rule for items in the dropdown.
|
|
155
155
|
*
|
|
156
|
+
* @VegaWarning Specifies the display rule for items in the dropdown, only be active if matchTargetWidth is true or maxWidth has value.
|
|
156
157
|
* @vegaVersion 1.13.0
|
|
157
158
|
*/
|
|
158
159
|
this.itemDisplayRule = 'newline';
|
|
@@ -655,6 +656,9 @@ export class VegaDropdown {
|
|
|
655
656
|
"optional": false,
|
|
656
657
|
"docs": {
|
|
657
658
|
"tags": [{
|
|
659
|
+
"name": "VegaWarning",
|
|
660
|
+
"text": "Specifies the display rule for items in the dropdown, only be active if matchTargetWidth is true or maxWidth has value."
|
|
661
|
+
}, {
|
|
658
662
|
"name": "vegaVersion",
|
|
659
663
|
"text": "1.13.0"
|
|
660
664
|
}],
|
package/dist/collection/components/vega-form/slimmers/controllers/vega-form-field-controller.js
ADDED
|
@@ -0,0 +1,351 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
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;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { InjectVegaSlimmer, MapToComponentField, MapToComponentMethod, VegaSlimmer } from 'vega-slimmer/core';
|
|
8
|
+
import { ImmutableMap } from '../../../../helpers/immutable/immutable-map';
|
|
9
|
+
import { isElementVisible, isParent } from '../../../../utils/ui';
|
|
10
|
+
import { Observer } from '../../../../helpers/change-manager/observer/observer';
|
|
11
|
+
import ChangeManager from '../../../../helpers/change-manager/change-manager';
|
|
12
|
+
import { FORM_ELEMENT_VALIDATE, FORM_ELEMENT_VALUE_CHANGE, FORM_FIELD_ELEMENT_DISCONNECTED, FORM_FIELD_PENDING_VALID_CHANGE, } from '../../../../helpers/change-manager/subject/static-subject/static-subject-title';
|
|
13
|
+
import { FormFieldControllerSlimmer } from '../../../../helpers/slimmers/form-field-controller-slimmer';
|
|
14
|
+
import { ChildNodesNotifyObserverSlimmer, } from '../../../../helpers/event-manager/slimmers/child-nodes-notify-observer-slimmer';
|
|
15
|
+
import { isObjectArrayLike } from '../../../../utils/array';
|
|
16
|
+
import domNodeSubjectFactory from '../../../../helpers/change-manager/subject/dom-node-subject/dom-node-subject-factory';
|
|
17
|
+
import { VegaInternalValid } from '../../../../helpers/event-manager/event-id/vega-internal-event-id';
|
|
18
|
+
/**
|
|
19
|
+
* The form field controller for vega form to manage the form field states.
|
|
20
|
+
*/
|
|
21
|
+
export class VegaFormFieldController extends VegaSlimmer {
|
|
22
|
+
constructor() {
|
|
23
|
+
super(...arguments);
|
|
24
|
+
this.childNotifyObserver = new ChildNodesNotifyObserverSlimmer(FORM_ELEMENT_VALIDATE, (input) => this.updateInternalValidStatus(input));
|
|
25
|
+
this.childNodeValueChangeObserver = new ChildNodesNotifyObserverSlimmer(FORM_ELEMENT_VALUE_CHANGE, () => {
|
|
26
|
+
this.isTouched = true;
|
|
27
|
+
});
|
|
28
|
+
this._invalidFieldPathMap = new ImmutableMap(new Map(), (newMap) => {
|
|
29
|
+
this._invalidFieldPathMap = newMap;
|
|
30
|
+
this.updateIsValidFlag();
|
|
31
|
+
});
|
|
32
|
+
/**
|
|
33
|
+
* The form field element pending async valid map
|
|
34
|
+
*/
|
|
35
|
+
this._pendingValidFieldPathMap = new ImmutableMap(new Map(), (newMap) => {
|
|
36
|
+
this._pendingValidFieldPathMap = newMap;
|
|
37
|
+
this.updateIsValidFlag();
|
|
38
|
+
});
|
|
39
|
+
/**
|
|
40
|
+
* If the element is valid, remove it from the set of
|
|
41
|
+
* invalid elements. If the element is invalid,
|
|
42
|
+
* add it to the set of invalid elements.
|
|
43
|
+
*
|
|
44
|
+
* @param {NotifyObserverPayload<boolean>} payload - CustomEvent<boolean> the vegaValidate subject notify from child elements
|
|
45
|
+
*/
|
|
46
|
+
this.updateInternalValidStatus = (payload) => {
|
|
47
|
+
if (payload.host !== this.host) {
|
|
48
|
+
const target = payload.host;
|
|
49
|
+
const isElementValid = payload.detail;
|
|
50
|
+
if (FormFieldControllerSlimmer.isValidFormField(target) &&
|
|
51
|
+
this.shouldVisitElement(target, false, false)) {
|
|
52
|
+
if (isElementValid) {
|
|
53
|
+
this.invalidFieldPathMap.delete(target);
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
this.invalidFieldPathMap.set(target, target.dataset['vegaForm']);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Component lifecycle - [connectedCallback]
|
|
64
|
+
*/
|
|
65
|
+
connectedCallback() {
|
|
66
|
+
this.initFormFieldDisconnectedObserver();
|
|
67
|
+
this.registerFormFieldPendingValid();
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* When the vegaForm is deleted, it is necessary to notify the parent's vegaForm to update its isValid status.
|
|
71
|
+
*/
|
|
72
|
+
disconnectedCallback() {
|
|
73
|
+
ChangeManager.notify(FORM_FIELD_ELEMENT_DISCONNECTED, { host: this.host });
|
|
74
|
+
ChangeManager.unregister(FORM_FIELD_ELEMENT_DISCONNECTED, this.formFieldDisconnectedObserver);
|
|
75
|
+
ChangeManager.unregister(FORM_FIELD_PENDING_VALID_CHANGE, this.formFieldPendingValidObserver);
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* @inheritDoc
|
|
79
|
+
*/
|
|
80
|
+
async getValue(option) {
|
|
81
|
+
const result = {};
|
|
82
|
+
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
83
|
+
const formFieldName = this.getFormFieldName(element);
|
|
84
|
+
if (isForm) {
|
|
85
|
+
result[formFieldName] = await element.getValue(option);
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
result[formFieldName] = this.getFormFieldValue(element);
|
|
89
|
+
}
|
|
90
|
+
}, option);
|
|
91
|
+
return (isObjectArrayLike(result) ? Object.values(result) : result);
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* @inheritDoc
|
|
95
|
+
*/
|
|
96
|
+
async setValue(value, option) {
|
|
97
|
+
if (value) {
|
|
98
|
+
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
99
|
+
const formFieldName = this.getFormFieldName(element);
|
|
100
|
+
if (isForm) {
|
|
101
|
+
await element.setValue(value[formFieldName], option);
|
|
102
|
+
}
|
|
103
|
+
else {
|
|
104
|
+
await element.componentOnReady(); // Link issue https://gethired.atlassian.net/browse/GHUI-385
|
|
105
|
+
if (value[formFieldName] !== undefined) {
|
|
106
|
+
// If element have setValue method, we will directly call this method, otherwise we set the value to value property.
|
|
107
|
+
typeof element['setValue'] === 'function'
|
|
108
|
+
? await element['setValue'](value[formFieldName])
|
|
109
|
+
: (element['value'] = value[formFieldName]);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}, option);
|
|
113
|
+
this.isTouched = false;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* @inheritDoc
|
|
118
|
+
*/
|
|
119
|
+
async valid(showError = true) {
|
|
120
|
+
const result = { isValid: true, invalidFields: [] };
|
|
121
|
+
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
122
|
+
if (typeof element['valid'] === 'function' && isForm) {
|
|
123
|
+
const nestedFormValidationResult = await element.valid(showError);
|
|
124
|
+
if (!nestedFormValidationResult.isValid) {
|
|
125
|
+
result.isValid = false;
|
|
126
|
+
result.invalidFields.push(...nestedFormValidationResult.invalidFields);
|
|
127
|
+
result.invalidFieldsErrorMessages = Object.assign(Object.assign({}, result.invalidFieldsErrorMessages), nestedFormValidationResult.invalidFieldsErrorMessages);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
const { isValid, message } = await this.handleChildFormFieldElementValid(element, showError);
|
|
132
|
+
if (!isValid) {
|
|
133
|
+
result.isValid = false;
|
|
134
|
+
result.invalidFields.push(this.getFormFieldName(element));
|
|
135
|
+
if (!result.invalidFieldsErrorMessages) {
|
|
136
|
+
result.invalidFieldsErrorMessages = {};
|
|
137
|
+
}
|
|
138
|
+
result.invalidFieldsErrorMessages[this.getFormFieldName(element)] = message;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
return result;
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* The getter for the {@link _invalidFieldPathMap}
|
|
146
|
+
*
|
|
147
|
+
* @returns {ImmutableMap<HTMLElement, string>} The map of invalid field elements and their paths
|
|
148
|
+
*/
|
|
149
|
+
get invalidFieldPathMap() {
|
|
150
|
+
return this._invalidFieldPathMap;
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* The getter for the {@link _pendingValidFieldPathMap}
|
|
154
|
+
*
|
|
155
|
+
* @returns {ImmutableMap<HTMLElement, string>} The map of pending valid field elements and their paths
|
|
156
|
+
*/
|
|
157
|
+
get pendingValidFieldPathMap() {
|
|
158
|
+
return this._pendingValidFieldPathMap;
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Set the isTouched property of the form.
|
|
162
|
+
*
|
|
163
|
+
* @param {boolean} isTouched - The new value for isTouched.
|
|
164
|
+
*/
|
|
165
|
+
setIsTouched(isTouched) {
|
|
166
|
+
this.isTouched = isTouched;
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* It returns the value of data-vega-form that the given element is associated with.
|
|
170
|
+
*
|
|
171
|
+
* @param {HTMLElement} element - The element that is being validated.
|
|
172
|
+
* @returns {string} The name of the field.
|
|
173
|
+
*/
|
|
174
|
+
getFormFieldName(element) {
|
|
175
|
+
return element.dataset['vegaForm'];
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Check if the given element is part of the current form.
|
|
179
|
+
*
|
|
180
|
+
* @param {HTMLElement} element - The element to check.
|
|
181
|
+
* @returns {boolean} True if the element is part of the current form, false otherwise.
|
|
182
|
+
*/
|
|
183
|
+
isElementInCurrentForm(element) {
|
|
184
|
+
return this.invalidFieldPathMap.has(element) || isParent(element, this.host);
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Navigate the immediate child node under current vega form element with the following strategy
|
|
188
|
+
* - if a matched vega field element found, will pass it to the visitor method passed in
|
|
189
|
+
* - if a non-matched node found, it will call itself recursively and pass the node as the second parameter
|
|
190
|
+
* Once the navigation is finished, it will wait for all the pending visitor/self-invocation promise finished before return
|
|
191
|
+
*
|
|
192
|
+
* @param {(element: HTMLElement, isForm: boolean) => Promise<void>} visitor async callback method that will be invoked if a matched vega field element found
|
|
193
|
+
* @param {FormControlOption} [option] form control option to skip disabled/invisible components
|
|
194
|
+
* @param {HTMLElement} [startElementNode=this.host] the element to start the navigation, default to current vega form host
|
|
195
|
+
* @returns {Promise<void>} return void wrapped with promise to notify the navigation is done
|
|
196
|
+
*/
|
|
197
|
+
async navigateVegaFormChildren(visitor, option, startElementNode = this.host) {
|
|
198
|
+
const promiseQueue = [];
|
|
199
|
+
Array.from(startElementNode.children).forEach((child) => {
|
|
200
|
+
if (FormFieldControllerSlimmer.isValidFormField(child)) {
|
|
201
|
+
if (this.shouldVisitElement(child, option === null || option === void 0 ? void 0 : option.skipDisabled, option === null || option === void 0 ? void 0 : option.skipInvisible)) {
|
|
202
|
+
promiseQueue.push(visitor(child, child.tagName === 'VEGA-FORM'));
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
promiseQueue.push(this.navigateVegaFormChildren(visitor, option, child));
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
await Promise.all(promiseQueue);
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* Update the {@link isValid} property value based on the size of {@link invalidFieldPathMap}
|
|
213
|
+
* If the number of invalid elements is zero, then the form is valid.
|
|
214
|
+
*/
|
|
215
|
+
updateIsValidFlag() {
|
|
216
|
+
this.isValid = this.pendingValidFieldPathMap.size > 0 ? null : this.invalidFieldPathMap.size === 0;
|
|
217
|
+
}
|
|
218
|
+
/**
|
|
219
|
+
* Registers an observer with the ChangeManager that will be notified when a form field's pending validation state changes.
|
|
220
|
+
*/
|
|
221
|
+
registerFormFieldPendingValid() {
|
|
222
|
+
this.formFieldPendingValidObserver = new Observer(this.canAcceptFormFieldPendingValid.bind(this), this.handleFieldPendingValid.bind(this));
|
|
223
|
+
ChangeManager.register(FORM_FIELD_PENDING_VALID_CHANGE, this.formFieldPendingValidObserver);
|
|
224
|
+
}
|
|
225
|
+
/**
|
|
226
|
+
* Can accept handler for FORM_FIELD_PENDING_VALID_CHANGE.
|
|
227
|
+
*
|
|
228
|
+
* @param {PendingValidPayload} payload - The payload containing the host element that triggered the pending valid change event.
|
|
229
|
+
* @returns {boolean} True if the host element is part of the current form, false otherwise.
|
|
230
|
+
*/
|
|
231
|
+
canAcceptFormFieldPendingValid(payload) {
|
|
232
|
+
return this.isElementInCurrentForm(payload.host);
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* Handles the pending valid state change for a form field.
|
|
236
|
+
*
|
|
237
|
+
* @param {PendingValidPayload} payload - The payload containing the host element and its pending valid state.
|
|
238
|
+
*/
|
|
239
|
+
handleFieldPendingValid(payload) {
|
|
240
|
+
if (typeof payload.detail === 'boolean') {
|
|
241
|
+
this.pendingValidFieldPathMap.delete(payload.host);
|
|
242
|
+
}
|
|
243
|
+
else {
|
|
244
|
+
this.pendingValidFieldPathMap.set(payload.host, payload.host.dataset['vegaForm']);
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* This function registers an observer with the ChangeManager that will be notified when an element
|
|
249
|
+
* delete operation is triggered
|
|
250
|
+
*/
|
|
251
|
+
initFormFieldDisconnectedObserver() {
|
|
252
|
+
this.formFieldDisconnectedObserver = new Observer(this.canAcceptFormFieldDisconnectedOperation.bind(this), this.updateInvalidFieldPath.bind(this));
|
|
253
|
+
ChangeManager.register(FORM_FIELD_ELEMENT_DISCONNECTED, this.formFieldDisconnectedObserver);
|
|
254
|
+
}
|
|
255
|
+
/**
|
|
256
|
+
* If the deleted element is a child or grandchild of current vegaForm, the isValid of all these vegaForms will be updated.
|
|
257
|
+
*
|
|
258
|
+
* @param {DisconnectedElementOperationPayload} payload - the delete element and vegaForm array.
|
|
259
|
+
* @returns {boolean} A boolean value.
|
|
260
|
+
*/
|
|
261
|
+
canAcceptFormFieldDisconnectedOperation(payload) {
|
|
262
|
+
return this.invalidFieldPathMap.has(payload.host);
|
|
263
|
+
}
|
|
264
|
+
/**
|
|
265
|
+
* Get the fieldName of the deleted element in the current vegaForm, delete it from the invalidFieldPathSet array, and update isValid at the same time.
|
|
266
|
+
*
|
|
267
|
+
* @param {DisconnectedElementOperationPayload} payload - the delete element and vegaForm array.
|
|
268
|
+
*/
|
|
269
|
+
async updateInvalidFieldPath(payload) {
|
|
270
|
+
this.invalidFieldPathMap.delete(payload.host);
|
|
271
|
+
this.pendingValidFieldPathMap.delete(payload.host);
|
|
272
|
+
}
|
|
273
|
+
/**
|
|
274
|
+
* Return true if the HTMLElement has data-vega-form property, and it's not disabled and not invisible if these two properties have to be checked.
|
|
275
|
+
*
|
|
276
|
+
* @param {HTMLElement} element - The HTMLElement to check.
|
|
277
|
+
* @param {boolean} skipDisabled - If true, then disabled form fields will be skipped.
|
|
278
|
+
* @param {boolean} skipInvisible - If true, only visible elements will be visited.
|
|
279
|
+
* @returns {boolean} a boolean value.
|
|
280
|
+
*/
|
|
281
|
+
shouldVisitElement(element, skipDisabled, skipInvisible) {
|
|
282
|
+
return (this.getFormFieldName(element) &&
|
|
283
|
+
(!skipDisabled || !element['disabled']) &&
|
|
284
|
+
(!skipInvisible || isElementVisible(element)));
|
|
285
|
+
}
|
|
286
|
+
/**
|
|
287
|
+
* It retrieves the value of a form field element.
|
|
288
|
+
*
|
|
289
|
+
* @param {HTMLElement} element - The form field element.
|
|
290
|
+
* @returns {unknown} The value of the form field element.
|
|
291
|
+
*/
|
|
292
|
+
getFormFieldValue(element) {
|
|
293
|
+
return typeof element['value'] === 'undefined'
|
|
294
|
+
? // use element.getAttribute since the value property is not available in unit testing
|
|
295
|
+
element.getAttribute('value')
|
|
296
|
+
: element['value'];
|
|
297
|
+
}
|
|
298
|
+
/**
|
|
299
|
+
* It handles the validation of a child form field element.
|
|
300
|
+
*
|
|
301
|
+
* @param {HTMLElement} element - The form field element to validate.
|
|
302
|
+
* @param {boolean | 'rule'} showError - Whether to show error messages.
|
|
303
|
+
* @returns {Promise<EvaluateResultBase>} The validation result.
|
|
304
|
+
*/
|
|
305
|
+
async handleChildFormFieldElementValid(element, showError) {
|
|
306
|
+
const subject = domNodeSubjectFactory.getSubject(element, VegaInternalValid);
|
|
307
|
+
const { isValid, message } = await new Promise((resolve) => {
|
|
308
|
+
//This setTimeout method here to avoid the dom node subject observer not existing and blocks the promise status
|
|
309
|
+
const timerId = setTimeout(() => {
|
|
310
|
+
resolve({ isValid: true, message: '' });
|
|
311
|
+
}, 2000);
|
|
312
|
+
ChangeManager.notify(subject, {
|
|
313
|
+
host: element,
|
|
314
|
+
message: showError,
|
|
315
|
+
promiseResolve: resolve,
|
|
316
|
+
timerId,
|
|
317
|
+
});
|
|
318
|
+
});
|
|
319
|
+
return { isValid, message };
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
__decorate([
|
|
323
|
+
MapToComponentField()
|
|
324
|
+
], VegaFormFieldController.prototype, "host", void 0);
|
|
325
|
+
__decorate([
|
|
326
|
+
MapToComponentField({ writable: true })
|
|
327
|
+
], VegaFormFieldController.prototype, "isValid", void 0);
|
|
328
|
+
__decorate([
|
|
329
|
+
MapToComponentField({ writable: true })
|
|
330
|
+
], VegaFormFieldController.prototype, "isTouched", void 0);
|
|
331
|
+
__decorate([
|
|
332
|
+
InjectVegaSlimmer()
|
|
333
|
+
], VegaFormFieldController.prototype, "childNotifyObserver", void 0);
|
|
334
|
+
__decorate([
|
|
335
|
+
InjectVegaSlimmer()
|
|
336
|
+
], VegaFormFieldController.prototype, "childNodeValueChangeObserver", void 0);
|
|
337
|
+
__decorate([
|
|
338
|
+
MapToComponentMethod('connectedCallback')
|
|
339
|
+
], VegaFormFieldController.prototype, "connectedCallback", null);
|
|
340
|
+
__decorate([
|
|
341
|
+
MapToComponentMethod('disconnectedCallback')
|
|
342
|
+
], VegaFormFieldController.prototype, "disconnectedCallback", null);
|
|
343
|
+
__decorate([
|
|
344
|
+
MapToComponentMethod('getValue')
|
|
345
|
+
], VegaFormFieldController.prototype, "getValue", null);
|
|
346
|
+
__decorate([
|
|
347
|
+
MapToComponentMethod('setValue')
|
|
348
|
+
], VegaFormFieldController.prototype, "setValue", null);
|
|
349
|
+
__decorate([
|
|
350
|
+
MapToComponentMethod('valid')
|
|
351
|
+
], VegaFormFieldController.prototype, "valid", null);
|
package/dist/collection/components/vega-form/slimmers/controllers/vega-form-reset-controller.js
ADDED
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
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;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { MapToComponentField, MapToComponentMethod, VegaSlimmer } from 'vega-slimmer/core';
|
|
8
|
+
import ChangeManager from '../../../../helpers/change-manager/change-manager';
|
|
9
|
+
import { FORM_RESET_OPERATION_TRIGGERED } from '../../../../helpers/change-manager/subject/static-subject/static-subject-title';
|
|
10
|
+
import { VegaInternalFormReset } from '../../../../helpers/event-manager/event-id/vega-internal-event-id';
|
|
11
|
+
import { Observer } from '../../../../helpers/change-manager/observer/observer';
|
|
12
|
+
import domNodesSubjectFactory from '../../../../helpers/change-manager/subject/dom-node-subject/dom-node-subject-factory';
|
|
13
|
+
import changeManager from '../../../../helpers/change-manager/change-manager';
|
|
14
|
+
import { findParent } from '../../../../utils/ui';
|
|
15
|
+
/**
|
|
16
|
+
* Reset controller for handling form reset events in the VegaForm component.
|
|
17
|
+
*/
|
|
18
|
+
export class VegaFormResetController extends VegaSlimmer {
|
|
19
|
+
/**
|
|
20
|
+
* Component lifecycle - [connectedCallback]
|
|
21
|
+
*/
|
|
22
|
+
connectedCallback() {
|
|
23
|
+
this.registerFormResetChangeManager();
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Component lifecycle - [disconnectedCallback]
|
|
27
|
+
*/
|
|
28
|
+
disconnectedCallback() {
|
|
29
|
+
this.unregisterFormResetChangeManager();
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* @inheritDoc
|
|
33
|
+
*/
|
|
34
|
+
async reset(defaultValueMap = {}, option) {
|
|
35
|
+
await this.vegaFormFieldController.navigateVegaFormChildren(async (element, isForm) => {
|
|
36
|
+
const formFieldName = this.vegaFormFieldController.getFormFieldName(element);
|
|
37
|
+
if (isForm) {
|
|
38
|
+
await element.reset(defaultValueMap[formFieldName] || {}, option);
|
|
39
|
+
}
|
|
40
|
+
}, option);
|
|
41
|
+
ChangeManager.notify(FORM_RESET_OPERATION_TRIGGERED, {
|
|
42
|
+
host: this.host,
|
|
43
|
+
defaultValueMap,
|
|
44
|
+
option,
|
|
45
|
+
});
|
|
46
|
+
this.vegaFormFieldController.setIsTouched(false);
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Registers the form reset event observer with the ChangeManager.
|
|
50
|
+
*/
|
|
51
|
+
registerFormResetChangeManager() {
|
|
52
|
+
var _a;
|
|
53
|
+
const outerForm = (_a = findParent(this.host, 'vega-form', { outerMost: true })) !== null && _a !== void 0 ? _a : this.host;
|
|
54
|
+
this.formResetEventObserver = new Observer(this.canAcceptFormResetEvent.bind(this), this.handleResetEvents.bind(this));
|
|
55
|
+
ChangeManager.register(domNodesSubjectFactory.getSubject(outerForm, VegaInternalFormReset), this.formResetEventObserver);
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Unregister the form reset event observer from the ChangeManager.
|
|
59
|
+
*/
|
|
60
|
+
unregisterFormResetChangeManager() {
|
|
61
|
+
var _a;
|
|
62
|
+
const outerForm = (_a = findParent(this.host, 'vega-form', { outerMost: true })) !== null && _a !== void 0 ? _a : this.host;
|
|
63
|
+
changeManager.unregister(domNodesSubjectFactory.getSubject(outerForm, VegaInternalFormReset), this.formResetEventObserver);
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Can accept form reset event.
|
|
67
|
+
*
|
|
68
|
+
* @param {FormEventsPayload} payload - The form events payload.
|
|
69
|
+
* @returns {boolean} True if the event can be accepted, false otherwise.
|
|
70
|
+
*/
|
|
71
|
+
canAcceptFormResetEvent(payload) {
|
|
72
|
+
return this.vegaFormFieldController.isElementInCurrentForm(payload.host);
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Handles reset events by resetting the form and emitting a reset event.
|
|
76
|
+
*/
|
|
77
|
+
async handleResetEvents() {
|
|
78
|
+
await this.host.reset();
|
|
79
|
+
this.resetEventEmitter.emit();
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
__decorate([
|
|
83
|
+
MapToComponentField()
|
|
84
|
+
], VegaFormResetController.prototype, "host", void 0);
|
|
85
|
+
__decorate([
|
|
86
|
+
MapToComponentField()
|
|
87
|
+
], VegaFormResetController.prototype, "vegaFormFieldController", void 0);
|
|
88
|
+
__decorate([
|
|
89
|
+
MapToComponentField()
|
|
90
|
+
], VegaFormResetController.prototype, "resetEventEmitter", void 0);
|
|
91
|
+
__decorate([
|
|
92
|
+
MapToComponentMethod('connectedCallback')
|
|
93
|
+
], VegaFormResetController.prototype, "connectedCallback", null);
|
|
94
|
+
__decorate([
|
|
95
|
+
MapToComponentMethod('disconnectedCallback')
|
|
96
|
+
], VegaFormResetController.prototype, "disconnectedCallback", null);
|
|
97
|
+
__decorate([
|
|
98
|
+
MapToComponentMethod('reset')
|
|
99
|
+
], VegaFormResetController.prototype, "reset", null);
|
package/dist/collection/components/vega-form/slimmers/controllers/vega-form-submit-controller.js
ADDED
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
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;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { MapToComponentField, MapToComponentMethod, VegaSlimmer } from 'vega-slimmer/core';
|
|
8
|
+
import { tryGetDocument } from '../../../../utils/try-get-document';
|
|
9
|
+
import { VegaInternalFormSubmit } from '../../../../helpers/event-manager/event-id/vega-internal-event-id';
|
|
10
|
+
import changeManager from '../../../../helpers/change-manager/change-manager';
|
|
11
|
+
import domNodesSubjectFactory from '../../../../helpers/change-manager/subject/dom-node-subject/dom-node-subject-factory';
|
|
12
|
+
import { Observer } from '../../../../helpers/change-manager/observer/observer';
|
|
13
|
+
import { findParent } from '../../../../utils/ui';
|
|
14
|
+
/**
|
|
15
|
+
* Controller responsible for handling form submission in the VegaForm component.
|
|
16
|
+
*/
|
|
17
|
+
export class VegaFormSubmitController extends VegaSlimmer {
|
|
18
|
+
/**
|
|
19
|
+
* Component lifecycle - [connectedCallback]
|
|
20
|
+
*/
|
|
21
|
+
connectedCallback() {
|
|
22
|
+
this.registerFormSubmitChangeManager();
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Component lifecycle - [disconnectedCallback]
|
|
26
|
+
*/
|
|
27
|
+
disconnectedCallback() {
|
|
28
|
+
this.unregisterFormSubmitChangeManager();
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Submits the form using native HTML form submission with all current field values.
|
|
32
|
+
*
|
|
33
|
+
* This method collects all form field values, creates hidden input elements for each field,
|
|
34
|
+
* appends them to a container inside the native form, and then triggers the native
|
|
35
|
+
* `requestSubmit()` method to submit the form.
|
|
36
|
+
*
|
|
37
|
+
* The method ensures that the form data is available in the native form for submission,
|
|
38
|
+
* which is useful when `useNativeForm` is enabled.
|
|
39
|
+
*
|
|
40
|
+
* @returns {Promise<void>} Resolves when the form submission process is complete.
|
|
41
|
+
*/
|
|
42
|
+
async submitWithFormData() {
|
|
43
|
+
if (!this.useNativeForm)
|
|
44
|
+
return;
|
|
45
|
+
const data = await this.host.getValue();
|
|
46
|
+
for (const dataKey in data) {
|
|
47
|
+
const hiddenInput = tryGetDocument().createElement('input');
|
|
48
|
+
hiddenInput.type = 'hidden';
|
|
49
|
+
hiddenInput.name = dataKey;
|
|
50
|
+
hiddenInput.value = data[dataKey];
|
|
51
|
+
this.nativeFormRenderer.getNativeFormRef().append(hiddenInput);
|
|
52
|
+
}
|
|
53
|
+
this.nativeFormRenderer.getNativeFormRef().requestSubmit();
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Registers the form submit event observer with the ChangeManager.
|
|
57
|
+
*/
|
|
58
|
+
registerFormSubmitChangeManager() {
|
|
59
|
+
var _a;
|
|
60
|
+
this.formSubmitEventObserver = new Observer(this.canAcceptFormSubmitEvent.bind(this), this.handleSubmitEvents.bind(this));
|
|
61
|
+
const outerForm = (_a = findParent(this.host, 'vega-form', { outerMost: true })) !== null && _a !== void 0 ? _a : this.host;
|
|
62
|
+
changeManager.register(domNodesSubjectFactory.getSubject(outerForm, VegaInternalFormSubmit), this.formSubmitEventObserver);
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Unregister the form submit event observer from the ChangeManager.
|
|
66
|
+
*/
|
|
67
|
+
unregisterFormSubmitChangeManager() {
|
|
68
|
+
var _a;
|
|
69
|
+
const outerForm = (_a = findParent(this.host, 'vega-form', { outerMost: true })) !== null && _a !== void 0 ? _a : this.host;
|
|
70
|
+
changeManager.unregister(domNodesSubjectFactory.getSubject(outerForm, VegaInternalFormSubmit), this.formSubmitEventObserver);
|
|
71
|
+
}
|
|
72
|
+
/*
|
|
73
|
+
* The below method is e2e-test covered in
|
|
74
|
+
* @see{module:vega-form-field-enter-to-submit-e2e}
|
|
75
|
+
*/
|
|
76
|
+
/* istanbul ignore next */
|
|
77
|
+
/**
|
|
78
|
+
* Can accept handler for FORM_SUBMIT.
|
|
79
|
+
*
|
|
80
|
+
* @param {FormEventsPayload} payload - The payload containing the host element that triggered the submit event.
|
|
81
|
+
* @returns {boolean} True if the host element is part of the current form, false otherwise.
|
|
82
|
+
*/
|
|
83
|
+
canAcceptFormSubmitEvent(payload) {
|
|
84
|
+
return this.vegaFormFieldController.isElementInCurrentForm(payload.host);
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Handles the form submission process.
|
|
88
|
+
*
|
|
89
|
+
* @returns {Promise<void>} Resolves when the submission process is complete.
|
|
90
|
+
*/
|
|
91
|
+
async handleSubmitEvents() {
|
|
92
|
+
const valid = await this.host.valid();
|
|
93
|
+
if (valid.isValid) {
|
|
94
|
+
const formValue = await this.host.getValue();
|
|
95
|
+
const submitEvent = this.submitEventEmitter.emit(formValue);
|
|
96
|
+
if (!submitEvent.defaultPrevented) {
|
|
97
|
+
await this.submitWithFormData();
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
__decorate([
|
|
103
|
+
MapToComponentField()
|
|
104
|
+
], VegaFormSubmitController.prototype, "host", void 0);
|
|
105
|
+
__decorate([
|
|
106
|
+
MapToComponentField()
|
|
107
|
+
], VegaFormSubmitController.prototype, "useNativeForm", void 0);
|
|
108
|
+
__decorate([
|
|
109
|
+
MapToComponentField()
|
|
110
|
+
], VegaFormSubmitController.prototype, "nativeFormRenderer", void 0);
|
|
111
|
+
__decorate([
|
|
112
|
+
MapToComponentField()
|
|
113
|
+
], VegaFormSubmitController.prototype, "submitEventEmitter", void 0);
|
|
114
|
+
__decorate([
|
|
115
|
+
MapToComponentField()
|
|
116
|
+
], VegaFormSubmitController.prototype, "vegaFormFieldController", void 0);
|
|
117
|
+
__decorate([
|
|
118
|
+
MapToComponentMethod('connectedCallback')
|
|
119
|
+
], VegaFormSubmitController.prototype, "connectedCallback", null);
|
|
120
|
+
__decorate([
|
|
121
|
+
MapToComponentMethod('disconnectedCallback')
|
|
122
|
+
], VegaFormSubmitController.prototype, "disconnectedCallback", null);
|