@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
|
@@ -1,40 +1,41 @@
|
|
|
1
|
-
import { r as registerInstance, c as createEvent,
|
|
2
|
-
import { F as FormFieldControllerSlimmer } from './form-field-controller-slimmer-f7e8845b.js';
|
|
1
|
+
import { h, r as registerInstance, c as createEvent, H as Host, g as getElement } from './index-090d31ca.js';
|
|
3
2
|
import { C as ChangeManager } from './change-manager-6a7eb88c.js';
|
|
4
|
-
import {
|
|
5
|
-
import { f as FIELD_ERROR_MESSAGE_CHANGE, g as FORM_ELEMENT_VALIDATE, b as FORM_ELEMENT_VALUE_CHANGE, d as FORM_FIELD_ELEMENT_DISCONNECTED, c as FORM_FIELD_PENDING_VALID_CHANGE, e as FORM_RESET_OPERATION_TRIGGERED, F as FORM_SUBMIT, a as FORM_RESET } from './static-subject-title-633b3474.js';
|
|
6
|
-
import { d as isObjectArrayLike } from './array-7888f339.js';
|
|
3
|
+
import { d as FIELD_ERROR_MESSAGE_CHANGE, e as FORM_ELEMENT_VALIDATE, F as FORM_ELEMENT_VALUE_CHANGE, b as FORM_FIELD_ELEMENT_DISCONNECTED, a as FORM_FIELD_PENDING_VALID_CHANGE, c as FORM_RESET_OPERATION_TRIGGERED } from './static-subject-title-52f93124.js';
|
|
7
4
|
import { s as sanitizeVegaComponent } from './component-7d906393.js';
|
|
8
|
-
import { f as findParent, d as isElementVisible, b as isParent } from './ui-c20be16d.js';
|
|
9
|
-
import { I as ImmutableMap } from './immutable-map-612922a2.js';
|
|
10
5
|
import { c as MapToComponentField, M as MapToComponentMethod, V as VegaSlimmer, I as InjectVegaSlimmer } from './global-slimmer-registry-17c4efd4.js';
|
|
6
|
+
import { m as methodPlaceholder } from './placeholder-bf562081.js';
|
|
11
7
|
import { V as VegaComponentUsageRuntimeMetricsSlimmer, I as InjectVegaGlobalSlimmer } from './component-usage-runtime-metrics-a84cc93e.js';
|
|
12
|
-
import { c as createEventEmitSlimmer } from './event-emit-slimmer-
|
|
13
|
-
import { C as ChildNodesEventPreventSlimmer } from './child-nodes-event-prevent-slimmer-
|
|
14
|
-
import { y as VegaFormSubmit, z as VegaFormReset, A as VegaValidate
|
|
15
|
-
import {
|
|
16
|
-
import {
|
|
17
|
-
import {
|
|
18
|
-
import {
|
|
8
|
+
import { c as createEventEmitSlimmer } from './event-emit-slimmer-000ca6a7.js';
|
|
9
|
+
import { C as ChildNodesEventPreventSlimmer } from './child-nodes-event-prevent-slimmer-f32efdee.js';
|
|
10
|
+
import { d as domNodeSubjectFactory, y as VegaFormSubmit, z as VegaFormReset, A as VegaValidate } from './dom-node-subject-observer-factory-ed4b89f4.js';
|
|
11
|
+
import { c as createSubStateNotifySlimmer } from './sub-state-notify-slimmer-8b3b15ee.js';
|
|
12
|
+
import { S as SubStateObserverSlimmer } from './sub-state-observer-slimmer-2b98e2c9.js';
|
|
13
|
+
import { F as FormFieldControllerSlimmer } from './form-field-controller-slimmer-24dbc255.js';
|
|
14
|
+
import { t as tryGetDocument } from './try-get-document-bef0f526.js';
|
|
15
|
+
import { d as VegaInternalFormSubmit, g as VegaInternalValid, e as VegaInternalFormReset } from './vega-internal-event-id-5c3e5f7f.js';
|
|
16
|
+
import { O as Observer } from './observer-3959f9dd.js';
|
|
17
|
+
import { f as findParent, b as isParent, d as isElementVisible } from './ui-bb99c0c2.js';
|
|
18
|
+
import { I as ImmutableMap } from './immutable-map-612922a2.js';
|
|
19
|
+
import { C as ChildNodesNotifyObserverSlimmer } from './child-nodes-notify-observer-slimmer-b676cd2b.js';
|
|
20
|
+
import { d as isObjectArrayLike } from './array-7888f339.js';
|
|
21
|
+
import './dynamic-slimmer-90b8af32.js';
|
|
22
|
+
import './internal-vega-event-manager-13e3ed3d.js';
|
|
23
|
+
import './vega-env-manager-8f8dc473.js';
|
|
24
|
+
import './feature-flag-controller-51659753.js';
|
|
25
|
+
import './index-e9da316f.js';
|
|
26
|
+
import './_commonjsHelpers-9943807e.js';
|
|
19
27
|
import './string-a953eafc.js';
|
|
20
28
|
import './create-public-api-runtime-metrics-slimmer-bedf3a1e.js';
|
|
21
|
-
import './
|
|
22
|
-
import './translation-833d9ef4.js';
|
|
29
|
+
import './translation-f10b1e19.js';
|
|
23
30
|
import './page-resize-observer-slimmer-0bf7fbf3.js';
|
|
24
31
|
import './ui-8424715a.js';
|
|
25
32
|
import './breakpoints-d9faf11c.js';
|
|
26
|
-
import './try-get-document-bef0f526.js';
|
|
27
33
|
import './internal-form-field-validation-rule.abstract-f5b6bdbf.js';
|
|
28
34
|
import './mutation-observer-slimmer-58ebc13c.js';
|
|
29
35
|
import './mutation-observer-filters-1a054fb0.js';
|
|
30
36
|
import './number-4398f2e1.js';
|
|
31
|
-
import './internal-vega-event-manager-cb06e987.js';
|
|
32
|
-
import './vega-env-manager-8f8dc473.js';
|
|
33
|
-
import './feature-flag-controller-51659753.js';
|
|
34
|
-
import './index-e9da316f.js';
|
|
35
|
-
import './_commonjsHelpers-9943807e.js';
|
|
36
37
|
|
|
37
|
-
var __decorate$
|
|
38
|
+
var __decorate$6 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
38
39
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
39
40
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
40
41
|
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;
|
|
@@ -57,14 +58,14 @@ class VegaFormNestStateController extends SubStateObserverSlimmer {
|
|
|
57
58
|
});
|
|
58
59
|
}
|
|
59
60
|
}
|
|
60
|
-
__decorate$
|
|
61
|
+
__decorate$6([
|
|
61
62
|
MapToComponentField()
|
|
62
63
|
], VegaFormNestStateController.prototype, "host", void 0);
|
|
63
|
-
__decorate$
|
|
64
|
+
__decorate$6([
|
|
64
65
|
MapToComponentField({ writable: true })
|
|
65
66
|
], VegaFormNestStateController.prototype, "disableBlurValidation", void 0);
|
|
66
67
|
|
|
67
|
-
var __decorate$
|
|
68
|
+
var __decorate$5 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
68
69
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
69
70
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
70
71
|
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;
|
|
@@ -134,12 +135,590 @@ class VegaFormFieldValidationStateController extends VegaSlimmer {
|
|
|
134
135
|
ChangeManager.notify(FORM_ELEMENT_VALIDATE, { host: target, detail: isValid });
|
|
135
136
|
}
|
|
136
137
|
}
|
|
138
|
+
__decorate$5([
|
|
139
|
+
MapToComponentField()
|
|
140
|
+
], VegaFormFieldValidationStateController.prototype, "host", void 0);
|
|
141
|
+
__decorate$5([
|
|
142
|
+
MapToComponentMethod('setValidationStates')
|
|
143
|
+
], VegaFormFieldValidationStateController.prototype, "setValidationStates", null);
|
|
144
|
+
|
|
145
|
+
var __decorate$4 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
146
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
147
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
148
|
+
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;
|
|
149
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
150
|
+
};
|
|
151
|
+
/**
|
|
152
|
+
* The native form renderer for vega form to render a native HTML form element.
|
|
153
|
+
*/
|
|
154
|
+
class NativeFormRenderer extends VegaSlimmer {
|
|
155
|
+
getNativeFormRef() {
|
|
156
|
+
return this.nativeFormRef;
|
|
157
|
+
}
|
|
158
|
+
render() {
|
|
159
|
+
return (h("form", { action: this.action, method: this.method, ref: (ref) => {
|
|
160
|
+
if (ref) {
|
|
161
|
+
this.nativeFormRef = ref;
|
|
162
|
+
}
|
|
163
|
+
} },
|
|
164
|
+
h("slot", null)));
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
__decorate$4([
|
|
168
|
+
MapToComponentField()
|
|
169
|
+
], NativeFormRenderer.prototype, "method", void 0);
|
|
170
|
+
__decorate$4([
|
|
171
|
+
MapToComponentField()
|
|
172
|
+
], NativeFormRenderer.prototype, "action", void 0);
|
|
173
|
+
|
|
174
|
+
var __decorate$3 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
175
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
176
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
177
|
+
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;
|
|
178
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
179
|
+
};
|
|
180
|
+
/**
|
|
181
|
+
* Controller responsible for handling form submission in the VegaForm component.
|
|
182
|
+
*/
|
|
183
|
+
class VegaFormSubmitController extends VegaSlimmer {
|
|
184
|
+
/**
|
|
185
|
+
* Component lifecycle - [connectedCallback]
|
|
186
|
+
*/
|
|
187
|
+
connectedCallback() {
|
|
188
|
+
this.registerFormSubmitChangeManager();
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Component lifecycle - [disconnectedCallback]
|
|
192
|
+
*/
|
|
193
|
+
disconnectedCallback() {
|
|
194
|
+
this.unregisterFormSubmitChangeManager();
|
|
195
|
+
}
|
|
196
|
+
/**
|
|
197
|
+
* Submits the form using native HTML form submission with all current field values.
|
|
198
|
+
*
|
|
199
|
+
* This method collects all form field values, creates hidden input elements for each field,
|
|
200
|
+
* appends them to a container inside the native form, and then triggers the native
|
|
201
|
+
* `requestSubmit()` method to submit the form.
|
|
202
|
+
*
|
|
203
|
+
* The method ensures that the form data is available in the native form for submission,
|
|
204
|
+
* which is useful when `useNativeForm` is enabled.
|
|
205
|
+
*
|
|
206
|
+
* @returns {Promise<void>} Resolves when the form submission process is complete.
|
|
207
|
+
*/
|
|
208
|
+
async submitWithFormData() {
|
|
209
|
+
if (!this.useNativeForm)
|
|
210
|
+
return;
|
|
211
|
+
const data = await this.host.getValue();
|
|
212
|
+
for (const dataKey in data) {
|
|
213
|
+
const hiddenInput = tryGetDocument().createElement('input');
|
|
214
|
+
hiddenInput.type = 'hidden';
|
|
215
|
+
hiddenInput.name = dataKey;
|
|
216
|
+
hiddenInput.value = data[dataKey];
|
|
217
|
+
this.nativeFormRenderer.getNativeFormRef().append(hiddenInput);
|
|
218
|
+
}
|
|
219
|
+
this.nativeFormRenderer.getNativeFormRef().requestSubmit();
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Registers the form submit event observer with the ChangeManager.
|
|
223
|
+
*/
|
|
224
|
+
registerFormSubmitChangeManager() {
|
|
225
|
+
var _a;
|
|
226
|
+
this.formSubmitEventObserver = new Observer(this.canAcceptFormSubmitEvent.bind(this), this.handleSubmitEvents.bind(this));
|
|
227
|
+
const outerForm = (_a = findParent(this.host, 'vega-form', { outerMost: true })) !== null && _a !== void 0 ? _a : this.host;
|
|
228
|
+
ChangeManager.register(domNodeSubjectFactory.getSubject(outerForm, VegaInternalFormSubmit), this.formSubmitEventObserver);
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Unregister the form submit event observer from the ChangeManager.
|
|
232
|
+
*/
|
|
233
|
+
unregisterFormSubmitChangeManager() {
|
|
234
|
+
var _a;
|
|
235
|
+
const outerForm = (_a = findParent(this.host, 'vega-form', { outerMost: true })) !== null && _a !== void 0 ? _a : this.host;
|
|
236
|
+
ChangeManager.unregister(domNodeSubjectFactory.getSubject(outerForm, VegaInternalFormSubmit), this.formSubmitEventObserver);
|
|
237
|
+
}
|
|
238
|
+
/*
|
|
239
|
+
* The below method is e2e-test covered in
|
|
240
|
+
* @see{module:vega-form-field-enter-to-submit-e2e}
|
|
241
|
+
*/
|
|
242
|
+
/* istanbul ignore next */
|
|
243
|
+
/**
|
|
244
|
+
* Can accept handler for FORM_SUBMIT.
|
|
245
|
+
*
|
|
246
|
+
* @param {FormEventsPayload} payload - The payload containing the host element that triggered the submit event.
|
|
247
|
+
* @returns {boolean} True if the host element is part of the current form, false otherwise.
|
|
248
|
+
*/
|
|
249
|
+
canAcceptFormSubmitEvent(payload) {
|
|
250
|
+
return this.vegaFormFieldController.isElementInCurrentForm(payload.host);
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* Handles the form submission process.
|
|
254
|
+
*
|
|
255
|
+
* @returns {Promise<void>} Resolves when the submission process is complete.
|
|
256
|
+
*/
|
|
257
|
+
async handleSubmitEvents() {
|
|
258
|
+
const valid = await this.host.valid();
|
|
259
|
+
if (valid.isValid) {
|
|
260
|
+
const formValue = await this.host.getValue();
|
|
261
|
+
const submitEvent = this.submitEventEmitter.emit(formValue);
|
|
262
|
+
if (!submitEvent.defaultPrevented) {
|
|
263
|
+
await this.submitWithFormData();
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
__decorate$3([
|
|
269
|
+
MapToComponentField()
|
|
270
|
+
], VegaFormSubmitController.prototype, "host", void 0);
|
|
271
|
+
__decorate$3([
|
|
272
|
+
MapToComponentField()
|
|
273
|
+
], VegaFormSubmitController.prototype, "useNativeForm", void 0);
|
|
274
|
+
__decorate$3([
|
|
275
|
+
MapToComponentField()
|
|
276
|
+
], VegaFormSubmitController.prototype, "nativeFormRenderer", void 0);
|
|
277
|
+
__decorate$3([
|
|
278
|
+
MapToComponentField()
|
|
279
|
+
], VegaFormSubmitController.prototype, "submitEventEmitter", void 0);
|
|
280
|
+
__decorate$3([
|
|
281
|
+
MapToComponentField()
|
|
282
|
+
], VegaFormSubmitController.prototype, "vegaFormFieldController", void 0);
|
|
283
|
+
__decorate$3([
|
|
284
|
+
MapToComponentMethod('connectedCallback')
|
|
285
|
+
], VegaFormSubmitController.prototype, "connectedCallback", null);
|
|
286
|
+
__decorate$3([
|
|
287
|
+
MapToComponentMethod('disconnectedCallback')
|
|
288
|
+
], VegaFormSubmitController.prototype, "disconnectedCallback", null);
|
|
289
|
+
|
|
290
|
+
var __decorate$2 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
291
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
292
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
293
|
+
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;
|
|
294
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
295
|
+
};
|
|
296
|
+
/**
|
|
297
|
+
* The form field controller for vega form to manage the form field states.
|
|
298
|
+
*/
|
|
299
|
+
class VegaFormFieldController extends VegaSlimmer {
|
|
300
|
+
constructor() {
|
|
301
|
+
super(...arguments);
|
|
302
|
+
this.childNotifyObserver = new ChildNodesNotifyObserverSlimmer(FORM_ELEMENT_VALIDATE, (input) => this.updateInternalValidStatus(input));
|
|
303
|
+
this.childNodeValueChangeObserver = new ChildNodesNotifyObserverSlimmer(FORM_ELEMENT_VALUE_CHANGE, () => {
|
|
304
|
+
this.isTouched = true;
|
|
305
|
+
});
|
|
306
|
+
this._invalidFieldPathMap = new ImmutableMap(new Map(), (newMap) => {
|
|
307
|
+
this._invalidFieldPathMap = newMap;
|
|
308
|
+
this.updateIsValidFlag();
|
|
309
|
+
});
|
|
310
|
+
/**
|
|
311
|
+
* The form field element pending async valid map
|
|
312
|
+
*/
|
|
313
|
+
this._pendingValidFieldPathMap = new ImmutableMap(new Map(), (newMap) => {
|
|
314
|
+
this._pendingValidFieldPathMap = newMap;
|
|
315
|
+
this.updateIsValidFlag();
|
|
316
|
+
});
|
|
317
|
+
/**
|
|
318
|
+
* If the element is valid, remove it from the set of
|
|
319
|
+
* invalid elements. If the element is invalid,
|
|
320
|
+
* add it to the set of invalid elements.
|
|
321
|
+
*
|
|
322
|
+
* @param {NotifyObserverPayload<boolean>} payload - CustomEvent<boolean> the vegaValidate subject notify from child elements
|
|
323
|
+
*/
|
|
324
|
+
this.updateInternalValidStatus = (payload) => {
|
|
325
|
+
if (payload.host !== this.host) {
|
|
326
|
+
const target = payload.host;
|
|
327
|
+
const isElementValid = payload.detail;
|
|
328
|
+
if (FormFieldControllerSlimmer.isValidFormField(target) &&
|
|
329
|
+
this.shouldVisitElement(target, false, false)) {
|
|
330
|
+
if (isElementValid) {
|
|
331
|
+
this.invalidFieldPathMap.delete(target);
|
|
332
|
+
}
|
|
333
|
+
else {
|
|
334
|
+
this.invalidFieldPathMap.set(target, target.dataset['vegaForm']);
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
};
|
|
339
|
+
}
|
|
340
|
+
/**
|
|
341
|
+
* Component lifecycle - [connectedCallback]
|
|
342
|
+
*/
|
|
343
|
+
connectedCallback() {
|
|
344
|
+
this.initFormFieldDisconnectedObserver();
|
|
345
|
+
this.registerFormFieldPendingValid();
|
|
346
|
+
}
|
|
347
|
+
/**
|
|
348
|
+
* When the vegaForm is deleted, it is necessary to notify the parent's vegaForm to update its isValid status.
|
|
349
|
+
*/
|
|
350
|
+
disconnectedCallback() {
|
|
351
|
+
ChangeManager.notify(FORM_FIELD_ELEMENT_DISCONNECTED, { host: this.host });
|
|
352
|
+
ChangeManager.unregister(FORM_FIELD_ELEMENT_DISCONNECTED, this.formFieldDisconnectedObserver);
|
|
353
|
+
ChangeManager.unregister(FORM_FIELD_PENDING_VALID_CHANGE, this.formFieldPendingValidObserver);
|
|
354
|
+
}
|
|
355
|
+
/**
|
|
356
|
+
* @inheritDoc
|
|
357
|
+
*/
|
|
358
|
+
async getValue(option) {
|
|
359
|
+
const result = {};
|
|
360
|
+
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
361
|
+
const formFieldName = this.getFormFieldName(element);
|
|
362
|
+
if (isForm) {
|
|
363
|
+
result[formFieldName] = await element.getValue(option);
|
|
364
|
+
}
|
|
365
|
+
else {
|
|
366
|
+
result[formFieldName] = this.getFormFieldValue(element);
|
|
367
|
+
}
|
|
368
|
+
}, option);
|
|
369
|
+
return (isObjectArrayLike(result) ? Object.values(result) : result);
|
|
370
|
+
}
|
|
371
|
+
/**
|
|
372
|
+
* @inheritDoc
|
|
373
|
+
*/
|
|
374
|
+
async setValue(value, option) {
|
|
375
|
+
if (value) {
|
|
376
|
+
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
377
|
+
const formFieldName = this.getFormFieldName(element);
|
|
378
|
+
if (isForm) {
|
|
379
|
+
await element.setValue(value[formFieldName], option);
|
|
380
|
+
}
|
|
381
|
+
else {
|
|
382
|
+
await element.componentOnReady(); // Link issue https://gethired.atlassian.net/browse/GHUI-385
|
|
383
|
+
if (value[formFieldName] !== undefined) {
|
|
384
|
+
// If element have setValue method, we will directly call this method, otherwise we set the value to value property.
|
|
385
|
+
typeof element['setValue'] === 'function'
|
|
386
|
+
? await element['setValue'](value[formFieldName])
|
|
387
|
+
: (element['value'] = value[formFieldName]);
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
}, option);
|
|
391
|
+
this.isTouched = false;
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
/**
|
|
395
|
+
* @inheritDoc
|
|
396
|
+
*/
|
|
397
|
+
async valid(showError = true) {
|
|
398
|
+
const result = { isValid: true, invalidFields: [] };
|
|
399
|
+
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
400
|
+
if (typeof element['valid'] === 'function' && isForm) {
|
|
401
|
+
const nestedFormValidationResult = await element.valid(showError);
|
|
402
|
+
if (!nestedFormValidationResult.isValid) {
|
|
403
|
+
result.isValid = false;
|
|
404
|
+
result.invalidFields.push(...nestedFormValidationResult.invalidFields);
|
|
405
|
+
result.invalidFieldsErrorMessages = Object.assign(Object.assign({}, result.invalidFieldsErrorMessages), nestedFormValidationResult.invalidFieldsErrorMessages);
|
|
406
|
+
}
|
|
407
|
+
}
|
|
408
|
+
else {
|
|
409
|
+
const { isValid, message } = await this.handleChildFormFieldElementValid(element, showError);
|
|
410
|
+
if (!isValid) {
|
|
411
|
+
result.isValid = false;
|
|
412
|
+
result.invalidFields.push(this.getFormFieldName(element));
|
|
413
|
+
if (!result.invalidFieldsErrorMessages) {
|
|
414
|
+
result.invalidFieldsErrorMessages = {};
|
|
415
|
+
}
|
|
416
|
+
result.invalidFieldsErrorMessages[this.getFormFieldName(element)] = message;
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
});
|
|
420
|
+
return result;
|
|
421
|
+
}
|
|
422
|
+
/**
|
|
423
|
+
* The getter for the {@link _invalidFieldPathMap}
|
|
424
|
+
*
|
|
425
|
+
* @returns {ImmutableMap<HTMLElement, string>} The map of invalid field elements and their paths
|
|
426
|
+
*/
|
|
427
|
+
get invalidFieldPathMap() {
|
|
428
|
+
return this._invalidFieldPathMap;
|
|
429
|
+
}
|
|
430
|
+
/**
|
|
431
|
+
* The getter for the {@link _pendingValidFieldPathMap}
|
|
432
|
+
*
|
|
433
|
+
* @returns {ImmutableMap<HTMLElement, string>} The map of pending valid field elements and their paths
|
|
434
|
+
*/
|
|
435
|
+
get pendingValidFieldPathMap() {
|
|
436
|
+
return this._pendingValidFieldPathMap;
|
|
437
|
+
}
|
|
438
|
+
/**
|
|
439
|
+
* Set the isTouched property of the form.
|
|
440
|
+
*
|
|
441
|
+
* @param {boolean} isTouched - The new value for isTouched.
|
|
442
|
+
*/
|
|
443
|
+
setIsTouched(isTouched) {
|
|
444
|
+
this.isTouched = isTouched;
|
|
445
|
+
}
|
|
446
|
+
/**
|
|
447
|
+
* It returns the value of data-vega-form that the given element is associated with.
|
|
448
|
+
*
|
|
449
|
+
* @param {HTMLElement} element - The element that is being validated.
|
|
450
|
+
* @returns {string} The name of the field.
|
|
451
|
+
*/
|
|
452
|
+
getFormFieldName(element) {
|
|
453
|
+
return element.dataset['vegaForm'];
|
|
454
|
+
}
|
|
455
|
+
/**
|
|
456
|
+
* Check if the given element is part of the current form.
|
|
457
|
+
*
|
|
458
|
+
* @param {HTMLElement} element - The element to check.
|
|
459
|
+
* @returns {boolean} True if the element is part of the current form, false otherwise.
|
|
460
|
+
*/
|
|
461
|
+
isElementInCurrentForm(element) {
|
|
462
|
+
return this.invalidFieldPathMap.has(element) || isParent(element, this.host);
|
|
463
|
+
}
|
|
464
|
+
/**
|
|
465
|
+
* Navigate the immediate child node under current vega form element with the following strategy
|
|
466
|
+
* - if a matched vega field element found, will pass it to the visitor method passed in
|
|
467
|
+
* - if a non-matched node found, it will call itself recursively and pass the node as the second parameter
|
|
468
|
+
* Once the navigation is finished, it will wait for all the pending visitor/self-invocation promise finished before return
|
|
469
|
+
*
|
|
470
|
+
* @param {(element: HTMLElement, isForm: boolean) => Promise<void>} visitor async callback method that will be invoked if a matched vega field element found
|
|
471
|
+
* @param {FormControlOption} [option] form control option to skip disabled/invisible components
|
|
472
|
+
* @param {HTMLElement} [startElementNode=this.host] the element to start the navigation, default to current vega form host
|
|
473
|
+
* @returns {Promise<void>} return void wrapped with promise to notify the navigation is done
|
|
474
|
+
*/
|
|
475
|
+
async navigateVegaFormChildren(visitor, option, startElementNode = this.host) {
|
|
476
|
+
const promiseQueue = [];
|
|
477
|
+
Array.from(startElementNode.children).forEach((child) => {
|
|
478
|
+
if (FormFieldControllerSlimmer.isValidFormField(child)) {
|
|
479
|
+
if (this.shouldVisitElement(child, option === null || option === void 0 ? void 0 : option.skipDisabled, option === null || option === void 0 ? void 0 : option.skipInvisible)) {
|
|
480
|
+
promiseQueue.push(visitor(child, child.tagName === 'VEGA-FORM'));
|
|
481
|
+
}
|
|
482
|
+
}
|
|
483
|
+
else {
|
|
484
|
+
promiseQueue.push(this.navigateVegaFormChildren(visitor, option, child));
|
|
485
|
+
}
|
|
486
|
+
});
|
|
487
|
+
await Promise.all(promiseQueue);
|
|
488
|
+
}
|
|
489
|
+
/**
|
|
490
|
+
* Update the {@link isValid} property value based on the size of {@link invalidFieldPathMap}
|
|
491
|
+
* If the number of invalid elements is zero, then the form is valid.
|
|
492
|
+
*/
|
|
493
|
+
updateIsValidFlag() {
|
|
494
|
+
this.isValid = this.pendingValidFieldPathMap.size > 0 ? null : this.invalidFieldPathMap.size === 0;
|
|
495
|
+
}
|
|
496
|
+
/**
|
|
497
|
+
* Registers an observer with the ChangeManager that will be notified when a form field's pending validation state changes.
|
|
498
|
+
*/
|
|
499
|
+
registerFormFieldPendingValid() {
|
|
500
|
+
this.formFieldPendingValidObserver = new Observer(this.canAcceptFormFieldPendingValid.bind(this), this.handleFieldPendingValid.bind(this));
|
|
501
|
+
ChangeManager.register(FORM_FIELD_PENDING_VALID_CHANGE, this.formFieldPendingValidObserver);
|
|
502
|
+
}
|
|
503
|
+
/**
|
|
504
|
+
* Can accept handler for FORM_FIELD_PENDING_VALID_CHANGE.
|
|
505
|
+
*
|
|
506
|
+
* @param {PendingValidPayload} payload - The payload containing the host element that triggered the pending valid change event.
|
|
507
|
+
* @returns {boolean} True if the host element is part of the current form, false otherwise.
|
|
508
|
+
*/
|
|
509
|
+
canAcceptFormFieldPendingValid(payload) {
|
|
510
|
+
return this.isElementInCurrentForm(payload.host);
|
|
511
|
+
}
|
|
512
|
+
/**
|
|
513
|
+
* Handles the pending valid state change for a form field.
|
|
514
|
+
*
|
|
515
|
+
* @param {PendingValidPayload} payload - The payload containing the host element and its pending valid state.
|
|
516
|
+
*/
|
|
517
|
+
handleFieldPendingValid(payload) {
|
|
518
|
+
if (typeof payload.detail === 'boolean') {
|
|
519
|
+
this.pendingValidFieldPathMap.delete(payload.host);
|
|
520
|
+
}
|
|
521
|
+
else {
|
|
522
|
+
this.pendingValidFieldPathMap.set(payload.host, payload.host.dataset['vegaForm']);
|
|
523
|
+
}
|
|
524
|
+
}
|
|
525
|
+
/**
|
|
526
|
+
* This function registers an observer with the ChangeManager that will be notified when an element
|
|
527
|
+
* delete operation is triggered
|
|
528
|
+
*/
|
|
529
|
+
initFormFieldDisconnectedObserver() {
|
|
530
|
+
this.formFieldDisconnectedObserver = new Observer(this.canAcceptFormFieldDisconnectedOperation.bind(this), this.updateInvalidFieldPath.bind(this));
|
|
531
|
+
ChangeManager.register(FORM_FIELD_ELEMENT_DISCONNECTED, this.formFieldDisconnectedObserver);
|
|
532
|
+
}
|
|
533
|
+
/**
|
|
534
|
+
* If the deleted element is a child or grandchild of current vegaForm, the isValid of all these vegaForms will be updated.
|
|
535
|
+
*
|
|
536
|
+
* @param {DisconnectedElementOperationPayload} payload - the delete element and vegaForm array.
|
|
537
|
+
* @returns {boolean} A boolean value.
|
|
538
|
+
*/
|
|
539
|
+
canAcceptFormFieldDisconnectedOperation(payload) {
|
|
540
|
+
return this.invalidFieldPathMap.has(payload.host);
|
|
541
|
+
}
|
|
542
|
+
/**
|
|
543
|
+
* Get the fieldName of the deleted element in the current vegaForm, delete it from the invalidFieldPathSet array, and update isValid at the same time.
|
|
544
|
+
*
|
|
545
|
+
* @param {DisconnectedElementOperationPayload} payload - the delete element and vegaForm array.
|
|
546
|
+
*/
|
|
547
|
+
async updateInvalidFieldPath(payload) {
|
|
548
|
+
this.invalidFieldPathMap.delete(payload.host);
|
|
549
|
+
this.pendingValidFieldPathMap.delete(payload.host);
|
|
550
|
+
}
|
|
551
|
+
/**
|
|
552
|
+
* 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.
|
|
553
|
+
*
|
|
554
|
+
* @param {HTMLElement} element - The HTMLElement to check.
|
|
555
|
+
* @param {boolean} skipDisabled - If true, then disabled form fields will be skipped.
|
|
556
|
+
* @param {boolean} skipInvisible - If true, only visible elements will be visited.
|
|
557
|
+
* @returns {boolean} a boolean value.
|
|
558
|
+
*/
|
|
559
|
+
shouldVisitElement(element, skipDisabled, skipInvisible) {
|
|
560
|
+
return (this.getFormFieldName(element) &&
|
|
561
|
+
(!skipDisabled || !element['disabled']) &&
|
|
562
|
+
(!skipInvisible || isElementVisible(element)));
|
|
563
|
+
}
|
|
564
|
+
/**
|
|
565
|
+
* It retrieves the value of a form field element.
|
|
566
|
+
*
|
|
567
|
+
* @param {HTMLElement} element - The form field element.
|
|
568
|
+
* @returns {unknown} The value of the form field element.
|
|
569
|
+
*/
|
|
570
|
+
getFormFieldValue(element) {
|
|
571
|
+
return typeof element['value'] === 'undefined'
|
|
572
|
+
? // use element.getAttribute since the value property is not available in unit testing
|
|
573
|
+
element.getAttribute('value')
|
|
574
|
+
: element['value'];
|
|
575
|
+
}
|
|
576
|
+
/**
|
|
577
|
+
* It handles the validation of a child form field element.
|
|
578
|
+
*
|
|
579
|
+
* @param {HTMLElement} element - The form field element to validate.
|
|
580
|
+
* @param {boolean | 'rule'} showError - Whether to show error messages.
|
|
581
|
+
* @returns {Promise<EvaluateResultBase>} The validation result.
|
|
582
|
+
*/
|
|
583
|
+
async handleChildFormFieldElementValid(element, showError) {
|
|
584
|
+
const subject = domNodeSubjectFactory.getSubject(element, VegaInternalValid);
|
|
585
|
+
const { isValid, message } = await new Promise((resolve) => {
|
|
586
|
+
//This setTimeout method here to avoid the dom node subject observer not existing and blocks the promise status
|
|
587
|
+
const timerId = setTimeout(() => {
|
|
588
|
+
resolve({ isValid: true, message: '' });
|
|
589
|
+
}, 2000);
|
|
590
|
+
ChangeManager.notify(subject, {
|
|
591
|
+
host: element,
|
|
592
|
+
message: showError,
|
|
593
|
+
promiseResolve: resolve,
|
|
594
|
+
timerId,
|
|
595
|
+
});
|
|
596
|
+
});
|
|
597
|
+
return { isValid, message };
|
|
598
|
+
}
|
|
599
|
+
}
|
|
600
|
+
__decorate$2([
|
|
601
|
+
MapToComponentField()
|
|
602
|
+
], VegaFormFieldController.prototype, "host", void 0);
|
|
603
|
+
__decorate$2([
|
|
604
|
+
MapToComponentField({ writable: true })
|
|
605
|
+
], VegaFormFieldController.prototype, "isValid", void 0);
|
|
606
|
+
__decorate$2([
|
|
607
|
+
MapToComponentField({ writable: true })
|
|
608
|
+
], VegaFormFieldController.prototype, "isTouched", void 0);
|
|
609
|
+
__decorate$2([
|
|
610
|
+
InjectVegaSlimmer()
|
|
611
|
+
], VegaFormFieldController.prototype, "childNotifyObserver", void 0);
|
|
612
|
+
__decorate$2([
|
|
613
|
+
InjectVegaSlimmer()
|
|
614
|
+
], VegaFormFieldController.prototype, "childNodeValueChangeObserver", void 0);
|
|
615
|
+
__decorate$2([
|
|
616
|
+
MapToComponentMethod('connectedCallback')
|
|
617
|
+
], VegaFormFieldController.prototype, "connectedCallback", null);
|
|
618
|
+
__decorate$2([
|
|
619
|
+
MapToComponentMethod('disconnectedCallback')
|
|
620
|
+
], VegaFormFieldController.prototype, "disconnectedCallback", null);
|
|
621
|
+
__decorate$2([
|
|
622
|
+
MapToComponentMethod('getValue')
|
|
623
|
+
], VegaFormFieldController.prototype, "getValue", null);
|
|
624
|
+
__decorate$2([
|
|
625
|
+
MapToComponentMethod('setValue')
|
|
626
|
+
], VegaFormFieldController.prototype, "setValue", null);
|
|
627
|
+
__decorate$2([
|
|
628
|
+
MapToComponentMethod('valid')
|
|
629
|
+
], VegaFormFieldController.prototype, "valid", null);
|
|
630
|
+
|
|
631
|
+
var __decorate$1 = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
|
|
632
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
633
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
634
|
+
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;
|
|
635
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
636
|
+
};
|
|
637
|
+
/**
|
|
638
|
+
* Reset controller for handling form reset events in the VegaForm component.
|
|
639
|
+
*/
|
|
640
|
+
class VegaFormResetController extends VegaSlimmer {
|
|
641
|
+
/**
|
|
642
|
+
* Component lifecycle - [connectedCallback]
|
|
643
|
+
*/
|
|
644
|
+
connectedCallback() {
|
|
645
|
+
this.registerFormResetChangeManager();
|
|
646
|
+
}
|
|
647
|
+
/**
|
|
648
|
+
* Component lifecycle - [disconnectedCallback]
|
|
649
|
+
*/
|
|
650
|
+
disconnectedCallback() {
|
|
651
|
+
this.unregisterFormResetChangeManager();
|
|
652
|
+
}
|
|
653
|
+
/**
|
|
654
|
+
* @inheritDoc
|
|
655
|
+
*/
|
|
656
|
+
async reset(defaultValueMap = {}, option) {
|
|
657
|
+
await this.vegaFormFieldController.navigateVegaFormChildren(async (element, isForm) => {
|
|
658
|
+
const formFieldName = this.vegaFormFieldController.getFormFieldName(element);
|
|
659
|
+
if (isForm) {
|
|
660
|
+
await element.reset(defaultValueMap[formFieldName] || {}, option);
|
|
661
|
+
}
|
|
662
|
+
}, option);
|
|
663
|
+
ChangeManager.notify(FORM_RESET_OPERATION_TRIGGERED, {
|
|
664
|
+
host: this.host,
|
|
665
|
+
defaultValueMap,
|
|
666
|
+
option,
|
|
667
|
+
});
|
|
668
|
+
this.vegaFormFieldController.setIsTouched(false);
|
|
669
|
+
}
|
|
670
|
+
/**
|
|
671
|
+
* Registers the form reset event observer with the ChangeManager.
|
|
672
|
+
*/
|
|
673
|
+
registerFormResetChangeManager() {
|
|
674
|
+
var _a;
|
|
675
|
+
const outerForm = (_a = findParent(this.host, 'vega-form', { outerMost: true })) !== null && _a !== void 0 ? _a : this.host;
|
|
676
|
+
this.formResetEventObserver = new Observer(this.canAcceptFormResetEvent.bind(this), this.handleResetEvents.bind(this));
|
|
677
|
+
ChangeManager.register(domNodeSubjectFactory.getSubject(outerForm, VegaInternalFormReset), this.formResetEventObserver);
|
|
678
|
+
}
|
|
679
|
+
/**
|
|
680
|
+
* Unregister the form reset event observer from the ChangeManager.
|
|
681
|
+
*/
|
|
682
|
+
unregisterFormResetChangeManager() {
|
|
683
|
+
var _a;
|
|
684
|
+
const outerForm = (_a = findParent(this.host, 'vega-form', { outerMost: true })) !== null && _a !== void 0 ? _a : this.host;
|
|
685
|
+
ChangeManager.unregister(domNodeSubjectFactory.getSubject(outerForm, VegaInternalFormReset), this.formResetEventObserver);
|
|
686
|
+
}
|
|
687
|
+
/**
|
|
688
|
+
* Can accept form reset event.
|
|
689
|
+
*
|
|
690
|
+
* @param {FormEventsPayload} payload - The form events payload.
|
|
691
|
+
* @returns {boolean} True if the event can be accepted, false otherwise.
|
|
692
|
+
*/
|
|
693
|
+
canAcceptFormResetEvent(payload) {
|
|
694
|
+
return this.vegaFormFieldController.isElementInCurrentForm(payload.host);
|
|
695
|
+
}
|
|
696
|
+
/**
|
|
697
|
+
* Handles reset events by resetting the form and emitting a reset event.
|
|
698
|
+
*/
|
|
699
|
+
async handleResetEvents() {
|
|
700
|
+
await this.host.reset();
|
|
701
|
+
this.resetEventEmitter.emit();
|
|
702
|
+
}
|
|
703
|
+
}
|
|
137
704
|
__decorate$1([
|
|
138
705
|
MapToComponentField()
|
|
139
|
-
],
|
|
706
|
+
], VegaFormResetController.prototype, "host", void 0);
|
|
140
707
|
__decorate$1([
|
|
141
|
-
|
|
142
|
-
],
|
|
708
|
+
MapToComponentField()
|
|
709
|
+
], VegaFormResetController.prototype, "vegaFormFieldController", void 0);
|
|
710
|
+
__decorate$1([
|
|
711
|
+
MapToComponentField()
|
|
712
|
+
], VegaFormResetController.prototype, "resetEventEmitter", void 0);
|
|
713
|
+
__decorate$1([
|
|
714
|
+
MapToComponentMethod('connectedCallback')
|
|
715
|
+
], VegaFormResetController.prototype, "connectedCallback", null);
|
|
716
|
+
__decorate$1([
|
|
717
|
+
MapToComponentMethod('disconnectedCallback')
|
|
718
|
+
], VegaFormResetController.prototype, "disconnectedCallback", null);
|
|
719
|
+
__decorate$1([
|
|
720
|
+
MapToComponentMethod('reset')
|
|
721
|
+
], VegaFormResetController.prototype, "reset", null);
|
|
143
722
|
|
|
144
723
|
const vegaFormCss = ":host{display:block}";
|
|
145
724
|
|
|
@@ -178,20 +757,12 @@ const VegaForm = class {
|
|
|
178
757
|
e.stopPropagation();
|
|
179
758
|
},
|
|
180
759
|
});
|
|
181
|
-
this.childNotifyObserver = new ChildNodesNotifyObserverSlimmer(FORM_ELEMENT_VALIDATE, (input) => this.updateInternalValidStatus(input));
|
|
182
|
-
this.childNodeValueChangeObserver = new ChildNodesNotifyObserverSlimmer(FORM_ELEMENT_VALUE_CHANGE, () => this.updateInternalTouchedStatus());
|
|
183
760
|
this.vegaComponentUsageRuntimeMetricsSlimmer = new VegaComponentUsageRuntimeMetricsSlimmer();
|
|
184
761
|
this.vegaFormFieldValidationStateController = new VegaFormFieldValidationStateController();
|
|
185
|
-
this.
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
// The form field element pending async valid map
|
|
190
|
-
this.pendingValidFieldPathMap = new ImmutableMap(new Map(), (newMap) => {
|
|
191
|
-
this.pendingValidFieldPathMap = newMap;
|
|
192
|
-
this.updateIsValidFlag();
|
|
193
|
-
});
|
|
194
|
-
this.controlledFieldPathSet = new Set();
|
|
762
|
+
this.nativeFormRenderer = new NativeFormRenderer();
|
|
763
|
+
this.vegaFormSubmitController = new VegaFormSubmitController();
|
|
764
|
+
this.vegaFormResetController = new VegaFormResetController();
|
|
765
|
+
this.vegaFormFieldController = new VegaFormFieldController();
|
|
195
766
|
/**
|
|
196
767
|
* Indicates whether the current form-controlled elements are valid.
|
|
197
768
|
*
|
|
@@ -228,6 +799,7 @@ const VegaForm = class {
|
|
|
228
799
|
*
|
|
229
800
|
* @vegaVersion 1.3.0
|
|
230
801
|
*/
|
|
802
|
+
/* eslint-disable-next-line @stencil/strict-mutable */
|
|
231
803
|
this.isTouched = false;
|
|
232
804
|
/**
|
|
233
805
|
* Specifies whether form validation should be disabled on blur events of form elements.
|
|
@@ -242,27 +814,18 @@ const VegaForm = class {
|
|
|
242
814
|
/* eslint-disable-next-line @stencil/strict-mutable */
|
|
243
815
|
this.disableBlurValidation = false;
|
|
244
816
|
/**
|
|
245
|
-
*
|
|
246
|
-
* invalid elements. If the element is invalid,
|
|
247
|
-
* add it to the set of invalid elements.
|
|
817
|
+
* Determines whether the `vega-form` content is wrapped in a native HTML <form> element.
|
|
248
818
|
*
|
|
249
|
-
* @
|
|
819
|
+
* @vegaVersion 2.64.0
|
|
250
820
|
*/
|
|
251
|
-
this.
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
}
|
|
260
|
-
else {
|
|
261
|
-
this.invalidFieldPathMap.set(target, target.dataset['vegaForm']);
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
}
|
|
265
|
-
};
|
|
821
|
+
this.useNativeForm = false;
|
|
822
|
+
/**
|
|
823
|
+
* Specifies the HTTP method used for form submission.
|
|
824
|
+
* This property takes effect only when {@link useNativeForm} is set to `true`.
|
|
825
|
+
*
|
|
826
|
+
* @vegaVersion 2.64.0
|
|
827
|
+
*/
|
|
828
|
+
this.method = 'get';
|
|
266
829
|
}
|
|
267
830
|
watchIsValid() {
|
|
268
831
|
this.validateEventEmitter.emit(this.isValid);
|
|
@@ -270,28 +833,6 @@ const VegaForm = class {
|
|
|
270
833
|
}
|
|
271
834
|
watchDisableBlurValidation() {
|
|
272
835
|
}
|
|
273
|
-
/**
|
|
274
|
-
* When the vegaForm is deleted, it is necessary to notify
|
|
275
|
-
* the parent's vegaForm to update its isValid status.
|
|
276
|
-
*/
|
|
277
|
-
async disconnectedCallback() {
|
|
278
|
-
ChangeManager.notify(FORM_FIELD_ELEMENT_DISCONNECTED, {
|
|
279
|
-
host: this.host,
|
|
280
|
-
});
|
|
281
|
-
ChangeManager.unregister(FORM_FIELD_ELEMENT_DISCONNECTED, this.formFieldDisconnectedObserver);
|
|
282
|
-
ChangeManager.unregister(FORM_FIELD_PENDING_VALID_CHANGE, this.formFieldPendingValidObserver);
|
|
283
|
-
}
|
|
284
|
-
async componentDidLoad() {
|
|
285
|
-
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
286
|
-
if (!isForm) {
|
|
287
|
-
this.controlledFieldPathSet.add(this.getFormFieldName(element, true));
|
|
288
|
-
}
|
|
289
|
-
});
|
|
290
|
-
this.initFormFieldDisconnectedObserver();
|
|
291
|
-
this.registerFormSubmitChangeManager();
|
|
292
|
-
this.registerFormResetChangeManager();
|
|
293
|
-
this.registerFormFieldPendingValidChangeManager();
|
|
294
|
-
}
|
|
295
836
|
/**
|
|
296
837
|
* Invoke this method asynchronously to retrieve the validation result for
|
|
297
838
|
* all the vega field elements nested within the `vega-form`.
|
|
@@ -304,29 +845,7 @@ const VegaForm = class {
|
|
|
304
845
|
* @vegaVersion 1.3.0
|
|
305
846
|
*/
|
|
306
847
|
async valid(showError = true) {
|
|
307
|
-
|
|
308
|
-
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
309
|
-
if (typeof element['valid'] === 'function' && isForm) {
|
|
310
|
-
const nestedFormValidationResult = await element.valid(showError);
|
|
311
|
-
if (!nestedFormValidationResult.isValid) {
|
|
312
|
-
result.isValid = false;
|
|
313
|
-
result.invalidFields.push(...nestedFormValidationResult.invalidFields);
|
|
314
|
-
result.invalidFieldsErrorMessages = Object.assign(Object.assign({}, result.invalidFieldsErrorMessages), nestedFormValidationResult.invalidFieldsErrorMessages);
|
|
315
|
-
}
|
|
316
|
-
}
|
|
317
|
-
else {
|
|
318
|
-
const { isValid, message } = await this.handleChildFormFieldElementValid(element, showError);
|
|
319
|
-
if (!isValid) {
|
|
320
|
-
result.isValid = false;
|
|
321
|
-
result.invalidFields.push(this.getFormFieldName(element));
|
|
322
|
-
if (!result.invalidFieldsErrorMessages) {
|
|
323
|
-
result.invalidFieldsErrorMessages = {};
|
|
324
|
-
}
|
|
325
|
-
result.invalidFieldsErrorMessages[this.getFormFieldName(element)] = message;
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
});
|
|
329
|
-
return result;
|
|
848
|
+
return methodPlaceholder(showError);
|
|
330
849
|
}
|
|
331
850
|
/**
|
|
332
851
|
* Invoke this method asynchronously to retrieve the values for
|
|
@@ -337,17 +856,7 @@ const VegaForm = class {
|
|
|
337
856
|
* @vegaVersion 1.3.0
|
|
338
857
|
*/
|
|
339
858
|
async getValue(option) {
|
|
340
|
-
|
|
341
|
-
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
342
|
-
const formFieldName = this.getFormFieldName(element);
|
|
343
|
-
if (isForm) {
|
|
344
|
-
result[formFieldName] = await element.getValue(option);
|
|
345
|
-
}
|
|
346
|
-
else {
|
|
347
|
-
result[formFieldName] = VegaForm.getFormFieldValue(element);
|
|
348
|
-
}
|
|
349
|
-
}, option);
|
|
350
|
-
return (isObjectArrayLike(result) ? Object.values(result) : result);
|
|
859
|
+
return methodPlaceholder(option);
|
|
351
860
|
}
|
|
352
861
|
/**
|
|
353
862
|
* Invoke this method to prefill the `vega-form` with the given value.
|
|
@@ -359,24 +868,6 @@ const VegaForm = class {
|
|
|
359
868
|
* @vegaVersion 1.3.0
|
|
360
869
|
*/
|
|
361
870
|
async setValue(value, option) {
|
|
362
|
-
if (value) {
|
|
363
|
-
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
364
|
-
const formFieldName = this.getFormFieldName(element);
|
|
365
|
-
if (isForm) {
|
|
366
|
-
await element.setValue(value[formFieldName], option);
|
|
367
|
-
}
|
|
368
|
-
else {
|
|
369
|
-
await element.componentOnReady(); // Link issue https://gethired.atlassian.net/browse/GHUI-385
|
|
370
|
-
if (value[formFieldName] !== undefined) {
|
|
371
|
-
// If element have setValue method, we will directly call this method, otherwise we set the value to value property.
|
|
372
|
-
typeof element['setValue'] === 'function'
|
|
373
|
-
? await element['setValue'](value[formFieldName])
|
|
374
|
-
: (element['value'] = value[formFieldName]);
|
|
375
|
-
}
|
|
376
|
-
}
|
|
377
|
-
}, option);
|
|
378
|
-
this.isTouched = false;
|
|
379
|
-
}
|
|
380
871
|
}
|
|
381
872
|
/**
|
|
382
873
|
* Invoke this method to reset the vega field elements in the form to
|
|
@@ -389,18 +880,6 @@ const VegaForm = class {
|
|
|
389
880
|
* @vegaVersion 1.3.0
|
|
390
881
|
*/
|
|
391
882
|
async reset(defaultValueMap = {}, option) {
|
|
392
|
-
await this.navigateVegaFormChildren(async (element, isForm) => {
|
|
393
|
-
const formFieldName = this.getFormFieldName(element);
|
|
394
|
-
if (isForm) {
|
|
395
|
-
await element.reset(defaultValueMap[formFieldName] || {}, option);
|
|
396
|
-
}
|
|
397
|
-
}, option);
|
|
398
|
-
ChangeManager.notify(FORM_RESET_OPERATION_TRIGGERED, {
|
|
399
|
-
host: this.host,
|
|
400
|
-
defaultValueMap,
|
|
401
|
-
option,
|
|
402
|
-
});
|
|
403
|
-
this.isTouched = false;
|
|
404
883
|
}
|
|
405
884
|
/**
|
|
406
885
|
* Invoke this method to set validation states on specific form fields.
|
|
@@ -411,180 +890,8 @@ const VegaForm = class {
|
|
|
411
890
|
*/
|
|
412
891
|
async setValidationStates(states) {
|
|
413
892
|
}
|
|
414
|
-
static getFormFieldValue(element) {
|
|
415
|
-
return typeof element['value'] === 'undefined'
|
|
416
|
-
? // use element.getAttribute since the value property is not available in unit testing
|
|
417
|
-
element.getAttribute('value')
|
|
418
|
-
: element['value'];
|
|
419
|
-
}
|
|
420
893
|
render() {
|
|
421
|
-
return sanitizeVegaComponent(h(Host, null, h("slot", null)), this.host);
|
|
422
|
-
}
|
|
423
|
-
/**
|
|
424
|
-
* If the value of any child elements have changed,
|
|
425
|
-
* make 'isTouched' prop as false.
|
|
426
|
-
*/
|
|
427
|
-
updateInternalTouchedStatus() {
|
|
428
|
-
this.isTouched = true;
|
|
429
|
-
}
|
|
430
|
-
/**
|
|
431
|
-
* Navigate the immediate child node under current vega form element with the following strategy
|
|
432
|
-
* - if a matched vega field element found, will pass it to the visitor method passed in
|
|
433
|
-
* - if a non-matched node found, it will call itself recursively and pass the node as the second parameter
|
|
434
|
-
* Once the navigation is finished, it will wait for all the pending visitor/self-invocation promise finished before return
|
|
435
|
-
*
|
|
436
|
-
* @param visitor async callback method that will be invoked if a matched vega field element found
|
|
437
|
-
* @param {FormControlOption} [option] form control option to skip disabled/invisible components
|
|
438
|
-
* @param [startElementNode] element node that the navigation will be started from, default is the current host element
|
|
439
|
-
* @return {Promise<void>} return void wrapped with promise to notify the navigation is done
|
|
440
|
-
*/
|
|
441
|
-
async navigateVegaFormChildren(visitor, option, startElementNode = this.host) {
|
|
442
|
-
const promiseQueue = [];
|
|
443
|
-
Array.from(startElementNode.children).forEach((child) => {
|
|
444
|
-
if (FormFieldControllerSlimmer.isValidFormField(child)) {
|
|
445
|
-
if (this.shouldVisitElement(child, option === null || option === void 0 ? void 0 : option.skipDisabled, option === null || option === void 0 ? void 0 : option.skipInvisible)) {
|
|
446
|
-
promiseQueue.push(visitor(child, child.tagName === 'VEGA-FORM'));
|
|
447
|
-
}
|
|
448
|
-
}
|
|
449
|
-
else {
|
|
450
|
-
promiseQueue.push(this.navigateVegaFormChildren(visitor, option, child));
|
|
451
|
-
}
|
|
452
|
-
});
|
|
453
|
-
await Promise.all(promiseQueue);
|
|
454
|
-
}
|
|
455
|
-
/**
|
|
456
|
-
* Update the {@link isValid} property value based on the size of {@link invalidFieldPathSet}
|
|
457
|
-
* If the number of invalid elements is zero, then the form is valid.
|
|
458
|
-
*/
|
|
459
|
-
updateIsValidFlag() {
|
|
460
|
-
this.isValid = this.pendingValidFieldPathMap.size > 0 ? null : this.invalidFieldPathMap.size === 0;
|
|
461
|
-
}
|
|
462
|
-
/**
|
|
463
|
-
* It returns the value of data-vega-form that the given element is associated with, if child HTMLElements share the same data-vega-form property name
|
|
464
|
-
* in the same vega-form, then includePath has to be set to be true to get a complete path to avoid the confusion of isValid checking.
|
|
465
|
-
*
|
|
466
|
-
* @param {HTMLElement} element - The element that is being validated.
|
|
467
|
-
* @param {boolean} [includePath] - If true, the field name will include the path to the field. For
|
|
468
|
-
* example, if the field is in a vega-form with the name "address", the field name will be "address ->
|
|
469
|
-
* street".
|
|
470
|
-
* @returns The name of the field.
|
|
471
|
-
*/
|
|
472
|
-
getFormFieldName(element, includePath) {
|
|
473
|
-
let fieldName = element.dataset['vegaForm'];
|
|
474
|
-
if (includePath) {
|
|
475
|
-
let currentVegaForm = findParent(element, 'vega-form');
|
|
476
|
-
/**
|
|
477
|
-
* The below method is e2e-test covered in
|
|
478
|
-
* @see {module:nested-vega-form-isValid-should-be-as-expected-when-value-changed}
|
|
479
|
-
*/
|
|
480
|
-
/* istanbul ignore next */
|
|
481
|
-
while (currentVegaForm && currentVegaForm !== this.host) {
|
|
482
|
-
fieldName = currentVegaForm.dataset['vegaForm'] + ' -> ' + fieldName;
|
|
483
|
-
currentVegaForm = findParent(currentVegaForm, 'vega-form');
|
|
484
|
-
}
|
|
485
|
-
}
|
|
486
|
-
return fieldName;
|
|
487
|
-
}
|
|
488
|
-
/**
|
|
489
|
-
* 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.
|
|
490
|
-
*
|
|
491
|
-
* @param {HTMLElement} element - The HTMLElement to check.
|
|
492
|
-
* @param {boolean} skipDisabled - If true, then disabled form fields will be skipped.
|
|
493
|
-
* @param {boolean} skipInvisible - If true, only visible elements will be visited.
|
|
494
|
-
* @returns a boolean value.
|
|
495
|
-
*/
|
|
496
|
-
shouldVisitElement(element, skipDisabled, skipInvisible) {
|
|
497
|
-
return (this.getFormFieldName(element) &&
|
|
498
|
-
(!skipDisabled || !element['disabled']) &&
|
|
499
|
-
(!skipInvisible || isElementVisible(element)));
|
|
500
|
-
}
|
|
501
|
-
/**
|
|
502
|
-
* This function registers an observer with the ChangeManager that will be notified when a element
|
|
503
|
-
* delete operation is triggered
|
|
504
|
-
*/
|
|
505
|
-
initFormFieldDisconnectedObserver() {
|
|
506
|
-
this.formFieldDisconnectedObserver = new Observer(this.canAcceptFormFieldDisconnectedOperation.bind(this), this.updateInvalidFieldPath.bind(this));
|
|
507
|
-
ChangeManager.register(FORM_FIELD_ELEMENT_DISCONNECTED, this.formFieldDisconnectedObserver);
|
|
508
|
-
}
|
|
509
|
-
/**
|
|
510
|
-
* If the deleted element is a child or grandchild of current vegaForm, the isValid of all these vegaForms will be updated.
|
|
511
|
-
*
|
|
512
|
-
* @param {DisconnectedElementOperationPayload} payload - the delete element and vegaForm array.
|
|
513
|
-
* @returns {boolean} A boolean value.
|
|
514
|
-
*/
|
|
515
|
-
canAcceptFormFieldDisconnectedOperation(payload) {
|
|
516
|
-
return this.invalidFieldPathMap.has(payload.host);
|
|
517
|
-
}
|
|
518
|
-
/**
|
|
519
|
-
* Get the fieldName of the deleted element in the current vegaForm, delete it from the invalidFieldPathSet array, and update isValid at the same time.
|
|
520
|
-
*/
|
|
521
|
-
async updateInvalidFieldPath(payload) {
|
|
522
|
-
this.invalidFieldPathMap.delete(payload.host);
|
|
523
|
-
this.pendingValidFieldPathMap.delete(payload.host);
|
|
524
|
-
}
|
|
525
|
-
registerFormSubmitChangeManager() {
|
|
526
|
-
this.formEventsObserver = new Observer(this.canAcceptFormSubmitEvent.bind(this), this.handleSubmitEvents.bind(this));
|
|
527
|
-
ChangeManager.register(FORM_SUBMIT, this.formEventsObserver);
|
|
528
|
-
}
|
|
529
|
-
/**
|
|
530
|
-
* The below method is e2e-test covered in
|
|
531
|
-
* @see{module:vega-form-field-enter-to-submit-e2e}
|
|
532
|
-
*/
|
|
533
|
-
/* istanbul ignore next */
|
|
534
|
-
canAcceptFormSubmitEvent(payload) {
|
|
535
|
-
return this.isElementInCurrentForm(payload.host);
|
|
536
|
-
}
|
|
537
|
-
async handleSubmitEvents() {
|
|
538
|
-
const valid = await this.valid();
|
|
539
|
-
if (valid.isValid) {
|
|
540
|
-
const formValue = await this.getValue();
|
|
541
|
-
this.submitEventEmitter.emit(formValue);
|
|
542
|
-
}
|
|
543
|
-
}
|
|
544
|
-
registerFormResetChangeManager() {
|
|
545
|
-
this.formEventsObserver = new Observer(this.canAcceptFormResetEvent.bind(this), this.handleResetEvents.bind(this));
|
|
546
|
-
ChangeManager.register(FORM_RESET, this.formEventsObserver);
|
|
547
|
-
}
|
|
548
|
-
canAcceptFormResetEvent(payload) {
|
|
549
|
-
return this.isElementInCurrentForm(payload.host);
|
|
550
|
-
}
|
|
551
|
-
async handleResetEvents() {
|
|
552
|
-
await this.reset();
|
|
553
|
-
this.resetEventEmitter.emit();
|
|
554
|
-
}
|
|
555
|
-
registerFormFieldPendingValidChangeManager() {
|
|
556
|
-
this.formFieldPendingValidObserver = new Observer(this.canAcceptFormFieldPendingValid.bind(this), this.handleFieldPendingValid.bind(this));
|
|
557
|
-
ChangeManager.register(FORM_FIELD_PENDING_VALID_CHANGE, this.formFieldPendingValidObserver);
|
|
558
|
-
}
|
|
559
|
-
canAcceptFormFieldPendingValid(payload) {
|
|
560
|
-
return this.isElementInCurrentForm(payload.host);
|
|
561
|
-
}
|
|
562
|
-
handleFieldPendingValid(payload) {
|
|
563
|
-
if (typeof payload.detail === 'boolean') {
|
|
564
|
-
this.pendingValidFieldPathMap.delete(payload.host);
|
|
565
|
-
}
|
|
566
|
-
else {
|
|
567
|
-
this.pendingValidFieldPathMap.set(payload.host, payload.host.dataset['vegaForm']);
|
|
568
|
-
}
|
|
569
|
-
}
|
|
570
|
-
isElementInCurrentForm(element) {
|
|
571
|
-
return this.invalidFieldPathMap.has(element) || isParent(element, this.host);
|
|
572
|
-
}
|
|
573
|
-
async handleChildFormFieldElementValid(element, showError) {
|
|
574
|
-
const subject = domNodeSubjectFactory.getSubject(element, VegaInternalValid);
|
|
575
|
-
const { isValid, message } = await new Promise((resolve) => {
|
|
576
|
-
//This setTimeout method here to avoid the dom node subject observer not existing and blocks the promise status
|
|
577
|
-
const timerId = setTimeout(() => {
|
|
578
|
-
resolve({ isValid: true, message: '' });
|
|
579
|
-
}, 2000);
|
|
580
|
-
ChangeManager.notify(subject, {
|
|
581
|
-
host: element,
|
|
582
|
-
message: showError,
|
|
583
|
-
promiseResolve: resolve,
|
|
584
|
-
timerId,
|
|
585
|
-
});
|
|
586
|
-
});
|
|
587
|
-
return { isValid, message };
|
|
894
|
+
return sanitizeVegaComponent(h(Host, null, this.useNativeForm ? this.nativeFormRenderer.render() : h("slot", null)), this.host);
|
|
588
895
|
}
|
|
589
896
|
get host() { return getElement(this); }
|
|
590
897
|
static get watchers() { return {
|
|
@@ -618,16 +925,22 @@ __decorate([
|
|
|
618
925
|
], VegaForm.prototype, "childFormValidateEventPrevent", void 0);
|
|
619
926
|
__decorate([
|
|
620
927
|
InjectVegaSlimmer()
|
|
621
|
-
], VegaForm.prototype, "
|
|
928
|
+
], VegaForm.prototype, "vegaComponentUsageRuntimeMetricsSlimmer", void 0);
|
|
622
929
|
__decorate([
|
|
623
930
|
InjectVegaSlimmer()
|
|
624
|
-
], VegaForm.prototype, "
|
|
931
|
+
], VegaForm.prototype, "vegaFormFieldValidationStateController", void 0);
|
|
625
932
|
__decorate([
|
|
626
933
|
InjectVegaSlimmer()
|
|
627
|
-
], VegaForm.prototype, "
|
|
934
|
+
], VegaForm.prototype, "nativeFormRenderer", void 0);
|
|
628
935
|
__decorate([
|
|
629
936
|
InjectVegaSlimmer()
|
|
630
|
-
], VegaForm.prototype, "
|
|
937
|
+
], VegaForm.prototype, "vegaFormSubmitController", void 0);
|
|
938
|
+
__decorate([
|
|
939
|
+
InjectVegaSlimmer()
|
|
940
|
+
], VegaForm.prototype, "vegaFormResetController", void 0);
|
|
941
|
+
__decorate([
|
|
942
|
+
InjectVegaSlimmer()
|
|
943
|
+
], VegaForm.prototype, "vegaFormFieldController", void 0);
|
|
631
944
|
VegaForm.style = vegaFormCss;
|
|
632
945
|
|
|
633
946
|
export { VegaForm as vega_form };
|