@vritti/quantum-ui 0.2.9 → 0.3.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/Alert.js +8 -31
- package/dist/Alert.js.map +1 -1
- package/dist/AppSelector.js +37 -0
- package/dist/AppSelector.js.map +1 -0
- package/dist/Avatar.js +5 -5
- package/dist/Avatar.js.map +1 -1
- package/dist/Badge.js +2 -28
- package/dist/Badge.js.map +1 -1
- package/dist/Badge2.js +30 -0
- package/dist/Badge2.js.map +1 -0
- package/dist/Breadcrumb.js +125 -0
- package/dist/Breadcrumb.js.map +1 -0
- package/dist/Button.js +8 -4
- package/dist/Button.js.map +1 -1
- package/dist/Button2.js +34 -15
- package/dist/Button2.js.map +1 -1
- package/dist/CardSkeleton.js +17 -0
- package/dist/CardSkeleton.js.map +1 -0
- package/dist/Chart.js +6195 -6401
- package/dist/Chart.js.map +1 -1
- package/dist/Checkbox.js +2 -289
- package/dist/Checkbox.js.map +1 -1
- package/dist/Checkbox2.js +293 -0
- package/dist/Checkbox2.js.map +1 -0
- package/dist/CheckboxGroup.js +74 -0
- package/dist/CheckboxGroup.js.map +1 -0
- package/dist/CloudProviderSelector.js +37 -0
- package/dist/CloudProviderSelector.js.map +1 -0
- package/dist/Collapsible.js +8 -0
- package/dist/Collapsible.js.map +1 -0
- package/dist/Combination.js +10 -2509
- package/dist/Combination.js.map +1 -1
- package/dist/ConfirmContext.js +75 -0
- package/dist/ConfirmContext.js.map +1 -0
- package/dist/CurrencySelector.js +194 -0
- package/dist/CurrencySelector.js.map +1 -0
- package/dist/DangerZoneSkeleton.js +52 -0
- package/dist/DangerZoneSkeleton.js.map +1 -0
- package/dist/DatePicker.js +36 -340
- package/dist/DatePicker.js.map +1 -1
- package/dist/DeploymentSelector.js +37 -0
- package/dist/DeploymentSelector.js.map +1 -0
- package/dist/Dialog.js +159 -0
- package/dist/Dialog.js.map +1 -0
- package/dist/DropdownMenu.js +66 -1423
- package/dist/DropdownMenu.js.map +1 -1
- package/dist/Empty.js +49 -0
- package/dist/Empty.js.map +1 -0
- package/dist/ErrorBoundary.js +255 -0
- package/dist/ErrorBoundary.js.map +1 -0
- package/dist/FeatureSelector.js +37 -0
- package/dist/FeatureSelector.js.map +1 -0
- package/dist/FilePreview.js +194 -0
- package/dist/FilePreview.js.map +1 -0
- package/dist/Form.js +1938 -19
- package/dist/Form.js.map +1 -1
- package/dist/HierarchyGraph.js +10729 -0
- package/dist/HierarchyGraph.js.map +1 -0
- package/dist/IndustrySelector.js +37 -0
- package/dist/IndustrySelector.js.map +1 -0
- package/dist/Input.js +22 -0
- package/dist/Input.js.map +1 -0
- package/dist/Label.js +1 -21
- package/dist/Label.js.map +1 -1
- package/dist/LocaleSelector.js +111 -0
- package/dist/LocaleSelector.js.map +1 -0
- package/dist/MicrofrontendSelector.js +19 -0
- package/dist/MicrofrontendSelector.js.map +1 -0
- package/dist/OTPField.js +28 -26
- package/dist/OTPField.js.map +1 -1
- package/dist/PageHeaderSkeleton.js +35 -0
- package/dist/PageHeaderSkeleton.js.map +1 -0
- package/dist/PasswordField.js +1 -49
- package/dist/PasswordField.js.map +1 -1
- package/dist/PhoneField.js +11 -16
- package/dist/PhoneField.js.map +1 -1
- package/dist/PlanSelector.js +37 -0
- package/dist/PlanSelector.js.map +1 -0
- package/dist/Progress.js +4 -3
- package/dist/Progress.js.map +1 -1
- package/dist/RadioGroup.js +392 -0
- package/dist/RadioGroup.js.map +1 -0
- package/dist/RegionSelector.js +37 -0
- package/dist/RegionSelector.js.map +1 -0
- package/dist/Select.js +780 -0
- package/dist/Select.js.map +1 -0
- package/dist/SelectFilter.js +387 -0
- package/dist/SelectFilter.js.map +1 -0
- package/dist/Sidebar.js +616 -0
- package/dist/Sidebar.js.map +1 -0
- package/dist/SingleSelect.js +429 -0
- package/dist/SingleSelect.js.map +1 -0
- package/dist/Sonner.js +6 -1135
- package/dist/Sonner.js.map +1 -1
- package/dist/Sortable.js +4517 -0
- package/dist/Sortable.js.map +1 -0
- package/dist/StepProgressIndicator.js +42 -0
- package/dist/StepProgressIndicator.js.map +1 -0
- package/dist/Switch.js +15 -15
- package/dist/Switch.js.map +1 -1
- package/dist/TabsSkeleton.js +188 -0
- package/dist/TabsSkeleton.js.map +1 -0
- package/dist/TextArea.js +16 -19
- package/dist/TextArea.js.map +1 -1
- package/dist/TextField.js +5 -20
- package/dist/TextField.js.map +1 -1
- package/dist/ThemeContext.js +2 -8
- package/dist/ThemeContext.js.map +1 -1
- package/dist/TimezoneSelector.js +144 -0
- package/dist/TimezoneSelector.js.map +1 -0
- package/dist/Toggle.js +2 -32
- package/dist/Toggle.js.map +1 -1
- package/dist/UploadFile.js +232 -0
- package/dist/UploadFile.js.map +1 -0
- package/dist/ValueFilter.js +123 -0
- package/dist/ValueFilter.js.map +1 -0
- package/dist/ViewTabs.js +218 -0
- package/dist/ViewTabs.js.map +1 -0
- package/dist/_commonjsHelpers.js +3 -1
- package/dist/_commonjsHelpers.js.map +1 -1
- package/dist/assets/quantum-ui.css +827 -57
- package/dist/axios.js +1239 -892
- package/dist/axios.js.map +1 -1
- package/dist/{chevron-down.js → chevron-left.js} +4 -4
- package/dist/chevron-left.js.map +1 -0
- package/dist/circle-alert.js +19 -0
- package/dist/circle-alert.js.map +1 -0
- package/dist/circle-check.js +18 -0
- package/dist/circle-check.js.map +1 -0
- package/dist/collapsible2.js +154 -0
- package/dist/collapsible2.js.map +1 -0
- package/dist/components/Badge.js +2 -1
- package/dist/components/Badge.js.map +1 -1
- package/dist/components/Breadcrumb.js +2 -0
- package/dist/components/Breadcrumb.js.map +1 -0
- package/dist/components/Card.js +1 -0
- package/dist/components/Card.js.map +1 -1
- package/dist/components/CheckboxGroup.js +2 -0
- package/dist/components/CheckboxGroup.js.map +1 -0
- package/dist/components/Collapsible.js +2 -0
- package/dist/components/Collapsible.js.map +1 -0
- package/dist/components/DangerZone.js +2 -0
- package/dist/components/DangerZone.js.map +1 -0
- package/dist/components/DataTable.js +2 -0
- package/dist/components/DataTable.js.map +1 -0
- package/dist/components/Dialog.js +2 -0
- package/dist/components/Dialog.js.map +1 -0
- package/dist/components/DropdownMenu.js +1 -1
- package/dist/components/Empty.js +2 -0
- package/dist/components/Empty.js.map +1 -0
- package/dist/components/ErrorBoundary.js +2 -0
- package/dist/components/ErrorBoundary.js.map +1 -0
- package/dist/components/FilePreview.js +2 -0
- package/dist/components/FilePreview.js.map +1 -0
- package/dist/components/HierarchyGraph.js +2 -0
- package/dist/components/HierarchyGraph.js.map +1 -0
- package/dist/components/PageHeader.js +2 -0
- package/dist/components/PageHeader.js.map +1 -0
- package/dist/components/RadioGroup.js +2 -0
- package/dist/components/RadioGroup.js.map +1 -0
- package/dist/components/RichTextEditor.js +4 -0
- package/dist/components/RichTextEditor.js.map +1 -0
- package/dist/components/Select.js +29 -0
- package/dist/components/Select.js.map +1 -0
- package/dist/components/Sidebar.js +2 -0
- package/dist/components/Sidebar.js.map +1 -0
- package/dist/components/Sortable.js +2 -0
- package/dist/components/Sortable.js.map +1 -0
- package/dist/components/StepProgressIndicator.js +2 -0
- package/dist/components/StepProgressIndicator.js.map +1 -0
- package/dist/components/Tabs.js +2 -0
- package/dist/components/Tabs.js.map +1 -0
- package/dist/components/UploadFile.js +2 -0
- package/dist/components/UploadFile.js.map +1 -0
- package/dist/components/ValueFilter.js +2 -0
- package/dist/components/ValueFilter.js.map +1 -0
- package/dist/components/ViewTabs.js +2 -0
- package/dist/components/ViewTabs.js.map +1 -0
- package/dist/context/index.js +1 -0
- package/dist/context/index.js.map +1 -1
- package/dist/dropdown-menu.js +1209 -0
- package/dist/dropdown-menu.js.map +1 -0
- package/dist/ellipsis.js +19 -0
- package/dist/ellipsis.js.map +1 -0
- package/dist/eye.js +52 -0
- package/dist/eye.js.map +1 -0
- package/dist/field.js +1 -1
- package/dist/file-text.js +27 -0
- package/dist/file-text.js.map +1 -0
- package/dist/grip-vertical.js +22 -0
- package/dist/grip-vertical.js.map +1 -0
- package/dist/hooks/index.js +3 -0
- package/dist/hooks/index.js.map +1 -1
- package/dist/image-component.js +614 -0
- package/dist/image-component.js.map +1 -0
- package/dist/index.js +49 -9
- package/dist/index.js.map +1 -1
- package/dist/index10.js +175 -94
- package/dist/index10.js.map +1 -1
- package/dist/index11.js +202 -67
- package/dist/index11.js.map +1 -1
- package/dist/index12.js +17 -38
- package/dist/index12.js.map +1 -1
- package/dist/index13.js +204 -188
- package/dist/index13.js.map +1 -1
- package/dist/index14.js +124 -192
- package/dist/index14.js.map +1 -1
- package/dist/index15.js +79 -0
- package/dist/index15.js.map +1 -0
- package/dist/index16.js +16 -0
- package/dist/index16.js.map +1 -0
- package/dist/index17.js +1137 -0
- package/dist/index17.js.map +1 -0
- package/dist/index18.js +41 -0
- package/dist/index18.js.map +1 -0
- package/dist/index19.js +314 -0
- package/dist/index19.js.map +1 -0
- package/dist/index2.js +54033 -55
- package/dist/index2.js.map +1 -1
- package/dist/index20.js +488 -0
- package/dist/index20.js.map +1 -0
- package/dist/index21.js +2540 -0
- package/dist/index21.js.map +1 -0
- package/dist/index22.js +36 -0
- package/dist/index22.js.map +1 -0
- package/dist/index23.js +13 -0
- package/dist/index23.js.map +1 -0
- package/dist/index24.js +8 -0
- package/dist/index24.js.map +1 -0
- package/dist/index25.js +35 -0
- package/dist/index25.js.map +1 -0
- package/dist/index26.js +65 -0
- package/dist/index26.js.map +1 -0
- package/dist/index27.js +16 -0
- package/dist/index27.js.map +1 -0
- package/dist/index28.js +41 -0
- package/dist/index28.js.map +1 -0
- package/dist/index29.js +84 -0
- package/dist/index29.js.map +1 -0
- package/dist/index3.js +42 -10
- package/dist/index3.js.map +1 -1
- package/dist/index30.js +199 -0
- package/dist/index30.js.map +1 -0
- package/dist/index4.js +290 -118
- package/dist/index4.js.map +1 -1
- package/dist/index5.js +96 -31
- package/dist/index5.js.map +1 -1
- package/dist/index6.js +36 -4
- package/dist/index6.js.map +1 -1
- package/dist/index7.js +1157 -11
- package/dist/index7.js.map +1 -1
- package/dist/index8.js +22 -42
- package/dist/index8.js.map +1 -1
- package/dist/index9.js +25 -35
- package/dist/index9.js.map +1 -1
- package/dist/lib/components/Alert/Alert.d.ts +2 -1
- package/dist/lib/components/Alert/Alert.d.ts.map +1 -1
- package/dist/lib/components/Breadcrumb/Breadcrumb.d.ts +17 -0
- package/dist/lib/components/Breadcrumb/Breadcrumb.d.ts.map +1 -0
- package/dist/lib/components/Breadcrumb/index.d.ts +4 -0
- package/dist/lib/components/Breadcrumb/index.d.ts.map +1 -0
- package/dist/lib/components/Button/Button.d.ts +3 -1
- package/dist/lib/components/Button/Button.d.ts.map +1 -1
- package/dist/lib/components/Card/CardSkeleton.d.ts +9 -0
- package/dist/lib/components/Card/CardSkeleton.d.ts.map +1 -0
- package/dist/lib/components/Card/index.d.ts +1 -0
- package/dist/lib/components/Card/index.d.ts.map +1 -1
- package/dist/lib/components/Chart/Chart.d.ts +1 -1
- package/dist/lib/components/Chart/Chart.d.ts.map +1 -1
- package/dist/lib/components/CheckboxGroup/CheckboxGroup.d.ts +24 -0
- package/dist/lib/components/CheckboxGroup/CheckboxGroup.d.ts.map +1 -0
- package/dist/lib/components/CheckboxGroup/index.d.ts +3 -0
- package/dist/lib/components/CheckboxGroup/index.d.ts.map +1 -0
- package/dist/lib/components/Collapsible/Collapsible.d.ts +5 -0
- package/dist/lib/components/Collapsible/Collapsible.d.ts.map +1 -0
- package/dist/lib/components/Collapsible/index.d.ts +2 -0
- package/dist/lib/components/Collapsible/index.d.ts.map +1 -0
- package/dist/lib/components/DangerZone/DangerZone.d.ts +13 -0
- package/dist/lib/components/DangerZone/DangerZone.d.ts.map +1 -0
- package/dist/lib/components/DangerZone/DangerZoneSkeleton.d.ts +9 -0
- package/dist/lib/components/DangerZone/DangerZoneSkeleton.d.ts.map +1 -0
- package/dist/lib/components/DangerZone/index.d.ts +4 -0
- package/dist/lib/components/DangerZone/index.d.ts.map +1 -0
- package/dist/lib/components/DataTable/DataTable.d.ts +6 -0
- package/dist/lib/components/DataTable/DataTable.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTableColumnHeader.d.ts +12 -0
- package/dist/lib/components/DataTable/components/DataTableColumnHeader.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTableEmpty.d.ts +13 -0
- package/dist/lib/components/DataTable/components/DataTableEmpty.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTableFilters.d.ts +11 -0
- package/dist/lib/components/DataTable/components/DataTableFilters.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTableImportDialog.d.ts +16 -0
- package/dist/lib/components/DataTable/components/DataTableImportDialog.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTablePagination.d.ts +12 -0
- package/dist/lib/components/DataTable/components/DataTablePagination.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTableRowDensity.d.ts +11 -0
- package/dist/lib/components/DataTable/components/DataTableRowDensity.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTableSearch.d.ts +14 -0
- package/dist/lib/components/DataTable/components/DataTableSearch.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTableSelectionBar.d.ts +14 -0
- package/dist/lib/components/DataTable/components/DataTableSelectionBar.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTableViewOptions.d.ts +11 -0
- package/dist/lib/components/DataTable/components/DataTableViewOptions.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTableViewTabs.d.ts +7 -0
- package/dist/lib/components/DataTable/components/DataTableViewTabs.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/DataTableViewsMenu.d.ts +14 -0
- package/dist/lib/components/DataTable/components/DataTableViewsMenu.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/FilterWrapper.d.ts +21 -0
- package/dist/lib/components/DataTable/components/FilterWrapper.d.ts.map +1 -0
- package/dist/lib/components/DataTable/components/RowActions.d.ts +20 -0
- package/dist/lib/components/DataTable/components/RowActions.d.ts.map +1 -0
- package/dist/lib/components/DataTable/hooks/useAutoUpsert.d.ts +3 -0
- package/dist/lib/components/DataTable/hooks/useAutoUpsert.d.ts.map +1 -0
- package/dist/lib/components/DataTable/hooks/useDataTable.d.ts +25 -0
- package/dist/lib/components/DataTable/hooks/useDataTable.d.ts.map +1 -0
- package/dist/lib/components/DataTable/index.d.ts +18 -0
- package/dist/lib/components/DataTable/index.d.ts.map +1 -0
- package/dist/lib/components/DataTable/store/store.d.ts +28 -0
- package/dist/lib/components/DataTable/store/store.d.ts.map +1 -0
- package/dist/lib/components/DataTable/store/useTableSlice.d.ts +18 -0
- package/dist/lib/components/DataTable/store/useTableSlice.d.ts.map +1 -0
- package/dist/lib/components/DataTable/types.d.ts +66 -0
- package/dist/lib/components/DataTable/types.d.ts.map +1 -0
- package/dist/lib/components/DataTable/utils.d.ts +10 -0
- package/dist/lib/components/DataTable/utils.d.ts.map +1 -0
- package/dist/lib/components/DatePicker/DatePicker.d.ts +1 -1
- package/dist/lib/components/DatePicker/DatePicker.d.ts.map +1 -1
- package/dist/lib/components/Dialog/Dialog.d.ts +31 -0
- package/dist/lib/components/Dialog/Dialog.d.ts.map +1 -0
- package/dist/lib/components/Dialog/index.d.ts +3 -0
- package/dist/lib/components/Dialog/index.d.ts.map +1 -0
- package/dist/lib/components/DropdownMenu/DropdownMenu.d.ts +1 -1
- package/dist/lib/components/DropdownMenu/DropdownMenu.d.ts.map +1 -1
- package/dist/lib/components/DropdownMenu/types.d.ts +10 -1
- package/dist/lib/components/DropdownMenu/types.d.ts.map +1 -1
- package/dist/lib/components/Editor/context/editor-config-context.d.ts +9 -0
- package/dist/lib/components/Editor/context/editor-config-context.d.ts.map +1 -0
- package/dist/lib/components/Editor/context/toolbar-context.d.ts +18 -0
- package/dist/lib/components/Editor/context/toolbar-context.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-hooks/use-debounce.d.ts +2 -0
- package/dist/lib/components/Editor/editor-hooks/use-debounce.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-hooks/use-modal.d.ts +6 -0
- package/dist/lib/components/Editor/editor-hooks/use-modal.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-hooks/use-report.d.ts +2 -0
- package/dist/lib/components/Editor/editor-hooks/use-report.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-hooks/use-update-toolbar.d.ts +3 -0
- package/dist/lib/components/Editor/editor-hooks/use-update-toolbar.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/button-group.d.ts +12 -0
- package/dist/lib/components/Editor/editor-ui/button-group.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/button.d.ts +11 -0
- package/dist/lib/components/Editor/editor-ui/button.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/code-button.d.ts +8 -0
- package/dist/lib/components/Editor/editor-ui/code-button.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/color-picker.d.ts +92 -0
- package/dist/lib/components/Editor/editor-ui/color-picker.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/command.d.ts +19 -0
- package/dist/lib/components/Editor/editor-ui/command.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/content-editable.d.ts +9 -0
- package/dist/lib/components/Editor/editor-ui/content-editable.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/dialog.d.ts +16 -0
- package/dist/lib/components/Editor/editor-ui/dialog.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/image-component.d.ts +16 -0
- package/dist/lib/components/Editor/editor-ui/image-component.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/image-resizer.d.ts +18 -0
- package/dist/lib/components/Editor/editor-ui/image-resizer.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/input.d.ts +4 -0
- package/dist/lib/components/Editor/editor-ui/input.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/label.d.ts +5 -0
- package/dist/lib/components/Editor/editor-ui/label.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/popover.d.ts +8 -0
- package/dist/lib/components/Editor/editor-ui/popover.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/scroll-area.d.ts +6 -0
- package/dist/lib/components/Editor/editor-ui/scroll-area.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/select.d.ts +16 -0
- package/dist/lib/components/Editor/editor-ui/select.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/separator.d.ts +5 -0
- package/dist/lib/components/Editor/editor-ui/separator.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/tabs.d.ts +8 -0
- package/dist/lib/components/Editor/editor-ui/tabs.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/toggle-group.d.ts +8 -0
- package/dist/lib/components/Editor/editor-ui/toggle-group.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/toggle.d.ts +10 -0
- package/dist/lib/components/Editor/editor-ui/toggle.d.ts.map +1 -0
- package/dist/lib/components/Editor/editor-ui/tooltip.d.ts +8 -0
- package/dist/lib/components/Editor/editor-ui/tooltip.d.ts.map +1 -0
- package/dist/lib/components/Editor/index.d.ts +4 -0
- package/dist/lib/components/Editor/index.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes/autocomplete-node.d.ts +19 -0
- package/dist/lib/components/Editor/nodes/autocomplete-node.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes/embeds/tweet-node.d.ts +22 -0
- package/dist/lib/components/Editor/nodes/embeds/tweet-node.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes/embeds/youtube-node.d.ts +23 -0
- package/dist/lib/components/Editor/nodes/embeds/youtube-node.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes/emoji-node.d.ts +18 -0
- package/dist/lib/components/Editor/nodes/emoji-node.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes/image-node.d.ts +49 -0
- package/dist/lib/components/Editor/nodes/image-node.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes/keyword-node.d.ts +15 -0
- package/dist/lib/components/Editor/nodes/keyword-node.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes/layout-container-node.d.ts +23 -0
- package/dist/lib/components/Editor/nodes/layout-container-node.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes/layout-item-node.d.ts +15 -0
- package/dist/lib/components/Editor/nodes/layout-item-node.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes/mention-node.d.ts +21 -0
- package/dist/lib/components/Editor/nodes/mention-node.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes/nodes.d.ts +3 -0
- package/dist/lib/components/Editor/nodes/nodes.d.ts.map +1 -0
- package/dist/lib/components/Editor/nodes.d.ts +2 -0
- package/dist/lib/components/Editor/nodes.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/actions-plugin.d.ts +4 -0
- package/dist/lib/components/Editor/plugins/actions/actions-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/character-limit-plugin.d.ts +5 -0
- package/dist/lib/components/Editor/plugins/actions/character-limit-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/clear-editor-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/actions/clear-editor-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/counter-character-plugin.d.ts +6 -0
- package/dist/lib/components/Editor/plugins/actions/counter-character-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/edit-mode-toggle-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/actions/edit-mode-toggle-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/import-export-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/actions/import-export-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/markdown-toggle-plugin.d.ts +6 -0
- package/dist/lib/components/Editor/plugins/actions/markdown-toggle-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/max-length-plugin.d.ts +4 -0
- package/dist/lib/components/Editor/plugins/actions/max-length-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/share-content-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/actions/share-content-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/speech-to-text-plugin.d.ts +7 -0
- package/dist/lib/components/Editor/plugins/actions/speech-to-text-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/actions/tree-view-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/actions/tree-view-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/auto-link-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/auto-link-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/autocomplete-plugin.d.ts +11 -0
- package/dist/lib/components/Editor/plugins/autocomplete-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/code-action-menu-plugin.d.ts +4 -0
- package/dist/lib/components/Editor/plugins/code-action-menu-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/code-highlight-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/code-highlight-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/component-picker-menu-plugin.d.ts +9 -0
- package/dist/lib/components/Editor/plugins/component-picker-menu-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/context-menu-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/context-menu-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/drag-drop-paste-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/drag-drop-paste-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/draggable-block-plugin.d.ts +5 -0
- package/dist/lib/components/Editor/plugins/draggable-block-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/embeds/auto-embed-plugin.d.ts +18 -0
- package/dist/lib/components/Editor/plugins/embeds/auto-embed-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/embeds/twitter-plugin.d.ts +5 -0
- package/dist/lib/components/Editor/plugins/embeds/twitter-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/embeds/youtube-plugin.d.ts +5 -0
- package/dist/lib/components/Editor/plugins/embeds/youtube-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/emoji-picker-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/emoji-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/emojis-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/emojis-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/floating-link-editor-plugin.d.ts +7 -0
- package/dist/lib/components/Editor/plugins/floating-link-editor-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/floating-text-format-plugin.d.ts +7 -0
- package/dist/lib/components/Editor/plugins/floating-text-format-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/images-plugin.d.ts +25 -0
- package/dist/lib/components/Editor/plugins/images-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/keywords-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/keywords-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/layout-plugin.d.ts +13 -0
- package/dist/lib/components/Editor/plugins/layout-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/link-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/link-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/list-max-indent-level-plugin.d.ts +4 -0
- package/dist/lib/components/Editor/plugins/list-max-indent-level-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/mentions-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/mentions-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/alignment-picker-plugin.d.ts +5 -0
- package/dist/lib/components/Editor/plugins/picker/alignment-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/bulleted-list-picker-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/picker/bulleted-list-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/check-list-picker-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/picker/check-list-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/code-picker-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/picker/code-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/columns-layout-picker-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/picker/columns-layout-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/component-picker-menu-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/picker/component-picker-menu-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/component-picker-option.d.ts +17 -0
- package/dist/lib/components/Editor/plugins/picker/component-picker-option.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/divider-picker-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/picker/divider-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/embeds-picker-plugin.d.ts +5 -0
- package/dist/lib/components/Editor/plugins/picker/embeds-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/heading-picker-plugin.d.ts +5 -0
- package/dist/lib/components/Editor/plugins/picker/heading-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/image-picker-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/picker/image-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/numbered-list-picker-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/picker/numbered-list-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/paragraph-picker-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/picker/paragraph-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/quote-picker-plugin.d.ts +3 -0
- package/dist/lib/components/Editor/plugins/picker/quote-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/picker/table-picker-plugin.d.ts +6 -0
- package/dist/lib/components/Editor/plugins/picker/table-picker-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/plugins.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/plugins.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/tab-focus-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/tab-focus-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/table-plugin.d.ts +34 -0
- package/dist/lib/components/Editor/plugins/table-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/block-format-data.d.ts +5 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/block-format-data.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-bulleted-list.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-bulleted-list.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-check-list.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-check-list.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-code-block.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-code-block.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-heading.d.ts +5 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-heading.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-numbered-list.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-numbered-list.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-paragraph.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-paragraph.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-quote.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format/format-quote.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format-toolbar-plugin.d.ts +4 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-format-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert/insert-columns-layout.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert/insert-columns-layout.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert/insert-embeds.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert/insert-embeds.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert/insert-horizontal-rule.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert/insert-horizontal-rule.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert/insert-image.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert/insert-image.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert/insert-table.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert/insert-table.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert-plugin.d.ts +4 -0
- package/dist/lib/components/Editor/plugins/toolbar/block-insert-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/clear-formatting-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/clear-formatting-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/code-language-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/code-language-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/element-format-toolbar-plugin.d.ts +4 -0
- package/dist/lib/components/Editor/plugins/toolbar/element-format-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/font-background-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/font-background-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/font-color-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/font-color-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/font-family-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/font-family-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/font-format-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/font-format-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/font-size-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/font-size-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/history-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/history-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/horizontal-rule-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/horizontal-rule-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/image-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/image-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/link-toolbar-plugin.d.ts +4 -0
- package/dist/lib/components/Editor/plugins/toolbar/link-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/subsuper-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/subsuper-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/table-toolbar-plugin.d.ts +2 -0
- package/dist/lib/components/Editor/plugins/toolbar/table-toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/toolbar/toolbar-plugin.d.ts +6 -0
- package/dist/lib/components/Editor/plugins/toolbar/toolbar-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins/typing-pref-plugin.d.ts +4 -0
- package/dist/lib/components/Editor/plugins/typing-pref-plugin.d.ts.map +1 -0
- package/dist/lib/components/Editor/plugins.d.ts +2 -0
- package/dist/lib/components/Editor/plugins.d.ts.map +1 -0
- package/dist/lib/components/Editor/shared/can-use-dom.d.ts +2 -0
- package/dist/lib/components/Editor/shared/can-use-dom.d.ts.map +1 -0
- package/dist/lib/components/Editor/shared/caret-from-point.d.ts +5 -0
- package/dist/lib/components/Editor/shared/caret-from-point.d.ts.map +1 -0
- package/dist/lib/components/Editor/shared/environment.d.ts +18 -0
- package/dist/lib/components/Editor/shared/environment.d.ts.map +1 -0
- package/dist/lib/components/Editor/shared/invariant.d.ts +2 -0
- package/dist/lib/components/Editor/shared/invariant.d.ts.map +1 -0
- package/dist/lib/components/Editor/shared/normalize-class-names.d.ts +2 -0
- package/dist/lib/components/Editor/shared/normalize-class-names.d.ts.map +1 -0
- package/dist/lib/components/Editor/shared/react-patches.d.ts +2 -0
- package/dist/lib/components/Editor/shared/react-patches.d.ts.map +1 -0
- package/dist/lib/components/Editor/shared/react-test-utils.d.ts +3 -0
- package/dist/lib/components/Editor/shared/react-test-utils.d.ts.map +1 -0
- package/dist/lib/components/Editor/shared/simple-diff-with-cursor.d.ts +6 -0
- package/dist/lib/components/Editor/shared/simple-diff-with-cursor.d.ts.map +1 -0
- package/dist/lib/components/Editor/shared/use-layout-effect.d.ts +4 -0
- package/dist/lib/components/Editor/shared/use-layout-effect.d.ts.map +1 -0
- package/dist/lib/components/Editor/shared/warn-only-once.d.ts +2 -0
- package/dist/lib/components/Editor/shared/warn-only-once.d.ts.map +1 -0
- package/dist/lib/components/Editor/themes/editor-theme.d.ts +3 -0
- package/dist/lib/components/Editor/themes/editor-theme.d.ts.map +1 -0
- package/dist/lib/components/Editor/transformers/index.d.ts +16 -0
- package/dist/lib/components/Editor/transformers/index.d.ts.map +1 -0
- package/dist/lib/components/Editor/transformers/markdown-emoji-transformer.d.ts +3 -0
- package/dist/lib/components/Editor/transformers/markdown-emoji-transformer.d.ts.map +1 -0
- package/dist/lib/components/Editor/transformers/markdown-hr-transformer.d.ts +3 -0
- package/dist/lib/components/Editor/transformers/markdown-hr-transformer.d.ts.map +1 -0
- package/dist/lib/components/Editor/transformers/markdown-image-transformer.d.ts +3 -0
- package/dist/lib/components/Editor/transformers/markdown-image-transformer.d.ts.map +1 -0
- package/dist/lib/components/Editor/transformers/markdown-table-transformer.d.ts +3 -0
- package/dist/lib/components/Editor/transformers/markdown-table-transformer.d.ts.map +1 -0
- package/dist/lib/components/Editor/transformers/markdown-tweet-transformer.d.ts +3 -0
- package/dist/lib/components/Editor/transformers/markdown-tweet-transformer.d.ts.map +1 -0
- package/dist/lib/components/Editor/types.d.ts +23 -0
- package/dist/lib/components/Editor/types.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/can-use-dom.d.ts +2 -0
- package/dist/lib/components/Editor/utils/can-use-dom.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/collapsible.d.ts +3 -0
- package/dist/lib/components/Editor/utils/collapsible.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/doc-serialization.d.ts +4 -0
- package/dist/lib/components/Editor/utils/doc-serialization.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/emoji-list.d.ts +21 -0
- package/dist/lib/components/Editor/utils/emoji-list.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/get-dom-range-rect.d.ts +2 -0
- package/dist/lib/components/Editor/utils/get-dom-range-rect.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/get-selected-node.d.ts +3 -0
- package/dist/lib/components/Editor/utils/get-selected-node.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/guard.d.ts +2 -0
- package/dist/lib/components/Editor/utils/guard.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/is-mobile-width.d.ts +2 -0
- package/dist/lib/components/Editor/utils/is-mobile-width.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/set-floating-elem-position-for-link-editor.d.ts +2 -0
- package/dist/lib/components/Editor/utils/set-floating-elem-position-for-link-editor.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/set-floating-elem-position.d.ts +2 -0
- package/dist/lib/components/Editor/utils/set-floating-elem-position.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/swipe.d.ts +5 -0
- package/dist/lib/components/Editor/utils/swipe.d.ts.map +1 -0
- package/dist/lib/components/Editor/utils/url.d.ts +3 -0
- package/dist/lib/components/Editor/utils/url.d.ts.map +1 -0
- package/dist/lib/components/Empty/Empty.d.ts +12 -0
- package/dist/lib/components/Empty/Empty.d.ts.map +1 -0
- package/dist/lib/components/Empty/index.d.ts +3 -0
- package/dist/lib/components/Empty/index.d.ts.map +1 -0
- package/dist/lib/components/ErrorBoundary/ErrorBoundary.d.ts +7 -0
- package/dist/lib/components/ErrorBoundary/ErrorBoundary.d.ts.map +1 -0
- package/dist/lib/components/ErrorBoundary/ErrorPage.d.ts +38 -0
- package/dist/lib/components/ErrorBoundary/ErrorPage.d.ts.map +1 -0
- package/dist/lib/components/ErrorBoundary/index.d.ts +3 -0
- package/dist/lib/components/ErrorBoundary/index.d.ts.map +1 -0
- package/dist/lib/components/FilePreview/FilePreview.d.ts +8 -0
- package/dist/lib/components/FilePreview/FilePreview.d.ts.map +1 -0
- package/dist/lib/components/FilePreview/index.d.ts +2 -0
- package/dist/lib/components/FilePreview/index.d.ts.map +1 -0
- package/dist/lib/components/Form/Form.d.ts +6 -3
- package/dist/lib/components/Form/Form.d.ts.map +1 -1
- package/dist/lib/components/HierarchyGraph/HierarchyGraph.d.ts +24 -0
- package/dist/lib/components/HierarchyGraph/HierarchyGraph.d.ts.map +1 -0
- package/dist/lib/components/HierarchyGraph/index.d.ts +5 -0
- package/dist/lib/components/HierarchyGraph/index.d.ts.map +1 -0
- package/dist/lib/components/PageHeader/PageHeader.d.ts +8 -0
- package/dist/lib/components/PageHeader/PageHeader.d.ts.map +1 -0
- package/dist/lib/components/PageHeader/PageHeaderSkeleton.d.ts +10 -0
- package/dist/lib/components/PageHeader/PageHeaderSkeleton.d.ts.map +1 -0
- package/dist/lib/components/PageHeader/index.d.ts +3 -0
- package/dist/lib/components/PageHeader/index.d.ts.map +1 -0
- package/dist/lib/components/PhoneField/PhoneField.d.ts +1 -0
- package/dist/lib/components/PhoneField/PhoneField.d.ts.map +1 -1
- package/dist/lib/components/RadioGroup/RadioGroup.d.ts +23 -0
- package/dist/lib/components/RadioGroup/RadioGroup.d.ts.map +1 -0
- package/dist/lib/components/RadioGroup/index.d.ts +3 -0
- package/dist/lib/components/RadioGroup/index.d.ts.map +1 -0
- package/dist/lib/components/Select/Select.d.ts +21 -0
- package/dist/lib/components/Select/Select.d.ts.map +1 -0
- package/dist/lib/components/Select/SelectFilter.d.ts +20 -0
- package/dist/lib/components/Select/SelectFilter.d.ts.map +1 -0
- package/dist/lib/components/Select/components/MultiSelect/MultiSelect.d.ts +27 -0
- package/dist/lib/components/Select/components/MultiSelect/MultiSelect.d.ts.map +1 -0
- package/dist/lib/components/Select/components/MultiSelect/MultiSelectFilter.d.ts +28 -0
- package/dist/lib/components/Select/components/MultiSelect/MultiSelectFilter.d.ts.map +1 -0
- package/dist/lib/components/Select/components/SingleSelect/SingleSelect.d.ts +41 -0
- package/dist/lib/components/Select/components/SingleSelect/SingleSelect.d.ts.map +1 -0
- package/dist/lib/components/Select/components/SingleSelect/SingleSelectFilter.d.ts +28 -0
- package/dist/lib/components/Select/components/SingleSelect/SingleSelectFilter.d.ts.map +1 -0
- package/dist/lib/components/Select/hooks/useMultiSelect.d.ts +33 -0
- package/dist/lib/components/Select/hooks/useMultiSelect.d.ts.map +1 -0
- package/dist/lib/components/Select/hooks/useSelect.d.ts +25 -0
- package/dist/lib/components/Select/hooks/useSelect.d.ts.map +1 -0
- package/dist/lib/components/Select/hooks/useSingleSelect.d.ts +31 -0
- package/dist/lib/components/Select/hooks/useSingleSelect.d.ts.map +1 -0
- package/dist/lib/components/Select/index.d.ts +40 -0
- package/dist/lib/components/Select/index.d.ts.map +1 -0
- package/dist/lib/components/Select/types.d.ts +38 -0
- package/dist/lib/components/Select/types.d.ts.map +1 -0
- package/dist/lib/components/Sidebar/Sidebar.d.ts +24 -0
- package/dist/lib/components/Sidebar/Sidebar.d.ts.map +1 -0
- package/dist/lib/components/Sidebar/index.d.ts +2 -0
- package/dist/lib/components/Sidebar/index.d.ts.map +1 -0
- package/dist/lib/components/Sortable/Sortable.d.ts +39 -0
- package/dist/lib/components/Sortable/Sortable.d.ts.map +1 -0
- package/dist/lib/components/Sortable/index.d.ts +3 -0
- package/dist/lib/components/Sortable/index.d.ts.map +1 -0
- package/dist/lib/components/StepProgressIndicator/StepProgressIndicator.d.ts +12 -0
- package/dist/lib/components/StepProgressIndicator/StepProgressIndicator.d.ts.map +1 -0
- package/dist/lib/components/StepProgressIndicator/index.d.ts +3 -0
- package/dist/lib/components/StepProgressIndicator/index.d.ts.map +1 -0
- package/dist/lib/components/Switch/Switch.d.ts.map +1 -1
- package/dist/lib/components/Tabs/Tabs.d.ts +27 -0
- package/dist/lib/components/Tabs/Tabs.d.ts.map +1 -0
- package/dist/lib/components/Tabs/TabsSkeleton.d.ts +11 -0
- package/dist/lib/components/Tabs/TabsSkeleton.d.ts.map +1 -0
- package/dist/lib/components/Tabs/index.d.ts +3 -0
- package/dist/lib/components/Tabs/index.d.ts.map +1 -0
- package/dist/lib/components/TextArea/TextArea.d.ts.map +1 -1
- package/dist/lib/components/TextField/TextField.d.ts.map +1 -1
- package/dist/lib/components/UploadFile/UploadFile.d.ts +26 -0
- package/dist/lib/components/UploadFile/UploadFile.d.ts.map +1 -0
- package/dist/lib/components/UploadFile/index.d.ts +2 -0
- package/dist/lib/components/UploadFile/index.d.ts.map +1 -0
- package/dist/lib/components/ValueFilter/ValueFilter.d.ts +11 -0
- package/dist/lib/components/ValueFilter/ValueFilter.d.ts.map +1 -0
- package/dist/lib/components/ValueFilter/index.d.ts +3 -0
- package/dist/lib/components/ValueFilter/index.d.ts.map +1 -0
- package/dist/lib/components/ViewTabs/ViewTabs.d.ts +23 -0
- package/dist/lib/components/ViewTabs/ViewTabs.d.ts.map +1 -0
- package/dist/lib/components/ViewTabs/index.d.ts +3 -0
- package/dist/lib/components/ViewTabs/index.d.ts.map +1 -0
- package/dist/lib/components/index.d.ts +21 -1
- package/dist/lib/components/index.d.ts.map +1 -1
- package/dist/lib/config/index.d.ts +6 -0
- package/dist/lib/config/index.d.ts.map +1 -1
- package/dist/lib/context/ConfirmContext.d.ts +21 -0
- package/dist/lib/context/ConfirmContext.d.ts.map +1 -0
- package/dist/lib/context/ThemeContext.d.ts +1 -1
- package/dist/lib/context/ThemeContext.d.ts.map +1 -1
- package/dist/lib/context/index.d.ts +2 -1
- package/dist/lib/context/index.d.ts.map +1 -1
- package/dist/lib/hooks/index.d.ts +7 -1
- package/dist/lib/hooks/index.d.ts.map +1 -1
- package/dist/lib/hooks/useConfirm.d.ts +4 -0
- package/dist/lib/hooks/useConfirm.d.ts.map +1 -0
- package/dist/lib/hooks/useDialog.d.ts +11 -0
- package/dist/lib/hooks/useDialog.d.ts.map +1 -0
- package/dist/lib/hooks/useIsMobile.d.ts +2 -0
- package/dist/lib/hooks/useIsMobile.d.ts.map +1 -0
- package/dist/lib/hooks/useSSE.d.ts +21 -0
- package/dist/lib/hooks/useSSE.d.ts.map +1 -0
- package/dist/lib/hooks/useSlugParams.d.ts +12 -0
- package/dist/lib/hooks/useSlugParams.d.ts.map +1 -0
- package/dist/lib/hooks/useTimer.d.ts +6 -0
- package/dist/lib/hooks/useTimer.d.ts.map +1 -0
- package/dist/lib/index.d.ts +3 -2
- package/dist/lib/index.d.ts.map +1 -1
- package/dist/lib/selects/app/AppFilter.d.ts +11 -0
- package/dist/lib/selects/app/AppFilter.d.ts.map +1 -0
- package/dist/lib/selects/app/AppSelector.d.ts +4 -0
- package/dist/lib/selects/app/AppSelector.d.ts.map +1 -0
- package/dist/lib/selects/app/index.d.ts +3 -0
- package/dist/lib/selects/app/index.d.ts.map +1 -0
- package/dist/lib/selects/app-code/AppCodeFilter.d.ts +11 -0
- package/dist/lib/selects/app-code/AppCodeFilter.d.ts.map +1 -0
- package/dist/lib/selects/app-code/AppCodeSelector.d.ts +4 -0
- package/dist/lib/selects/app-code/AppCodeSelector.d.ts.map +1 -0
- package/dist/lib/selects/app-code/index.d.ts +3 -0
- package/dist/lib/selects/app-code/index.d.ts.map +1 -0
- package/dist/lib/selects/cloud-provider/CloudProviderFilter.d.ts +11 -0
- package/dist/lib/selects/cloud-provider/CloudProviderFilter.d.ts.map +1 -0
- package/dist/lib/selects/cloud-provider/CloudProviderSelector.d.ts +4 -0
- package/dist/lib/selects/cloud-provider/CloudProviderSelector.d.ts.map +1 -0
- package/dist/lib/selects/cloud-provider/index.d.ts +3 -0
- package/dist/lib/selects/cloud-provider/index.d.ts.map +1 -0
- package/dist/lib/selects/currency/CurrencyFilter.d.ts +11 -0
- package/dist/lib/selects/currency/CurrencyFilter.d.ts.map +1 -0
- package/dist/lib/selects/currency/CurrencySelector.d.ts +4 -0
- package/dist/lib/selects/currency/CurrencySelector.d.ts.map +1 -0
- package/dist/lib/selects/currency/currencies.d.ts +3 -0
- package/dist/lib/selects/currency/currencies.d.ts.map +1 -0
- package/dist/lib/selects/currency/index.d.ts +3 -0
- package/dist/lib/selects/currency/index.d.ts.map +1 -0
- package/dist/lib/selects/deployment/DeploymentFilter.d.ts +11 -0
- package/dist/lib/selects/deployment/DeploymentFilter.d.ts.map +1 -0
- package/dist/lib/selects/deployment/DeploymentSelector.d.ts +4 -0
- package/dist/lib/selects/deployment/DeploymentSelector.d.ts.map +1 -0
- package/dist/lib/selects/deployment/index.d.ts +3 -0
- package/dist/lib/selects/deployment/index.d.ts.map +1 -0
- package/dist/lib/selects/feature/FeatureFilter.d.ts +11 -0
- package/dist/lib/selects/feature/FeatureFilter.d.ts.map +1 -0
- package/dist/lib/selects/feature/FeatureSelector.d.ts +4 -0
- package/dist/lib/selects/feature/FeatureSelector.d.ts.map +1 -0
- package/dist/lib/selects/feature/index.d.ts +3 -0
- package/dist/lib/selects/feature/index.d.ts.map +1 -0
- package/dist/lib/selects/index.d.ts +12 -0
- package/dist/lib/selects/index.d.ts.map +1 -0
- package/dist/lib/selects/industry/IndustryFilter.d.ts +11 -0
- package/dist/lib/selects/industry/IndustryFilter.d.ts.map +1 -0
- package/dist/lib/selects/industry/IndustrySelector.d.ts +4 -0
- package/dist/lib/selects/industry/IndustrySelector.d.ts.map +1 -0
- package/dist/lib/selects/industry/index.d.ts +3 -0
- package/dist/lib/selects/industry/index.d.ts.map +1 -0
- package/dist/lib/selects/locale/LocaleFilter.d.ts +11 -0
- package/dist/lib/selects/locale/LocaleFilter.d.ts.map +1 -0
- package/dist/lib/selects/locale/LocaleSelector.d.ts +4 -0
- package/dist/lib/selects/locale/LocaleSelector.d.ts.map +1 -0
- package/dist/lib/selects/locale/index.d.ts +3 -0
- package/dist/lib/selects/locale/index.d.ts.map +1 -0
- package/dist/lib/selects/locale/locales.d.ts +3 -0
- package/dist/lib/selects/locale/locales.d.ts.map +1 -0
- package/dist/lib/selects/microfrontend/MicrofrontendSelector.d.ts +4 -0
- package/dist/lib/selects/microfrontend/MicrofrontendSelector.d.ts.map +1 -0
- package/dist/lib/selects/microfrontend/index.d.ts +2 -0
- package/dist/lib/selects/microfrontend/index.d.ts.map +1 -0
- package/dist/lib/selects/plan/PlanFilter.d.ts +11 -0
- package/dist/lib/selects/plan/PlanFilter.d.ts.map +1 -0
- package/dist/lib/selects/plan/PlanSelector.d.ts +4 -0
- package/dist/lib/selects/plan/PlanSelector.d.ts.map +1 -0
- package/dist/lib/selects/plan/index.d.ts +3 -0
- package/dist/lib/selects/plan/index.d.ts.map +1 -0
- package/dist/lib/selects/region/RegionFilter.d.ts +11 -0
- package/dist/lib/selects/region/RegionFilter.d.ts.map +1 -0
- package/dist/lib/selects/region/RegionSelector.d.ts +4 -0
- package/dist/lib/selects/region/RegionSelector.d.ts.map +1 -0
- package/dist/lib/selects/region/index.d.ts +3 -0
- package/dist/lib/selects/region/index.d.ts.map +1 -0
- package/dist/lib/selects/timezone/TimezoneFilter.d.ts +11 -0
- package/dist/lib/selects/timezone/TimezoneFilter.d.ts.map +1 -0
- package/dist/lib/selects/timezone/TimezoneSelector.d.ts +4 -0
- package/dist/lib/selects/timezone/TimezoneSelector.d.ts.map +1 -0
- package/dist/lib/selects/timezone/index.d.ts +3 -0
- package/dist/lib/selects/timezone/index.d.ts.map +1 -0
- package/dist/lib/selects/timezone/timezones.d.ts +3 -0
- package/dist/lib/selects/timezone/timezones.d.ts.map +1 -0
- package/dist/lib/services/table-views.service.d.ts +25 -0
- package/dist/lib/services/table-views.service.d.ts.map +1 -0
- package/dist/lib/types/api-response.d.ts +21 -0
- package/dist/lib/types/api-response.d.ts.map +1 -0
- package/dist/lib/types/table-filter.d.ts +41 -0
- package/dist/lib/types/table-filter.d.ts.map +1 -0
- package/dist/lib/utils/axios.d.ts.map +1 -1
- package/dist/lib/utils/index.d.ts +1 -0
- package/dist/lib/utils/index.d.ts.map +1 -1
- package/dist/lib/utils/motion.d.ts +2 -0
- package/dist/lib/utils/motion.d.ts.map +1 -0
- package/dist/lib/utils/slug.d.ts +7 -0
- package/dist/lib/utils/slug.d.ts.map +1 -0
- package/dist/plus.js +18 -0
- package/dist/plus.js.map +1 -0
- package/dist/popover.js +33 -0
- package/dist/popover.js.map +1 -0
- package/dist/proxy.js +11392 -0
- package/dist/proxy.js.map +1 -0
- package/dist/react-error-boundary.js +67 -0
- package/dist/react-error-boundary.js.map +1 -0
- package/dist/select2.js +116 -0
- package/dist/select2.js.map +1 -0
- package/dist/selects/app-code.js +37 -0
- package/dist/selects/app-code.js.map +1 -0
- package/dist/selects/app.js +2 -0
- package/dist/selects/app.js.map +1 -0
- package/dist/selects/cloud-provider.js +2 -0
- package/dist/selects/cloud-provider.js.map +1 -0
- package/dist/selects/currency.js +2 -0
- package/dist/selects/currency.js.map +1 -0
- package/dist/selects/deployment.js +2 -0
- package/dist/selects/deployment.js.map +1 -0
- package/dist/selects/feature.js +2 -0
- package/dist/selects/feature.js.map +1 -0
- package/dist/selects/industry.js +2 -0
- package/dist/selects/industry.js.map +1 -0
- package/dist/selects/locale.js +2 -0
- package/dist/selects/locale.js.map +1 -0
- package/dist/selects/microfrontend.js +2 -0
- package/dist/selects/microfrontend.js.map +1 -0
- package/dist/selects/plan.js +2 -0
- package/dist/selects/plan.js.map +1 -0
- package/dist/selects/region.js +2 -0
- package/dist/selects/region.js.map +1 -0
- package/dist/selects/timezone.js +2 -0
- package/dist/selects/timezone.js.map +1 -0
- package/dist/separator2.js +1 -27
- package/dist/separator2.js.map +1 -1
- package/dist/shadcn/index.d.ts +2 -0
- package/dist/shadcn/index.d.ts.map +1 -1
- package/dist/shadcn/shadcnAlert/alert.d.ts.map +1 -1
- package/dist/shadcn/shadcnAlert/index.d.ts +1 -1
- package/dist/shadcn/shadcnAlert/index.d.ts.map +1 -1
- package/dist/shadcn/shadcnBadge/Badge.d.ts +1 -1
- package/dist/shadcn/shadcnBreadcrumb/breadcrumb.d.ts +18 -0
- package/dist/shadcn/shadcnBreadcrumb/breadcrumb.d.ts.map +1 -0
- package/dist/shadcn/shadcnBreadcrumb/index.d.ts +2 -0
- package/dist/shadcn/shadcnBreadcrumb/index.d.ts.map +1 -0
- package/dist/shadcn/shadcnButton/Button.d.ts +2 -2
- package/dist/shadcn/shadcnButton/Button.d.ts.map +1 -1
- package/dist/shadcn/shadcnCalendar/calendar.d.ts +1 -1
- package/dist/shadcn/shadcnCalendar/calendar.d.ts.map +1 -1
- package/dist/shadcn/shadcnChart/Chart.d.ts +2 -2
- package/dist/shadcn/shadcnChart/Chart.d.ts.map +1 -1
- package/dist/shadcn/shadcnCollapsible/collapsible.d.ts +7 -0
- package/dist/shadcn/shadcnCollapsible/collapsible.d.ts.map +1 -0
- package/dist/shadcn/shadcnCollapsible/index.d.ts +2 -0
- package/dist/shadcn/shadcnCollapsible/index.d.ts.map +1 -0
- package/dist/shadcn/shadcnDialog/dialog.d.ts +20 -0
- package/dist/shadcn/shadcnDialog/dialog.d.ts.map +1 -0
- package/dist/shadcn/shadcnDialog/index.d.ts +2 -0
- package/dist/shadcn/shadcnDialog/index.d.ts.map +1 -0
- package/dist/shadcn/shadcnDropdownMenu/dropdown-menu.d.ts +1 -1
- package/dist/shadcn/shadcnDropdownMenu/dropdown-menu.d.ts.map +1 -1
- package/dist/shadcn/shadcnForm/form.d.ts +1 -1
- package/dist/shadcn/shadcnForm/form.d.ts.map +1 -1
- package/dist/shadcn/shadcnInputOTP/InputOTP.d.ts +3 -3
- package/dist/shadcn/shadcnInputOTP/InputOTP.d.ts.map +1 -1
- package/dist/shadcn/shadcnMultiSelect/index.d.ts +3 -0
- package/dist/shadcn/shadcnMultiSelect/index.d.ts.map +1 -0
- package/dist/shadcn/shadcnMultiSelect/multi-select.d.ts +61 -0
- package/dist/shadcn/shadcnMultiSelect/multi-select.d.ts.map +1 -0
- package/dist/shadcn/shadcnProgress/Progress.d.ts +1 -1
- package/dist/shadcn/shadcnProgress/Progress.d.ts.map +1 -1
- package/dist/shadcn/shadcnRadioGroup/RadioGroup.d.ts +6 -0
- package/dist/shadcn/shadcnRadioGroup/RadioGroup.d.ts.map +1 -0
- package/dist/shadcn/shadcnRadioGroup/index.d.ts +2 -0
- package/dist/shadcn/shadcnRadioGroup/index.d.ts.map +1 -0
- package/dist/shadcn/shadcnSheet/sheet.d.ts +1 -1
- package/dist/shadcn/shadcnSheet/sheet.d.ts.map +1 -1
- package/dist/shadcn/shadcnSidebar/index.d.ts +2 -0
- package/dist/shadcn/shadcnSidebar/index.d.ts.map +1 -0
- package/dist/shadcn/shadcnSidebar/sidebar.d.ts +86 -0
- package/dist/shadcn/shadcnSidebar/sidebar.d.ts.map +1 -0
- package/dist/shadcn/shadcnSingleSelect/index.d.ts +3 -0
- package/dist/shadcn/shadcnSingleSelect/index.d.ts.map +1 -0
- package/dist/shadcn/shadcnSingleSelect/single-select.d.ts +61 -0
- package/dist/shadcn/shadcnSingleSelect/single-select.d.ts.map +1 -0
- package/dist/shadcn/shadcnSonner/sonner.d.ts +1 -1
- package/dist/shadcn/shadcnSonner/sonner.d.ts.map +1 -1
- package/dist/shadcn/shadcnSwitch/Switch.d.ts.map +1 -1
- package/dist/shadcn/shadcnTable/table.d.ts +1 -1
- package/dist/shadcn/shadcnTable/table.d.ts.map +1 -1
- package/dist/shadcn/shadcnTabs/index.d.ts +2 -0
- package/dist/shadcn/shadcnTabs/index.d.ts.map +1 -0
- package/dist/shadcn/shadcnTabs/tabs.d.ts +8 -0
- package/dist/shadcn/shadcnTabs/tabs.d.ts.map +1 -0
- package/dist/shadcn/shadcnTooltip/tooltip.d.ts +1 -1
- package/dist/shadcn/shadcnTooltip/tooltip.d.ts.map +1 -1
- package/dist/share-2.js +42 -0
- package/dist/share-2.js.map +1 -0
- package/dist/text-align-justify.js +34 -0
- package/dist/text-align-justify.js.map +1 -0
- package/dist/trash-2.js +55 -0
- package/dist/trash-2.js.map +1 -0
- package/dist/types/api-response.js +2 -0
- package/dist/types/api-response.js.map +1 -0
- package/dist/types/table-filter.js +17 -0
- package/dist/types/table-filter.js.map +1 -0
- package/dist/upload.js +19 -0
- package/dist/upload.js.map +1 -0
- package/dist/useConfirm.js +37 -0
- package/dist/useConfirm.js.map +1 -0
- package/dist/useDataTable.js +26545 -0
- package/dist/useDataTable.js.map +1 -0
- package/dist/useIsMobile.js +19 -0
- package/dist/useIsMobile.js.map +1 -0
- package/dist/useTheme.js.map +1 -1
- package/dist/useTimer.js +112 -0
- package/dist/useTimer.js.map +1 -0
- package/dist/utils/axios.js +1 -1
- package/dist/utils/motion.js +4425 -0
- package/dist/utils/motion.js.map +1 -0
- package/dist/utils/slug.js +15 -0
- package/dist/utils/slug.js.map +1 -0
- package/dist/utils.js +204 -39
- package/dist/utils.js.map +1 -1
- package/dist/value.js +820 -0
- package/dist/value.js.map +1 -0
- package/dist/x.js +18 -0
- package/dist/x.js.map +1 -0
- package/package.json +196 -7
- package/dist/SelectField.js +0 -1351
- package/dist/SelectField.js.map +0 -1
- package/dist/chevron-down.js.map +0 -1
- package/dist/components/SelectField.js +0 -2
- package/dist/components/SelectField.js.map +0 -1
- package/dist/lib/components/SelectField/SelectField.d.ts +0 -24
- package/dist/lib/components/SelectField/SelectField.d.ts.map +0 -1
- package/dist/lib/components/SelectField/index.d.ts +0 -3
- package/dist/lib/components/SelectField/index.d.ts.map +0 -1
package/dist/Form.js
CHANGED
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
-
import
|
|
3
|
-
import React__default from 'react';
|
|
2
|
+
import React__default, { useCallback, Children, isValidElement, Fragment, cloneElement } from 'react';
|
|
4
3
|
import { c as cn } from './utils.js';
|
|
4
|
+
import { a as axios } from './axios.js';
|
|
5
5
|
import { A as Alert } from './Alert.js';
|
|
6
6
|
import { B as Button } from './Button.js';
|
|
7
7
|
import { C as Checkbox } from './Checkbox.js';
|
|
8
|
+
import { C as CheckboxGroup } from './CheckboxGroup.js';
|
|
9
|
+
import { P as PhoneField } from './PhoneField.js';
|
|
10
|
+
import { R as RadioGroup } from './RadioGroup.js';
|
|
8
11
|
import { S as Switch } from './Switch.js';
|
|
12
|
+
import { U as UploadFile } from './UploadFile.js';
|
|
9
13
|
|
|
10
14
|
var isCheckBoxInput = (element) => element.type === 'checkbox';
|
|
11
15
|
|
|
@@ -110,11 +114,25 @@ var set = (object, path, value) => {
|
|
|
110
114
|
|
|
111
115
|
const EVENTS = {
|
|
112
116
|
BLUR: 'blur',
|
|
117
|
+
FOCUS_OUT: 'focusout',
|
|
113
118
|
CHANGE: 'change',
|
|
114
119
|
};
|
|
115
120
|
const VALIDATION_MODE = {
|
|
121
|
+
onBlur: 'onBlur',
|
|
122
|
+
onChange: 'onChange',
|
|
123
|
+
onSubmit: 'onSubmit',
|
|
124
|
+
onTouched: 'onTouched',
|
|
116
125
|
all: 'all',
|
|
117
126
|
};
|
|
127
|
+
const INPUT_VALIDATION_RULES = {
|
|
128
|
+
max: 'max',
|
|
129
|
+
min: 'min',
|
|
130
|
+
maxLength: 'maxLength',
|
|
131
|
+
minLength: 'minLength',
|
|
132
|
+
pattern: 'pattern',
|
|
133
|
+
required: 'required',
|
|
134
|
+
validate: 'validate',
|
|
135
|
+
};
|
|
118
136
|
|
|
119
137
|
/**
|
|
120
138
|
* Separate context for `control` to prevent unnecessary rerenders.
|
|
@@ -214,11 +232,14 @@ var isString = (value) => typeof value === 'string';
|
|
|
214
232
|
|
|
215
233
|
var generateWatchOutput = (names, _names, formValues, isGlobal, defaultValue) => {
|
|
216
234
|
if (isString(names)) {
|
|
235
|
+
isGlobal && _names.watch.add(names);
|
|
217
236
|
return get(formValues, names, defaultValue);
|
|
218
237
|
}
|
|
219
238
|
if (Array.isArray(names)) {
|
|
220
|
-
return names.map((fieldName) => (
|
|
239
|
+
return names.map((fieldName) => (isGlobal && _names.watch.add(fieldName),
|
|
240
|
+
get(formValues, fieldName)));
|
|
221
241
|
}
|
|
242
|
+
isGlobal && (_names.watchAll = true);
|
|
222
243
|
return formValues;
|
|
223
244
|
};
|
|
224
245
|
|
|
@@ -616,6 +637,1868 @@ const FormProvider = (props) => {
|
|
|
616
637
|
React__default.createElement(HookFormControlContext.Provider, { value: control }, children)));
|
|
617
638
|
};
|
|
618
639
|
|
|
640
|
+
var appendErrors = (name, validateAllFieldCriteria, errors, type, message) => validateAllFieldCriteria
|
|
641
|
+
? {
|
|
642
|
+
...errors[name],
|
|
643
|
+
types: {
|
|
644
|
+
...(errors[name] && errors[name].types ? errors[name].types : {}),
|
|
645
|
+
[type]: message || true,
|
|
646
|
+
},
|
|
647
|
+
}
|
|
648
|
+
: {};
|
|
649
|
+
|
|
650
|
+
var convertToArrayPayload = (value) => (Array.isArray(value) ? value : [value]);
|
|
651
|
+
|
|
652
|
+
var createSubject = () => {
|
|
653
|
+
let _observers = [];
|
|
654
|
+
const next = (value) => {
|
|
655
|
+
for (const observer of _observers) {
|
|
656
|
+
observer.next && observer.next(value);
|
|
657
|
+
}
|
|
658
|
+
};
|
|
659
|
+
const subscribe = (observer) => {
|
|
660
|
+
_observers.push(observer);
|
|
661
|
+
return {
|
|
662
|
+
unsubscribe: () => {
|
|
663
|
+
_observers = _observers.filter((o) => o !== observer);
|
|
664
|
+
},
|
|
665
|
+
};
|
|
666
|
+
};
|
|
667
|
+
const unsubscribe = () => {
|
|
668
|
+
_observers = [];
|
|
669
|
+
};
|
|
670
|
+
return {
|
|
671
|
+
get observers() {
|
|
672
|
+
return _observers;
|
|
673
|
+
},
|
|
674
|
+
next,
|
|
675
|
+
subscribe,
|
|
676
|
+
unsubscribe,
|
|
677
|
+
};
|
|
678
|
+
};
|
|
679
|
+
|
|
680
|
+
function extractFormValues(fieldsState, formValues) {
|
|
681
|
+
const values = {};
|
|
682
|
+
for (const key in fieldsState) {
|
|
683
|
+
if (fieldsState.hasOwnProperty(key)) {
|
|
684
|
+
const fieldState = fieldsState[key];
|
|
685
|
+
const fieldValue = formValues[key];
|
|
686
|
+
if (fieldState && isObject(fieldState) && fieldValue) {
|
|
687
|
+
const nestedFieldsState = extractFormValues(fieldState, fieldValue);
|
|
688
|
+
if (isObject(nestedFieldsState)) {
|
|
689
|
+
values[key] = nestedFieldsState;
|
|
690
|
+
}
|
|
691
|
+
}
|
|
692
|
+
else if (fieldsState[key]) {
|
|
693
|
+
values[key] = fieldValue;
|
|
694
|
+
}
|
|
695
|
+
}
|
|
696
|
+
}
|
|
697
|
+
return values;
|
|
698
|
+
}
|
|
699
|
+
|
|
700
|
+
var isEmptyObject = (value) => isObject(value) && !Object.keys(value).length;
|
|
701
|
+
|
|
702
|
+
var isFileInput = (element) => element.type === 'file';
|
|
703
|
+
|
|
704
|
+
var isHTMLElement = (value) => {
|
|
705
|
+
if (!isWeb) {
|
|
706
|
+
return false;
|
|
707
|
+
}
|
|
708
|
+
const owner = value ? value.ownerDocument : 0;
|
|
709
|
+
return (value instanceof
|
|
710
|
+
(owner && owner.defaultView ? owner.defaultView.HTMLElement : HTMLElement));
|
|
711
|
+
};
|
|
712
|
+
|
|
713
|
+
var isMultipleSelect = (element) => element.type === `select-multiple`;
|
|
714
|
+
|
|
715
|
+
var isRadioInput = (element) => element.type === 'radio';
|
|
716
|
+
|
|
717
|
+
var isRadioOrCheckbox = (ref) => isRadioInput(ref) || isCheckBoxInput(ref);
|
|
718
|
+
|
|
719
|
+
var live = (ref) => isHTMLElement(ref) && ref.isConnected;
|
|
720
|
+
|
|
721
|
+
function baseGet(object, updatePath) {
|
|
722
|
+
const length = updatePath.slice(0, -1).length;
|
|
723
|
+
let index = 0;
|
|
724
|
+
while (index < length) {
|
|
725
|
+
object = isUndefined(object) ? index++ : object[updatePath[index++]];
|
|
726
|
+
}
|
|
727
|
+
return object;
|
|
728
|
+
}
|
|
729
|
+
function isEmptyArray(obj) {
|
|
730
|
+
for (const key in obj) {
|
|
731
|
+
if (obj.hasOwnProperty(key) && !isUndefined(obj[key])) {
|
|
732
|
+
return false;
|
|
733
|
+
}
|
|
734
|
+
}
|
|
735
|
+
return true;
|
|
736
|
+
}
|
|
737
|
+
function unset(object, path) {
|
|
738
|
+
const paths = Array.isArray(path)
|
|
739
|
+
? path
|
|
740
|
+
: isKey(path)
|
|
741
|
+
? [path]
|
|
742
|
+
: stringToPath(path);
|
|
743
|
+
const childObject = paths.length === 1 ? object : baseGet(object, paths);
|
|
744
|
+
const index = paths.length - 1;
|
|
745
|
+
const key = paths[index];
|
|
746
|
+
if (childObject) {
|
|
747
|
+
delete childObject[key];
|
|
748
|
+
}
|
|
749
|
+
if (index !== 0 &&
|
|
750
|
+
((isObject(childObject) && isEmptyObject(childObject)) ||
|
|
751
|
+
(Array.isArray(childObject) && isEmptyArray(childObject)))) {
|
|
752
|
+
unset(object, paths.slice(0, -1));
|
|
753
|
+
}
|
|
754
|
+
return object;
|
|
755
|
+
}
|
|
756
|
+
|
|
757
|
+
var objectHasFunction = (data) => {
|
|
758
|
+
for (const key in data) {
|
|
759
|
+
if (isFunction(data[key])) {
|
|
760
|
+
return true;
|
|
761
|
+
}
|
|
762
|
+
}
|
|
763
|
+
return false;
|
|
764
|
+
};
|
|
765
|
+
|
|
766
|
+
function isTraversable(value) {
|
|
767
|
+
return Array.isArray(value) || (isObject(value) && !objectHasFunction(value));
|
|
768
|
+
}
|
|
769
|
+
function markFieldsDirty(data, fields = {}) {
|
|
770
|
+
for (const key in data) {
|
|
771
|
+
const value = data[key];
|
|
772
|
+
if (isTraversable(value)) {
|
|
773
|
+
fields[key] = Array.isArray(value) ? [] : {};
|
|
774
|
+
markFieldsDirty(value, fields[key]);
|
|
775
|
+
}
|
|
776
|
+
else if (!isUndefined(value)) {
|
|
777
|
+
fields[key] = true;
|
|
778
|
+
}
|
|
779
|
+
}
|
|
780
|
+
return fields;
|
|
781
|
+
}
|
|
782
|
+
function getDirtyFields(data, formValues, dirtyFieldsFromValues) {
|
|
783
|
+
if (!dirtyFieldsFromValues) {
|
|
784
|
+
dirtyFieldsFromValues = markFieldsDirty(formValues);
|
|
785
|
+
}
|
|
786
|
+
for (const key in data) {
|
|
787
|
+
const value = data[key];
|
|
788
|
+
if (isTraversable(value)) {
|
|
789
|
+
if (isUndefined(formValues) || isPrimitive(dirtyFieldsFromValues[key])) {
|
|
790
|
+
dirtyFieldsFromValues[key] = markFieldsDirty(value, Array.isArray(value) ? [] : {});
|
|
791
|
+
}
|
|
792
|
+
else {
|
|
793
|
+
getDirtyFields(value, isNullOrUndefined(formValues) ? {} : formValues[key], dirtyFieldsFromValues[key]);
|
|
794
|
+
}
|
|
795
|
+
}
|
|
796
|
+
else {
|
|
797
|
+
const formValue = formValues[key];
|
|
798
|
+
dirtyFieldsFromValues[key] = !deepEqual(value, formValue);
|
|
799
|
+
}
|
|
800
|
+
}
|
|
801
|
+
return dirtyFieldsFromValues;
|
|
802
|
+
}
|
|
803
|
+
|
|
804
|
+
const defaultResult = {
|
|
805
|
+
value: false,
|
|
806
|
+
isValid: false,
|
|
807
|
+
};
|
|
808
|
+
const validResult = { value: true, isValid: true };
|
|
809
|
+
var getCheckboxValue = (options) => {
|
|
810
|
+
if (Array.isArray(options)) {
|
|
811
|
+
if (options.length > 1) {
|
|
812
|
+
const values = options
|
|
813
|
+
.filter((option) => option && option.checked && !option.disabled)
|
|
814
|
+
.map((option) => option.value);
|
|
815
|
+
return { value: values, isValid: !!values.length };
|
|
816
|
+
}
|
|
817
|
+
return options[0].checked && !options[0].disabled
|
|
818
|
+
? // @ts-expect-error expected to work in the browser
|
|
819
|
+
options[0].attributes && !isUndefined(options[0].attributes.value)
|
|
820
|
+
? isUndefined(options[0].value) || options[0].value === ''
|
|
821
|
+
? validResult
|
|
822
|
+
: { value: options[0].value, isValid: true }
|
|
823
|
+
: validResult
|
|
824
|
+
: defaultResult;
|
|
825
|
+
}
|
|
826
|
+
return defaultResult;
|
|
827
|
+
};
|
|
828
|
+
|
|
829
|
+
var getFieldValueAs = (value, { valueAsNumber, valueAsDate, setValueAs }) => isUndefined(value)
|
|
830
|
+
? value
|
|
831
|
+
: valueAsNumber
|
|
832
|
+
? value === ''
|
|
833
|
+
? NaN
|
|
834
|
+
: value
|
|
835
|
+
? +value
|
|
836
|
+
: value
|
|
837
|
+
: valueAsDate && isString(value)
|
|
838
|
+
? new Date(value)
|
|
839
|
+
: setValueAs
|
|
840
|
+
? setValueAs(value)
|
|
841
|
+
: value;
|
|
842
|
+
|
|
843
|
+
const defaultReturn = {
|
|
844
|
+
isValid: false,
|
|
845
|
+
value: null,
|
|
846
|
+
};
|
|
847
|
+
var getRadioValue = (options) => Array.isArray(options)
|
|
848
|
+
? options.reduce((previous, option) => option && option.checked && !option.disabled
|
|
849
|
+
? {
|
|
850
|
+
isValid: true,
|
|
851
|
+
value: option.value,
|
|
852
|
+
}
|
|
853
|
+
: previous, defaultReturn)
|
|
854
|
+
: defaultReturn;
|
|
855
|
+
|
|
856
|
+
function getFieldValue(_f) {
|
|
857
|
+
const ref = _f.ref;
|
|
858
|
+
if (isFileInput(ref)) {
|
|
859
|
+
return ref.files;
|
|
860
|
+
}
|
|
861
|
+
if (isRadioInput(ref)) {
|
|
862
|
+
return getRadioValue(_f.refs).value;
|
|
863
|
+
}
|
|
864
|
+
if (isMultipleSelect(ref)) {
|
|
865
|
+
return [...ref.selectedOptions].map(({ value }) => value);
|
|
866
|
+
}
|
|
867
|
+
if (isCheckBoxInput(ref)) {
|
|
868
|
+
return getCheckboxValue(_f.refs).value;
|
|
869
|
+
}
|
|
870
|
+
return getFieldValueAs(isUndefined(ref.value) ? _f.ref.value : ref.value, _f);
|
|
871
|
+
}
|
|
872
|
+
|
|
873
|
+
var getResolverOptions = (fieldsNames, _fields, criteriaMode, shouldUseNativeValidation) => {
|
|
874
|
+
const fields = {};
|
|
875
|
+
for (const name of fieldsNames) {
|
|
876
|
+
const field = get(_fields, name);
|
|
877
|
+
field && set(fields, name, field._f);
|
|
878
|
+
}
|
|
879
|
+
return {
|
|
880
|
+
criteriaMode,
|
|
881
|
+
names: [...fieldsNames],
|
|
882
|
+
fields,
|
|
883
|
+
shouldUseNativeValidation,
|
|
884
|
+
};
|
|
885
|
+
};
|
|
886
|
+
|
|
887
|
+
var isRegex = (value) => value instanceof RegExp;
|
|
888
|
+
|
|
889
|
+
var getRuleValue = (rule) => isUndefined(rule)
|
|
890
|
+
? rule
|
|
891
|
+
: isRegex(rule)
|
|
892
|
+
? rule.source
|
|
893
|
+
: isObject(rule)
|
|
894
|
+
? isRegex(rule.value)
|
|
895
|
+
? rule.value.source
|
|
896
|
+
: rule.value
|
|
897
|
+
: rule;
|
|
898
|
+
|
|
899
|
+
var getValidationModes = (mode) => ({
|
|
900
|
+
isOnSubmit: !mode || mode === VALIDATION_MODE.onSubmit,
|
|
901
|
+
isOnBlur: mode === VALIDATION_MODE.onBlur,
|
|
902
|
+
isOnChange: mode === VALIDATION_MODE.onChange,
|
|
903
|
+
isOnAll: mode === VALIDATION_MODE.all,
|
|
904
|
+
isOnTouch: mode === VALIDATION_MODE.onTouched,
|
|
905
|
+
});
|
|
906
|
+
|
|
907
|
+
const ASYNC_FUNCTION = 'AsyncFunction';
|
|
908
|
+
var hasPromiseValidation = (fieldReference) => !!fieldReference &&
|
|
909
|
+
!!fieldReference.validate &&
|
|
910
|
+
!!((isFunction(fieldReference.validate) &&
|
|
911
|
+
fieldReference.validate.constructor.name === ASYNC_FUNCTION) ||
|
|
912
|
+
(isObject(fieldReference.validate) &&
|
|
913
|
+
Object.values(fieldReference.validate).find((validateFunction) => validateFunction.constructor.name === ASYNC_FUNCTION)));
|
|
914
|
+
|
|
915
|
+
var hasValidation = (options) => options.mount &&
|
|
916
|
+
(options.required ||
|
|
917
|
+
options.min ||
|
|
918
|
+
options.max ||
|
|
919
|
+
options.maxLength ||
|
|
920
|
+
options.minLength ||
|
|
921
|
+
options.pattern ||
|
|
922
|
+
options.validate);
|
|
923
|
+
|
|
924
|
+
var isWatched = (name, _names, isBlurEvent) => !isBlurEvent &&
|
|
925
|
+
(_names.watchAll ||
|
|
926
|
+
_names.watch.has(name) ||
|
|
927
|
+
[..._names.watch].some((watchName) => name.startsWith(watchName) &&
|
|
928
|
+
/^\.\w+/.test(name.slice(watchName.length))));
|
|
929
|
+
|
|
930
|
+
const iterateFieldsByAction = (fields, action, fieldsNames, abortEarly) => {
|
|
931
|
+
for (const key of fieldsNames || Object.keys(fields)) {
|
|
932
|
+
const field = get(fields, key);
|
|
933
|
+
if (field) {
|
|
934
|
+
const { _f, ...currentField } = field;
|
|
935
|
+
if (_f) {
|
|
936
|
+
if (_f.refs && _f.refs[0] && action(_f.refs[0], key) && !abortEarly) {
|
|
937
|
+
return true;
|
|
938
|
+
}
|
|
939
|
+
else if (_f.ref && action(_f.ref, _f.name) && !abortEarly) {
|
|
940
|
+
return true;
|
|
941
|
+
}
|
|
942
|
+
else {
|
|
943
|
+
if (iterateFieldsByAction(currentField, action)) {
|
|
944
|
+
break;
|
|
945
|
+
}
|
|
946
|
+
}
|
|
947
|
+
}
|
|
948
|
+
else if (isObject(currentField)) {
|
|
949
|
+
if (iterateFieldsByAction(currentField, action)) {
|
|
950
|
+
break;
|
|
951
|
+
}
|
|
952
|
+
}
|
|
953
|
+
}
|
|
954
|
+
}
|
|
955
|
+
return;
|
|
956
|
+
};
|
|
957
|
+
|
|
958
|
+
function schemaErrorLookup(errors, _fields, name) {
|
|
959
|
+
const error = get(errors, name);
|
|
960
|
+
if (error || isKey(name)) {
|
|
961
|
+
return {
|
|
962
|
+
error,
|
|
963
|
+
name,
|
|
964
|
+
};
|
|
965
|
+
}
|
|
966
|
+
const names = name.split('.');
|
|
967
|
+
while (names.length) {
|
|
968
|
+
const fieldName = names.join('.');
|
|
969
|
+
const field = get(_fields, fieldName);
|
|
970
|
+
const foundError = get(errors, fieldName);
|
|
971
|
+
if (field && !Array.isArray(field) && name !== fieldName) {
|
|
972
|
+
return { name };
|
|
973
|
+
}
|
|
974
|
+
if (foundError && foundError.type) {
|
|
975
|
+
return {
|
|
976
|
+
name: fieldName,
|
|
977
|
+
error: foundError,
|
|
978
|
+
};
|
|
979
|
+
}
|
|
980
|
+
if (foundError && foundError.root && foundError.root.type) {
|
|
981
|
+
return {
|
|
982
|
+
name: `${fieldName}.root`,
|
|
983
|
+
error: foundError.root,
|
|
984
|
+
};
|
|
985
|
+
}
|
|
986
|
+
names.pop();
|
|
987
|
+
}
|
|
988
|
+
return {
|
|
989
|
+
name,
|
|
990
|
+
};
|
|
991
|
+
}
|
|
992
|
+
|
|
993
|
+
var shouldRenderFormState = (formStateData, _proxyFormState, updateFormState, isRoot) => {
|
|
994
|
+
updateFormState(formStateData);
|
|
995
|
+
const { name, ...formState } = formStateData;
|
|
996
|
+
return (isEmptyObject(formState) ||
|
|
997
|
+
Object.keys(formState).length >= Object.keys(_proxyFormState).length ||
|
|
998
|
+
Object.keys(formState).find((key) => _proxyFormState[key] ===
|
|
999
|
+
(!isRoot || VALIDATION_MODE.all)));
|
|
1000
|
+
};
|
|
1001
|
+
|
|
1002
|
+
var shouldSubscribeByName = (name, signalName, exact) => !name ||
|
|
1003
|
+
!signalName ||
|
|
1004
|
+
name === signalName ||
|
|
1005
|
+
convertToArrayPayload(name).some((currentName) => currentName &&
|
|
1006
|
+
(exact
|
|
1007
|
+
? currentName === signalName
|
|
1008
|
+
: currentName.startsWith(signalName) ||
|
|
1009
|
+
signalName.startsWith(currentName)));
|
|
1010
|
+
|
|
1011
|
+
var skipValidation = (isBlurEvent, isTouched, isSubmitted, reValidateMode, mode) => {
|
|
1012
|
+
if (mode.isOnAll) {
|
|
1013
|
+
return false;
|
|
1014
|
+
}
|
|
1015
|
+
else if (!isSubmitted && mode.isOnTouch) {
|
|
1016
|
+
return !(isTouched || isBlurEvent);
|
|
1017
|
+
}
|
|
1018
|
+
else if (isSubmitted ? reValidateMode.isOnBlur : mode.isOnBlur) {
|
|
1019
|
+
return !isBlurEvent;
|
|
1020
|
+
}
|
|
1021
|
+
else if (isSubmitted ? reValidateMode.isOnChange : mode.isOnChange) {
|
|
1022
|
+
return isBlurEvent;
|
|
1023
|
+
}
|
|
1024
|
+
return true;
|
|
1025
|
+
};
|
|
1026
|
+
|
|
1027
|
+
var unsetEmptyArray = (ref, name) => !compact(get(ref, name)).length && unset(ref, name);
|
|
1028
|
+
|
|
1029
|
+
var updateFieldArrayRootError = (errors, error, name) => {
|
|
1030
|
+
const fieldArrayErrors = convertToArrayPayload(get(errors, name));
|
|
1031
|
+
set(fieldArrayErrors, 'root', error[name]);
|
|
1032
|
+
set(errors, name, fieldArrayErrors);
|
|
1033
|
+
return errors;
|
|
1034
|
+
};
|
|
1035
|
+
|
|
1036
|
+
function getValidateError(result, ref, type = 'validate') {
|
|
1037
|
+
if (isString(result) ||
|
|
1038
|
+
(Array.isArray(result) && result.every(isString)) ||
|
|
1039
|
+
(isBoolean(result) && !result)) {
|
|
1040
|
+
return {
|
|
1041
|
+
type,
|
|
1042
|
+
message: isString(result) ? result : '',
|
|
1043
|
+
ref,
|
|
1044
|
+
};
|
|
1045
|
+
}
|
|
1046
|
+
}
|
|
1047
|
+
|
|
1048
|
+
var getValueAndMessage = (validationData) => isObject(validationData) && !isRegex(validationData)
|
|
1049
|
+
? validationData
|
|
1050
|
+
: {
|
|
1051
|
+
value: validationData,
|
|
1052
|
+
message: '',
|
|
1053
|
+
};
|
|
1054
|
+
|
|
1055
|
+
var validateField = async (field, disabledFieldNames, formValues, validateAllFieldCriteria, shouldUseNativeValidation, isFieldArray) => {
|
|
1056
|
+
const { ref, refs, required, maxLength, minLength, min, max, pattern, validate, name, valueAsNumber, mount, } = field._f;
|
|
1057
|
+
const inputValue = get(formValues, name);
|
|
1058
|
+
if (!mount || disabledFieldNames.has(name)) {
|
|
1059
|
+
return {};
|
|
1060
|
+
}
|
|
1061
|
+
const inputRef = refs ? refs[0] : ref;
|
|
1062
|
+
const setCustomValidity = (message) => {
|
|
1063
|
+
if (shouldUseNativeValidation && inputRef.reportValidity) {
|
|
1064
|
+
inputRef.setCustomValidity(isBoolean(message) ? '' : message || '');
|
|
1065
|
+
inputRef.reportValidity();
|
|
1066
|
+
}
|
|
1067
|
+
};
|
|
1068
|
+
const error = {};
|
|
1069
|
+
const isRadio = isRadioInput(ref);
|
|
1070
|
+
const isCheckBox = isCheckBoxInput(ref);
|
|
1071
|
+
const isRadioOrCheckbox = isRadio || isCheckBox;
|
|
1072
|
+
const isEmpty = ((valueAsNumber || isFileInput(ref)) &&
|
|
1073
|
+
isUndefined(ref.value) &&
|
|
1074
|
+
isUndefined(inputValue)) ||
|
|
1075
|
+
(isHTMLElement(ref) && ref.value === '') ||
|
|
1076
|
+
inputValue === '' ||
|
|
1077
|
+
(Array.isArray(inputValue) && !inputValue.length);
|
|
1078
|
+
const appendErrorsCurry = appendErrors.bind(null, name, validateAllFieldCriteria, error);
|
|
1079
|
+
const getMinMaxMessage = (exceedMax, maxLengthMessage, minLengthMessage, maxType = INPUT_VALIDATION_RULES.maxLength, minType = INPUT_VALIDATION_RULES.minLength) => {
|
|
1080
|
+
const message = exceedMax ? maxLengthMessage : minLengthMessage;
|
|
1081
|
+
error[name] = {
|
|
1082
|
+
type: exceedMax ? maxType : minType,
|
|
1083
|
+
message,
|
|
1084
|
+
ref,
|
|
1085
|
+
...appendErrorsCurry(exceedMax ? maxType : minType, message),
|
|
1086
|
+
};
|
|
1087
|
+
};
|
|
1088
|
+
if (isFieldArray
|
|
1089
|
+
? !Array.isArray(inputValue) || !inputValue.length
|
|
1090
|
+
: required &&
|
|
1091
|
+
((!isRadioOrCheckbox && (isEmpty || isNullOrUndefined(inputValue))) ||
|
|
1092
|
+
(isBoolean(inputValue) && !inputValue) ||
|
|
1093
|
+
(isCheckBox && !getCheckboxValue(refs).isValid) ||
|
|
1094
|
+
(isRadio && !getRadioValue(refs).isValid))) {
|
|
1095
|
+
const { value, message } = isString(required)
|
|
1096
|
+
? { value: !!required, message: required }
|
|
1097
|
+
: getValueAndMessage(required);
|
|
1098
|
+
if (value) {
|
|
1099
|
+
error[name] = {
|
|
1100
|
+
type: INPUT_VALIDATION_RULES.required,
|
|
1101
|
+
message,
|
|
1102
|
+
ref: inputRef,
|
|
1103
|
+
...appendErrorsCurry(INPUT_VALIDATION_RULES.required, message),
|
|
1104
|
+
};
|
|
1105
|
+
if (!validateAllFieldCriteria) {
|
|
1106
|
+
setCustomValidity(message);
|
|
1107
|
+
return error;
|
|
1108
|
+
}
|
|
1109
|
+
}
|
|
1110
|
+
}
|
|
1111
|
+
if (!isEmpty && (!isNullOrUndefined(min) || !isNullOrUndefined(max))) {
|
|
1112
|
+
let exceedMax;
|
|
1113
|
+
let exceedMin;
|
|
1114
|
+
const maxOutput = getValueAndMessage(max);
|
|
1115
|
+
const minOutput = getValueAndMessage(min);
|
|
1116
|
+
if (!isNullOrUndefined(inputValue) && !isNaN(inputValue)) {
|
|
1117
|
+
const valueNumber = ref.valueAsNumber ||
|
|
1118
|
+
(inputValue ? +inputValue : inputValue);
|
|
1119
|
+
if (!isNullOrUndefined(maxOutput.value)) {
|
|
1120
|
+
exceedMax = valueNumber > maxOutput.value;
|
|
1121
|
+
}
|
|
1122
|
+
if (!isNullOrUndefined(minOutput.value)) {
|
|
1123
|
+
exceedMin = valueNumber < minOutput.value;
|
|
1124
|
+
}
|
|
1125
|
+
}
|
|
1126
|
+
else {
|
|
1127
|
+
const valueDate = ref.valueAsDate || new Date(inputValue);
|
|
1128
|
+
const convertTimeToDate = (time) => new Date(new Date().toDateString() + ' ' + time);
|
|
1129
|
+
const isTime = ref.type == 'time';
|
|
1130
|
+
const isWeek = ref.type == 'week';
|
|
1131
|
+
if (isString(maxOutput.value) && inputValue) {
|
|
1132
|
+
exceedMax = isTime
|
|
1133
|
+
? convertTimeToDate(inputValue) > convertTimeToDate(maxOutput.value)
|
|
1134
|
+
: isWeek
|
|
1135
|
+
? inputValue > maxOutput.value
|
|
1136
|
+
: valueDate > new Date(maxOutput.value);
|
|
1137
|
+
}
|
|
1138
|
+
if (isString(minOutput.value) && inputValue) {
|
|
1139
|
+
exceedMin = isTime
|
|
1140
|
+
? convertTimeToDate(inputValue) < convertTimeToDate(minOutput.value)
|
|
1141
|
+
: isWeek
|
|
1142
|
+
? inputValue < minOutput.value
|
|
1143
|
+
: valueDate < new Date(minOutput.value);
|
|
1144
|
+
}
|
|
1145
|
+
}
|
|
1146
|
+
if (exceedMax || exceedMin) {
|
|
1147
|
+
getMinMaxMessage(!!exceedMax, maxOutput.message, minOutput.message, INPUT_VALIDATION_RULES.max, INPUT_VALIDATION_RULES.min);
|
|
1148
|
+
if (!validateAllFieldCriteria) {
|
|
1149
|
+
setCustomValidity(error[name].message);
|
|
1150
|
+
return error;
|
|
1151
|
+
}
|
|
1152
|
+
}
|
|
1153
|
+
}
|
|
1154
|
+
if ((maxLength || minLength) &&
|
|
1155
|
+
!isEmpty &&
|
|
1156
|
+
(isString(inputValue) || (isFieldArray && Array.isArray(inputValue)))) {
|
|
1157
|
+
const maxLengthOutput = getValueAndMessage(maxLength);
|
|
1158
|
+
const minLengthOutput = getValueAndMessage(minLength);
|
|
1159
|
+
const exceedMax = !isNullOrUndefined(maxLengthOutput.value) &&
|
|
1160
|
+
inputValue.length > +maxLengthOutput.value;
|
|
1161
|
+
const exceedMin = !isNullOrUndefined(minLengthOutput.value) &&
|
|
1162
|
+
inputValue.length < +minLengthOutput.value;
|
|
1163
|
+
if (exceedMax || exceedMin) {
|
|
1164
|
+
getMinMaxMessage(exceedMax, maxLengthOutput.message, minLengthOutput.message);
|
|
1165
|
+
if (!validateAllFieldCriteria) {
|
|
1166
|
+
setCustomValidity(error[name].message);
|
|
1167
|
+
return error;
|
|
1168
|
+
}
|
|
1169
|
+
}
|
|
1170
|
+
}
|
|
1171
|
+
if (pattern && !isEmpty && isString(inputValue)) {
|
|
1172
|
+
const { value: patternValue, message } = getValueAndMessage(pattern);
|
|
1173
|
+
if (isRegex(patternValue) && !inputValue.match(patternValue)) {
|
|
1174
|
+
error[name] = {
|
|
1175
|
+
type: INPUT_VALIDATION_RULES.pattern,
|
|
1176
|
+
message,
|
|
1177
|
+
ref,
|
|
1178
|
+
...appendErrorsCurry(INPUT_VALIDATION_RULES.pattern, message),
|
|
1179
|
+
};
|
|
1180
|
+
if (!validateAllFieldCriteria) {
|
|
1181
|
+
setCustomValidity(message);
|
|
1182
|
+
return error;
|
|
1183
|
+
}
|
|
1184
|
+
}
|
|
1185
|
+
}
|
|
1186
|
+
if (validate) {
|
|
1187
|
+
if (isFunction(validate)) {
|
|
1188
|
+
const result = await validate(inputValue, formValues);
|
|
1189
|
+
const validateError = getValidateError(result, inputRef);
|
|
1190
|
+
if (validateError) {
|
|
1191
|
+
error[name] = {
|
|
1192
|
+
...validateError,
|
|
1193
|
+
...appendErrorsCurry(INPUT_VALIDATION_RULES.validate, validateError.message),
|
|
1194
|
+
};
|
|
1195
|
+
if (!validateAllFieldCriteria) {
|
|
1196
|
+
setCustomValidity(validateError.message);
|
|
1197
|
+
return error;
|
|
1198
|
+
}
|
|
1199
|
+
}
|
|
1200
|
+
}
|
|
1201
|
+
else if (isObject(validate)) {
|
|
1202
|
+
let validationResult = {};
|
|
1203
|
+
for (const key in validate) {
|
|
1204
|
+
if (!isEmptyObject(validationResult) && !validateAllFieldCriteria) {
|
|
1205
|
+
break;
|
|
1206
|
+
}
|
|
1207
|
+
const validateError = getValidateError(await validate[key](inputValue, formValues), inputRef, key);
|
|
1208
|
+
if (validateError) {
|
|
1209
|
+
validationResult = {
|
|
1210
|
+
...validateError,
|
|
1211
|
+
...appendErrorsCurry(key, validateError.message),
|
|
1212
|
+
};
|
|
1213
|
+
setCustomValidity(validateError.message);
|
|
1214
|
+
if (validateAllFieldCriteria) {
|
|
1215
|
+
error[name] = validationResult;
|
|
1216
|
+
}
|
|
1217
|
+
}
|
|
1218
|
+
}
|
|
1219
|
+
if (!isEmptyObject(validationResult)) {
|
|
1220
|
+
error[name] = {
|
|
1221
|
+
ref: inputRef,
|
|
1222
|
+
...validationResult,
|
|
1223
|
+
};
|
|
1224
|
+
if (!validateAllFieldCriteria) {
|
|
1225
|
+
return error;
|
|
1226
|
+
}
|
|
1227
|
+
}
|
|
1228
|
+
}
|
|
1229
|
+
}
|
|
1230
|
+
setCustomValidity(true);
|
|
1231
|
+
return error;
|
|
1232
|
+
};
|
|
1233
|
+
|
|
1234
|
+
const defaultOptions = {
|
|
1235
|
+
mode: VALIDATION_MODE.onSubmit,
|
|
1236
|
+
reValidateMode: VALIDATION_MODE.onChange,
|
|
1237
|
+
shouldFocusError: true,
|
|
1238
|
+
};
|
|
1239
|
+
function createFormControl(props = {}) {
|
|
1240
|
+
let _options = {
|
|
1241
|
+
...defaultOptions,
|
|
1242
|
+
...props,
|
|
1243
|
+
};
|
|
1244
|
+
let _formState = {
|
|
1245
|
+
submitCount: 0,
|
|
1246
|
+
isDirty: false,
|
|
1247
|
+
isReady: false,
|
|
1248
|
+
isLoading: isFunction(_options.defaultValues),
|
|
1249
|
+
isValidating: false,
|
|
1250
|
+
isSubmitted: false,
|
|
1251
|
+
isSubmitting: false,
|
|
1252
|
+
isSubmitSuccessful: false,
|
|
1253
|
+
isValid: false,
|
|
1254
|
+
touchedFields: {},
|
|
1255
|
+
dirtyFields: {},
|
|
1256
|
+
validatingFields: {},
|
|
1257
|
+
errors: _options.errors || {},
|
|
1258
|
+
disabled: _options.disabled || false,
|
|
1259
|
+
};
|
|
1260
|
+
let _fields = {};
|
|
1261
|
+
let _defaultValues = isObject(_options.defaultValues) || isObject(_options.values)
|
|
1262
|
+
? cloneObject(_options.defaultValues || _options.values) || {}
|
|
1263
|
+
: {};
|
|
1264
|
+
let _formValues = _options.shouldUnregister
|
|
1265
|
+
? {}
|
|
1266
|
+
: cloneObject(_defaultValues);
|
|
1267
|
+
let _state = {
|
|
1268
|
+
action: false,
|
|
1269
|
+
mount: false,
|
|
1270
|
+
watch: false,
|
|
1271
|
+
keepIsValid: false,
|
|
1272
|
+
};
|
|
1273
|
+
let _names = {
|
|
1274
|
+
mount: new Set(),
|
|
1275
|
+
disabled: new Set(),
|
|
1276
|
+
unMount: new Set(),
|
|
1277
|
+
array: new Set(),
|
|
1278
|
+
watch: new Set(),
|
|
1279
|
+
};
|
|
1280
|
+
let delayErrorCallback;
|
|
1281
|
+
let timer = 0;
|
|
1282
|
+
const defaultProxyFormState = {
|
|
1283
|
+
isDirty: false,
|
|
1284
|
+
dirtyFields: false,
|
|
1285
|
+
validatingFields: false,
|
|
1286
|
+
touchedFields: false,
|
|
1287
|
+
isValidating: false,
|
|
1288
|
+
isValid: false,
|
|
1289
|
+
errors: false,
|
|
1290
|
+
};
|
|
1291
|
+
const _proxyFormState = {
|
|
1292
|
+
...defaultProxyFormState,
|
|
1293
|
+
};
|
|
1294
|
+
let _proxySubscribeFormState = {
|
|
1295
|
+
..._proxyFormState,
|
|
1296
|
+
};
|
|
1297
|
+
const _subjects = {
|
|
1298
|
+
array: createSubject(),
|
|
1299
|
+
state: createSubject(),
|
|
1300
|
+
};
|
|
1301
|
+
const shouldDisplayAllAssociatedErrors = _options.criteriaMode === VALIDATION_MODE.all;
|
|
1302
|
+
const debounce = (callback) => (wait) => {
|
|
1303
|
+
clearTimeout(timer);
|
|
1304
|
+
timer = setTimeout(callback, wait);
|
|
1305
|
+
};
|
|
1306
|
+
const _setValid = async (shouldUpdateValid) => {
|
|
1307
|
+
if (_state.keepIsValid) {
|
|
1308
|
+
return;
|
|
1309
|
+
}
|
|
1310
|
+
if (!_options.disabled &&
|
|
1311
|
+
(_proxyFormState.isValid ||
|
|
1312
|
+
_proxySubscribeFormState.isValid ||
|
|
1313
|
+
shouldUpdateValid)) {
|
|
1314
|
+
let isValid;
|
|
1315
|
+
if (_options.resolver) {
|
|
1316
|
+
isValid = isEmptyObject((await _runSchema()).errors);
|
|
1317
|
+
_updateIsValidating();
|
|
1318
|
+
}
|
|
1319
|
+
else {
|
|
1320
|
+
isValid = await executeBuiltInValidation(_fields, true);
|
|
1321
|
+
}
|
|
1322
|
+
if (isValid !== _formState.isValid) {
|
|
1323
|
+
_subjects.state.next({
|
|
1324
|
+
isValid,
|
|
1325
|
+
});
|
|
1326
|
+
}
|
|
1327
|
+
}
|
|
1328
|
+
};
|
|
1329
|
+
const _updateIsValidating = (names, isValidating) => {
|
|
1330
|
+
if (!_options.disabled &&
|
|
1331
|
+
(_proxyFormState.isValidating ||
|
|
1332
|
+
_proxyFormState.validatingFields ||
|
|
1333
|
+
_proxySubscribeFormState.isValidating ||
|
|
1334
|
+
_proxySubscribeFormState.validatingFields)) {
|
|
1335
|
+
(names || Array.from(_names.mount)).forEach((name) => {
|
|
1336
|
+
if (name) {
|
|
1337
|
+
isValidating
|
|
1338
|
+
? set(_formState.validatingFields, name, isValidating)
|
|
1339
|
+
: unset(_formState.validatingFields, name);
|
|
1340
|
+
}
|
|
1341
|
+
});
|
|
1342
|
+
_subjects.state.next({
|
|
1343
|
+
validatingFields: _formState.validatingFields,
|
|
1344
|
+
isValidating: !isEmptyObject(_formState.validatingFields),
|
|
1345
|
+
});
|
|
1346
|
+
}
|
|
1347
|
+
};
|
|
1348
|
+
const _setFieldArray = (name, values = [], method, args, shouldSetValues = true, shouldUpdateFieldsAndState = true) => {
|
|
1349
|
+
if (args && method && !_options.disabled) {
|
|
1350
|
+
_state.action = true;
|
|
1351
|
+
if (shouldUpdateFieldsAndState && Array.isArray(get(_fields, name))) {
|
|
1352
|
+
const fieldValues = method(get(_fields, name), args.argA, args.argB);
|
|
1353
|
+
shouldSetValues && set(_fields, name, fieldValues);
|
|
1354
|
+
}
|
|
1355
|
+
if (shouldUpdateFieldsAndState &&
|
|
1356
|
+
Array.isArray(get(_formState.errors, name))) {
|
|
1357
|
+
const errors = method(get(_formState.errors, name), args.argA, args.argB);
|
|
1358
|
+
shouldSetValues && set(_formState.errors, name, errors);
|
|
1359
|
+
unsetEmptyArray(_formState.errors, name);
|
|
1360
|
+
}
|
|
1361
|
+
if ((_proxyFormState.touchedFields ||
|
|
1362
|
+
_proxySubscribeFormState.touchedFields) &&
|
|
1363
|
+
shouldUpdateFieldsAndState &&
|
|
1364
|
+
Array.isArray(get(_formState.touchedFields, name))) {
|
|
1365
|
+
const touchedFields = method(get(_formState.touchedFields, name), args.argA, args.argB);
|
|
1366
|
+
shouldSetValues && set(_formState.touchedFields, name, touchedFields);
|
|
1367
|
+
}
|
|
1368
|
+
if (_proxyFormState.dirtyFields || _proxySubscribeFormState.dirtyFields) {
|
|
1369
|
+
_formState.dirtyFields = getDirtyFields(_defaultValues, _formValues);
|
|
1370
|
+
}
|
|
1371
|
+
_subjects.state.next({
|
|
1372
|
+
name,
|
|
1373
|
+
isDirty: _getDirty(name, values),
|
|
1374
|
+
dirtyFields: _formState.dirtyFields,
|
|
1375
|
+
errors: _formState.errors,
|
|
1376
|
+
isValid: _formState.isValid,
|
|
1377
|
+
});
|
|
1378
|
+
}
|
|
1379
|
+
else {
|
|
1380
|
+
set(_formValues, name, values);
|
|
1381
|
+
}
|
|
1382
|
+
};
|
|
1383
|
+
const updateErrors = (name, error) => {
|
|
1384
|
+
set(_formState.errors, name, error);
|
|
1385
|
+
_subjects.state.next({
|
|
1386
|
+
errors: _formState.errors,
|
|
1387
|
+
});
|
|
1388
|
+
};
|
|
1389
|
+
const _setErrors = (errors) => {
|
|
1390
|
+
_formState.errors = errors;
|
|
1391
|
+
_subjects.state.next({
|
|
1392
|
+
errors: _formState.errors,
|
|
1393
|
+
isValid: false,
|
|
1394
|
+
});
|
|
1395
|
+
};
|
|
1396
|
+
const updateValidAndValue = (name, shouldSkipSetValueAs, value, ref) => {
|
|
1397
|
+
const field = get(_fields, name);
|
|
1398
|
+
if (field) {
|
|
1399
|
+
const defaultValue = get(_formValues, name, isUndefined(value) ? get(_defaultValues, name) : value);
|
|
1400
|
+
isUndefined(defaultValue) ||
|
|
1401
|
+
(ref && ref.defaultChecked) ||
|
|
1402
|
+
shouldSkipSetValueAs
|
|
1403
|
+
? set(_formValues, name, shouldSkipSetValueAs ? defaultValue : getFieldValue(field._f))
|
|
1404
|
+
: setFieldValue(name, defaultValue);
|
|
1405
|
+
_state.mount && !_state.action && _setValid();
|
|
1406
|
+
}
|
|
1407
|
+
};
|
|
1408
|
+
const updateTouchAndDirty = (name, fieldValue, isBlurEvent, shouldDirty, shouldRender) => {
|
|
1409
|
+
let shouldUpdateField = false;
|
|
1410
|
+
let isPreviousDirty = false;
|
|
1411
|
+
const output = {
|
|
1412
|
+
name,
|
|
1413
|
+
};
|
|
1414
|
+
if (!_options.disabled) {
|
|
1415
|
+
if (!isBlurEvent || shouldDirty) {
|
|
1416
|
+
if (_proxyFormState.isDirty || _proxySubscribeFormState.isDirty) {
|
|
1417
|
+
isPreviousDirty = _formState.isDirty;
|
|
1418
|
+
_formState.isDirty = output.isDirty = _getDirty();
|
|
1419
|
+
shouldUpdateField = isPreviousDirty !== output.isDirty;
|
|
1420
|
+
}
|
|
1421
|
+
const isCurrentFieldPristine = deepEqual(get(_defaultValues, name), fieldValue);
|
|
1422
|
+
isPreviousDirty = !!get(_formState.dirtyFields, name);
|
|
1423
|
+
isCurrentFieldPristine
|
|
1424
|
+
? unset(_formState.dirtyFields, name)
|
|
1425
|
+
: set(_formState.dirtyFields, name, true);
|
|
1426
|
+
output.dirtyFields = _formState.dirtyFields;
|
|
1427
|
+
shouldUpdateField =
|
|
1428
|
+
shouldUpdateField ||
|
|
1429
|
+
((_proxyFormState.dirtyFields ||
|
|
1430
|
+
_proxySubscribeFormState.dirtyFields) &&
|
|
1431
|
+
isPreviousDirty !== !isCurrentFieldPristine);
|
|
1432
|
+
}
|
|
1433
|
+
if (isBlurEvent) {
|
|
1434
|
+
const isPreviousFieldTouched = get(_formState.touchedFields, name);
|
|
1435
|
+
if (!isPreviousFieldTouched) {
|
|
1436
|
+
set(_formState.touchedFields, name, isBlurEvent);
|
|
1437
|
+
output.touchedFields = _formState.touchedFields;
|
|
1438
|
+
shouldUpdateField =
|
|
1439
|
+
shouldUpdateField ||
|
|
1440
|
+
((_proxyFormState.touchedFields ||
|
|
1441
|
+
_proxySubscribeFormState.touchedFields) &&
|
|
1442
|
+
isPreviousFieldTouched !== isBlurEvent);
|
|
1443
|
+
}
|
|
1444
|
+
}
|
|
1445
|
+
shouldUpdateField && shouldRender && _subjects.state.next(output);
|
|
1446
|
+
}
|
|
1447
|
+
return shouldUpdateField ? output : {};
|
|
1448
|
+
};
|
|
1449
|
+
const shouldRenderByError = (name, isValid, error, fieldState) => {
|
|
1450
|
+
const previousFieldError = get(_formState.errors, name);
|
|
1451
|
+
const shouldUpdateValid = (_proxyFormState.isValid || _proxySubscribeFormState.isValid) &&
|
|
1452
|
+
isBoolean(isValid) &&
|
|
1453
|
+
_formState.isValid !== isValid;
|
|
1454
|
+
if (_options.delayError && error) {
|
|
1455
|
+
delayErrorCallback = debounce(() => updateErrors(name, error));
|
|
1456
|
+
delayErrorCallback(_options.delayError);
|
|
1457
|
+
}
|
|
1458
|
+
else {
|
|
1459
|
+
clearTimeout(timer);
|
|
1460
|
+
delayErrorCallback = null;
|
|
1461
|
+
error
|
|
1462
|
+
? set(_formState.errors, name, error)
|
|
1463
|
+
: unset(_formState.errors, name);
|
|
1464
|
+
}
|
|
1465
|
+
if ((error ? !deepEqual(previousFieldError, error) : previousFieldError) ||
|
|
1466
|
+
!isEmptyObject(fieldState) ||
|
|
1467
|
+
shouldUpdateValid) {
|
|
1468
|
+
const updatedFormState = {
|
|
1469
|
+
...fieldState,
|
|
1470
|
+
...(shouldUpdateValid && isBoolean(isValid) ? { isValid } : {}),
|
|
1471
|
+
errors: _formState.errors,
|
|
1472
|
+
name,
|
|
1473
|
+
};
|
|
1474
|
+
_formState = {
|
|
1475
|
+
..._formState,
|
|
1476
|
+
...updatedFormState,
|
|
1477
|
+
};
|
|
1478
|
+
_subjects.state.next(updatedFormState);
|
|
1479
|
+
}
|
|
1480
|
+
};
|
|
1481
|
+
const _runSchema = async (name) => {
|
|
1482
|
+
_updateIsValidating(name, true);
|
|
1483
|
+
const result = await _options.resolver(_formValues, _options.context, getResolverOptions(name || _names.mount, _fields, _options.criteriaMode, _options.shouldUseNativeValidation));
|
|
1484
|
+
return result;
|
|
1485
|
+
};
|
|
1486
|
+
const executeSchemaAndUpdateState = async (names) => {
|
|
1487
|
+
const { errors } = await _runSchema(names);
|
|
1488
|
+
_updateIsValidating(names);
|
|
1489
|
+
if (names) {
|
|
1490
|
+
for (const name of names) {
|
|
1491
|
+
const error = get(errors, name);
|
|
1492
|
+
error
|
|
1493
|
+
? set(_formState.errors, name, error)
|
|
1494
|
+
: unset(_formState.errors, name);
|
|
1495
|
+
}
|
|
1496
|
+
}
|
|
1497
|
+
else {
|
|
1498
|
+
_formState.errors = errors;
|
|
1499
|
+
}
|
|
1500
|
+
return errors;
|
|
1501
|
+
};
|
|
1502
|
+
const executeBuiltInValidation = async (fields, shouldOnlyCheckValid, context = {
|
|
1503
|
+
valid: true,
|
|
1504
|
+
}) => {
|
|
1505
|
+
for (const name in fields) {
|
|
1506
|
+
const field = fields[name];
|
|
1507
|
+
if (field) {
|
|
1508
|
+
const { _f, ...fieldValue } = field;
|
|
1509
|
+
if (_f) {
|
|
1510
|
+
const isFieldArrayRoot = _names.array.has(_f.name);
|
|
1511
|
+
const isPromiseFunction = field._f && hasPromiseValidation(field._f);
|
|
1512
|
+
if (isPromiseFunction && _proxyFormState.validatingFields) {
|
|
1513
|
+
_updateIsValidating([_f.name], true);
|
|
1514
|
+
}
|
|
1515
|
+
const fieldError = await validateField(field, _names.disabled, _formValues, shouldDisplayAllAssociatedErrors, _options.shouldUseNativeValidation && !shouldOnlyCheckValid, isFieldArrayRoot);
|
|
1516
|
+
if (isPromiseFunction && _proxyFormState.validatingFields) {
|
|
1517
|
+
_updateIsValidating([_f.name]);
|
|
1518
|
+
}
|
|
1519
|
+
if (fieldError[_f.name]) {
|
|
1520
|
+
context.valid = false;
|
|
1521
|
+
if (shouldOnlyCheckValid || props.shouldUseNativeValidation) {
|
|
1522
|
+
break;
|
|
1523
|
+
}
|
|
1524
|
+
}
|
|
1525
|
+
!shouldOnlyCheckValid &&
|
|
1526
|
+
(get(fieldError, _f.name)
|
|
1527
|
+
? isFieldArrayRoot
|
|
1528
|
+
? updateFieldArrayRootError(_formState.errors, fieldError, _f.name)
|
|
1529
|
+
: set(_formState.errors, _f.name, fieldError[_f.name])
|
|
1530
|
+
: unset(_formState.errors, _f.name));
|
|
1531
|
+
}
|
|
1532
|
+
!isEmptyObject(fieldValue) &&
|
|
1533
|
+
(await executeBuiltInValidation(fieldValue, shouldOnlyCheckValid, context));
|
|
1534
|
+
}
|
|
1535
|
+
}
|
|
1536
|
+
return context.valid;
|
|
1537
|
+
};
|
|
1538
|
+
const _removeUnmounted = () => {
|
|
1539
|
+
for (const name of _names.unMount) {
|
|
1540
|
+
const field = get(_fields, name);
|
|
1541
|
+
field &&
|
|
1542
|
+
(field._f.refs
|
|
1543
|
+
? field._f.refs.every((ref) => !live(ref))
|
|
1544
|
+
: !live(field._f.ref)) &&
|
|
1545
|
+
unregister(name);
|
|
1546
|
+
}
|
|
1547
|
+
_names.unMount = new Set();
|
|
1548
|
+
};
|
|
1549
|
+
const _getDirty = (name, data) => !_options.disabled &&
|
|
1550
|
+
(name && data && set(_formValues, name, data),
|
|
1551
|
+
!deepEqual(getValues(), _defaultValues));
|
|
1552
|
+
const _getWatch = (names, defaultValue, isGlobal) => generateWatchOutput(names, _names, {
|
|
1553
|
+
...(_state.mount
|
|
1554
|
+
? _formValues
|
|
1555
|
+
: isUndefined(defaultValue)
|
|
1556
|
+
? _defaultValues
|
|
1557
|
+
: isString(names)
|
|
1558
|
+
? { [names]: defaultValue }
|
|
1559
|
+
: defaultValue),
|
|
1560
|
+
}, isGlobal, defaultValue);
|
|
1561
|
+
const _getFieldArray = (name) => compact(get(_state.mount ? _formValues : _defaultValues, name, _options.shouldUnregister ? get(_defaultValues, name, []) : []));
|
|
1562
|
+
const setFieldValue = (name, value, options = {}) => {
|
|
1563
|
+
const field = get(_fields, name);
|
|
1564
|
+
let fieldValue = value;
|
|
1565
|
+
if (field) {
|
|
1566
|
+
const fieldReference = field._f;
|
|
1567
|
+
if (fieldReference) {
|
|
1568
|
+
!fieldReference.disabled &&
|
|
1569
|
+
set(_formValues, name, getFieldValueAs(value, fieldReference));
|
|
1570
|
+
fieldValue =
|
|
1571
|
+
isHTMLElement(fieldReference.ref) && isNullOrUndefined(value)
|
|
1572
|
+
? ''
|
|
1573
|
+
: value;
|
|
1574
|
+
if (isMultipleSelect(fieldReference.ref)) {
|
|
1575
|
+
[...fieldReference.ref.options].forEach((optionRef) => (optionRef.selected = fieldValue.includes(optionRef.value)));
|
|
1576
|
+
}
|
|
1577
|
+
else if (fieldReference.refs) {
|
|
1578
|
+
if (isCheckBoxInput(fieldReference.ref)) {
|
|
1579
|
+
fieldReference.refs.forEach((checkboxRef) => {
|
|
1580
|
+
if (!checkboxRef.defaultChecked || !checkboxRef.disabled) {
|
|
1581
|
+
if (Array.isArray(fieldValue)) {
|
|
1582
|
+
checkboxRef.checked = !!fieldValue.find((data) => data === checkboxRef.value);
|
|
1583
|
+
}
|
|
1584
|
+
else {
|
|
1585
|
+
checkboxRef.checked =
|
|
1586
|
+
fieldValue === checkboxRef.value || !!fieldValue;
|
|
1587
|
+
}
|
|
1588
|
+
}
|
|
1589
|
+
});
|
|
1590
|
+
}
|
|
1591
|
+
else {
|
|
1592
|
+
fieldReference.refs.forEach((radioRef) => (radioRef.checked = radioRef.value === fieldValue));
|
|
1593
|
+
}
|
|
1594
|
+
}
|
|
1595
|
+
else if (isFileInput(fieldReference.ref)) {
|
|
1596
|
+
fieldReference.ref.value = '';
|
|
1597
|
+
}
|
|
1598
|
+
else {
|
|
1599
|
+
fieldReference.ref.value = fieldValue;
|
|
1600
|
+
if (!fieldReference.ref.type) {
|
|
1601
|
+
_subjects.state.next({
|
|
1602
|
+
name,
|
|
1603
|
+
values: cloneObject(_formValues),
|
|
1604
|
+
});
|
|
1605
|
+
}
|
|
1606
|
+
}
|
|
1607
|
+
}
|
|
1608
|
+
}
|
|
1609
|
+
(options.shouldDirty || options.shouldTouch) &&
|
|
1610
|
+
updateTouchAndDirty(name, fieldValue, options.shouldTouch, options.shouldDirty, true);
|
|
1611
|
+
options.shouldValidate && trigger(name);
|
|
1612
|
+
};
|
|
1613
|
+
const setValues = (name, value, options) => {
|
|
1614
|
+
for (const fieldKey in value) {
|
|
1615
|
+
if (!value.hasOwnProperty(fieldKey)) {
|
|
1616
|
+
return;
|
|
1617
|
+
}
|
|
1618
|
+
const fieldValue = value[fieldKey];
|
|
1619
|
+
const fieldName = name + '.' + fieldKey;
|
|
1620
|
+
const field = get(_fields, fieldName);
|
|
1621
|
+
(_names.array.has(name) ||
|
|
1622
|
+
isObject(fieldValue) ||
|
|
1623
|
+
(field && !field._f)) &&
|
|
1624
|
+
!isDateObject(fieldValue)
|
|
1625
|
+
? setValues(fieldName, fieldValue, options)
|
|
1626
|
+
: setFieldValue(fieldName, fieldValue, options);
|
|
1627
|
+
}
|
|
1628
|
+
};
|
|
1629
|
+
const setValue = (name, value, options = {}) => {
|
|
1630
|
+
const field = get(_fields, name);
|
|
1631
|
+
const isFieldArray = _names.array.has(name);
|
|
1632
|
+
const cloneValue = cloneObject(value);
|
|
1633
|
+
set(_formValues, name, cloneValue);
|
|
1634
|
+
if (isFieldArray) {
|
|
1635
|
+
_subjects.array.next({
|
|
1636
|
+
name,
|
|
1637
|
+
values: cloneObject(_formValues),
|
|
1638
|
+
});
|
|
1639
|
+
if ((_proxyFormState.isDirty ||
|
|
1640
|
+
_proxyFormState.dirtyFields ||
|
|
1641
|
+
_proxySubscribeFormState.isDirty ||
|
|
1642
|
+
_proxySubscribeFormState.dirtyFields) &&
|
|
1643
|
+
options.shouldDirty) {
|
|
1644
|
+
_subjects.state.next({
|
|
1645
|
+
name,
|
|
1646
|
+
dirtyFields: getDirtyFields(_defaultValues, _formValues),
|
|
1647
|
+
isDirty: _getDirty(name, cloneValue),
|
|
1648
|
+
});
|
|
1649
|
+
}
|
|
1650
|
+
}
|
|
1651
|
+
else {
|
|
1652
|
+
field && !field._f && !isNullOrUndefined(cloneValue)
|
|
1653
|
+
? setValues(name, cloneValue, options)
|
|
1654
|
+
: setFieldValue(name, cloneValue, options);
|
|
1655
|
+
}
|
|
1656
|
+
if (isWatched(name, _names)) {
|
|
1657
|
+
_subjects.state.next({
|
|
1658
|
+
..._formState,
|
|
1659
|
+
name,
|
|
1660
|
+
values: cloneObject(_formValues),
|
|
1661
|
+
});
|
|
1662
|
+
}
|
|
1663
|
+
else {
|
|
1664
|
+
_subjects.state.next({
|
|
1665
|
+
name: _state.mount ? name : undefined,
|
|
1666
|
+
values: cloneObject(_formValues),
|
|
1667
|
+
});
|
|
1668
|
+
}
|
|
1669
|
+
};
|
|
1670
|
+
const onChange = async (event) => {
|
|
1671
|
+
_state.mount = true;
|
|
1672
|
+
const target = event.target;
|
|
1673
|
+
let name = target.name;
|
|
1674
|
+
let isFieldValueUpdated = true;
|
|
1675
|
+
const field = get(_fields, name);
|
|
1676
|
+
const _updateIsFieldValueUpdated = (fieldValue) => {
|
|
1677
|
+
isFieldValueUpdated =
|
|
1678
|
+
Number.isNaN(fieldValue) ||
|
|
1679
|
+
(isDateObject(fieldValue) && isNaN(fieldValue.getTime())) ||
|
|
1680
|
+
deepEqual(fieldValue, get(_formValues, name, fieldValue));
|
|
1681
|
+
};
|
|
1682
|
+
const validationModeBeforeSubmit = getValidationModes(_options.mode);
|
|
1683
|
+
const validationModeAfterSubmit = getValidationModes(_options.reValidateMode);
|
|
1684
|
+
if (field) {
|
|
1685
|
+
let error;
|
|
1686
|
+
let isValid;
|
|
1687
|
+
const fieldValue = target.type
|
|
1688
|
+
? getFieldValue(field._f)
|
|
1689
|
+
: getEventValue(event);
|
|
1690
|
+
const isBlurEvent = event.type === EVENTS.BLUR || event.type === EVENTS.FOCUS_OUT;
|
|
1691
|
+
const shouldSkipValidation = (!hasValidation(field._f) &&
|
|
1692
|
+
!_options.resolver &&
|
|
1693
|
+
!get(_formState.errors, name) &&
|
|
1694
|
+
!field._f.deps) ||
|
|
1695
|
+
skipValidation(isBlurEvent, get(_formState.touchedFields, name), _formState.isSubmitted, validationModeAfterSubmit, validationModeBeforeSubmit);
|
|
1696
|
+
const watched = isWatched(name, _names, isBlurEvent);
|
|
1697
|
+
set(_formValues, name, fieldValue);
|
|
1698
|
+
if (isBlurEvent) {
|
|
1699
|
+
if (!target || !target.readOnly) {
|
|
1700
|
+
field._f.onBlur && field._f.onBlur(event);
|
|
1701
|
+
delayErrorCallback && delayErrorCallback(0);
|
|
1702
|
+
}
|
|
1703
|
+
}
|
|
1704
|
+
else if (field._f.onChange) {
|
|
1705
|
+
field._f.onChange(event);
|
|
1706
|
+
}
|
|
1707
|
+
const fieldState = updateTouchAndDirty(name, fieldValue, isBlurEvent);
|
|
1708
|
+
const shouldRender = !isEmptyObject(fieldState) || watched;
|
|
1709
|
+
!isBlurEvent &&
|
|
1710
|
+
_subjects.state.next({
|
|
1711
|
+
name,
|
|
1712
|
+
type: event.type,
|
|
1713
|
+
values: cloneObject(_formValues),
|
|
1714
|
+
});
|
|
1715
|
+
if (shouldSkipValidation) {
|
|
1716
|
+
if (_proxyFormState.isValid || _proxySubscribeFormState.isValid) {
|
|
1717
|
+
if (_options.mode === 'onBlur') {
|
|
1718
|
+
if (isBlurEvent) {
|
|
1719
|
+
_setValid();
|
|
1720
|
+
}
|
|
1721
|
+
}
|
|
1722
|
+
else if (!isBlurEvent) {
|
|
1723
|
+
_setValid();
|
|
1724
|
+
}
|
|
1725
|
+
}
|
|
1726
|
+
return (shouldRender &&
|
|
1727
|
+
_subjects.state.next({ name, ...(watched ? {} : fieldState) }));
|
|
1728
|
+
}
|
|
1729
|
+
!isBlurEvent && watched && _subjects.state.next({ ..._formState });
|
|
1730
|
+
if (_options.resolver) {
|
|
1731
|
+
const { errors } = await _runSchema([name]);
|
|
1732
|
+
_updateIsValidating([name]);
|
|
1733
|
+
_updateIsFieldValueUpdated(fieldValue);
|
|
1734
|
+
if (isFieldValueUpdated) {
|
|
1735
|
+
const previousErrorLookupResult = schemaErrorLookup(_formState.errors, _fields, name);
|
|
1736
|
+
const errorLookupResult = schemaErrorLookup(errors, _fields, previousErrorLookupResult.name || name);
|
|
1737
|
+
error = errorLookupResult.error;
|
|
1738
|
+
name = errorLookupResult.name;
|
|
1739
|
+
isValid = isEmptyObject(errors);
|
|
1740
|
+
}
|
|
1741
|
+
}
|
|
1742
|
+
else {
|
|
1743
|
+
_updateIsValidating([name], true);
|
|
1744
|
+
error = (await validateField(field, _names.disabled, _formValues, shouldDisplayAllAssociatedErrors, _options.shouldUseNativeValidation))[name];
|
|
1745
|
+
_updateIsValidating([name]);
|
|
1746
|
+
_updateIsFieldValueUpdated(fieldValue);
|
|
1747
|
+
if (isFieldValueUpdated) {
|
|
1748
|
+
if (error) {
|
|
1749
|
+
isValid = false;
|
|
1750
|
+
}
|
|
1751
|
+
else if (_proxyFormState.isValid ||
|
|
1752
|
+
_proxySubscribeFormState.isValid) {
|
|
1753
|
+
isValid = await executeBuiltInValidation(_fields, true);
|
|
1754
|
+
}
|
|
1755
|
+
}
|
|
1756
|
+
}
|
|
1757
|
+
if (isFieldValueUpdated) {
|
|
1758
|
+
field._f.deps &&
|
|
1759
|
+
(!Array.isArray(field._f.deps) || field._f.deps.length > 0) &&
|
|
1760
|
+
trigger(field._f.deps);
|
|
1761
|
+
shouldRenderByError(name, isValid, error, fieldState);
|
|
1762
|
+
}
|
|
1763
|
+
}
|
|
1764
|
+
};
|
|
1765
|
+
const _focusInput = (ref, key) => {
|
|
1766
|
+
if (get(_formState.errors, key) && ref.focus) {
|
|
1767
|
+
ref.focus();
|
|
1768
|
+
return 1;
|
|
1769
|
+
}
|
|
1770
|
+
return;
|
|
1771
|
+
};
|
|
1772
|
+
const trigger = async (name, options = {}) => {
|
|
1773
|
+
let isValid;
|
|
1774
|
+
let validationResult;
|
|
1775
|
+
const fieldNames = convertToArrayPayload(name);
|
|
1776
|
+
if (_options.resolver) {
|
|
1777
|
+
const errors = await executeSchemaAndUpdateState(isUndefined(name) ? name : fieldNames);
|
|
1778
|
+
isValid = isEmptyObject(errors);
|
|
1779
|
+
validationResult = name
|
|
1780
|
+
? !fieldNames.some((name) => get(errors, name))
|
|
1781
|
+
: isValid;
|
|
1782
|
+
}
|
|
1783
|
+
else if (name) {
|
|
1784
|
+
validationResult = (await Promise.all(fieldNames.map(async (fieldName) => {
|
|
1785
|
+
const field = get(_fields, fieldName);
|
|
1786
|
+
return await executeBuiltInValidation(field && field._f ? { [fieldName]: field } : field);
|
|
1787
|
+
}))).every(Boolean);
|
|
1788
|
+
!(!validationResult && !_formState.isValid) && _setValid();
|
|
1789
|
+
}
|
|
1790
|
+
else {
|
|
1791
|
+
validationResult = isValid = await executeBuiltInValidation(_fields);
|
|
1792
|
+
}
|
|
1793
|
+
_subjects.state.next({
|
|
1794
|
+
...(!isString(name) ||
|
|
1795
|
+
((_proxyFormState.isValid || _proxySubscribeFormState.isValid) &&
|
|
1796
|
+
isValid !== _formState.isValid)
|
|
1797
|
+
? {}
|
|
1798
|
+
: { name }),
|
|
1799
|
+
...(_options.resolver || !name ? { isValid } : {}),
|
|
1800
|
+
errors: _formState.errors,
|
|
1801
|
+
});
|
|
1802
|
+
options.shouldFocus &&
|
|
1803
|
+
!validationResult &&
|
|
1804
|
+
iterateFieldsByAction(_fields, _focusInput, name ? fieldNames : _names.mount);
|
|
1805
|
+
return validationResult;
|
|
1806
|
+
};
|
|
1807
|
+
const getValues = (fieldNames, config) => {
|
|
1808
|
+
let values = {
|
|
1809
|
+
...(_state.mount ? _formValues : _defaultValues),
|
|
1810
|
+
};
|
|
1811
|
+
if (config) {
|
|
1812
|
+
values = extractFormValues(config.dirtyFields ? _formState.dirtyFields : _formState.touchedFields, values);
|
|
1813
|
+
}
|
|
1814
|
+
return isUndefined(fieldNames)
|
|
1815
|
+
? values
|
|
1816
|
+
: isString(fieldNames)
|
|
1817
|
+
? get(values, fieldNames)
|
|
1818
|
+
: fieldNames.map((name) => get(values, name));
|
|
1819
|
+
};
|
|
1820
|
+
const getFieldState = (name, formState) => ({
|
|
1821
|
+
invalid: !!get((formState || _formState).errors, name),
|
|
1822
|
+
isDirty: !!get((formState || _formState).dirtyFields, name),
|
|
1823
|
+
error: get((formState || _formState).errors, name),
|
|
1824
|
+
isValidating: !!get(_formState.validatingFields, name),
|
|
1825
|
+
isTouched: !!get((formState || _formState).touchedFields, name),
|
|
1826
|
+
});
|
|
1827
|
+
const clearErrors = (name) => {
|
|
1828
|
+
const names = name ? convertToArrayPayload(name) : undefined;
|
|
1829
|
+
names === null || names === void 0 ? void 0 : names.forEach((inputName) => unset(_formState.errors, inputName));
|
|
1830
|
+
if (names) {
|
|
1831
|
+
// Emit for each cleared field with the field name so that
|
|
1832
|
+
// shouldSubscribeByName can filter and avoid broad re-renders
|
|
1833
|
+
names.forEach((inputName) => {
|
|
1834
|
+
_subjects.state.next({
|
|
1835
|
+
name: inputName,
|
|
1836
|
+
errors: _formState.errors,
|
|
1837
|
+
});
|
|
1838
|
+
});
|
|
1839
|
+
}
|
|
1840
|
+
else {
|
|
1841
|
+
// Clear all errors - emit without name to notify all subscribers
|
|
1842
|
+
_subjects.state.next({
|
|
1843
|
+
errors: {},
|
|
1844
|
+
});
|
|
1845
|
+
}
|
|
1846
|
+
};
|
|
1847
|
+
const setError = (name, error, options) => {
|
|
1848
|
+
const ref = (get(_fields, name, { _f: {} })._f || {}).ref;
|
|
1849
|
+
const currentError = get(_formState.errors, name) || {};
|
|
1850
|
+
// Don't override existing error messages elsewhere in the object tree.
|
|
1851
|
+
const { ref: currentRef, message, type, ...restOfErrorTree } = currentError;
|
|
1852
|
+
set(_formState.errors, name, {
|
|
1853
|
+
...restOfErrorTree,
|
|
1854
|
+
...error,
|
|
1855
|
+
ref,
|
|
1856
|
+
});
|
|
1857
|
+
_subjects.state.next({
|
|
1858
|
+
name,
|
|
1859
|
+
errors: _formState.errors,
|
|
1860
|
+
isValid: false,
|
|
1861
|
+
});
|
|
1862
|
+
options && options.shouldFocus && ref && ref.focus && ref.focus();
|
|
1863
|
+
};
|
|
1864
|
+
const watch = (name, defaultValue) => isFunction(name)
|
|
1865
|
+
? _subjects.state.subscribe({
|
|
1866
|
+
next: (payload) => 'values' in payload &&
|
|
1867
|
+
name(_getWatch(undefined, defaultValue), payload),
|
|
1868
|
+
})
|
|
1869
|
+
: _getWatch(name, defaultValue, true);
|
|
1870
|
+
const _subscribe = (props) => _subjects.state.subscribe({
|
|
1871
|
+
next: (formState) => {
|
|
1872
|
+
if (shouldSubscribeByName(props.name, formState.name, props.exact) &&
|
|
1873
|
+
shouldRenderFormState(formState, props.formState || _proxyFormState, _setFormState, props.reRenderRoot)) {
|
|
1874
|
+
props.callback({
|
|
1875
|
+
values: { ..._formValues },
|
|
1876
|
+
..._formState,
|
|
1877
|
+
...formState,
|
|
1878
|
+
defaultValues: _defaultValues,
|
|
1879
|
+
});
|
|
1880
|
+
}
|
|
1881
|
+
},
|
|
1882
|
+
}).unsubscribe;
|
|
1883
|
+
const subscribe = (props) => {
|
|
1884
|
+
_state.mount = true;
|
|
1885
|
+
_proxySubscribeFormState = {
|
|
1886
|
+
..._proxySubscribeFormState,
|
|
1887
|
+
...props.formState,
|
|
1888
|
+
};
|
|
1889
|
+
return _subscribe({
|
|
1890
|
+
...props,
|
|
1891
|
+
formState: {
|
|
1892
|
+
...defaultProxyFormState,
|
|
1893
|
+
...props.formState,
|
|
1894
|
+
},
|
|
1895
|
+
});
|
|
1896
|
+
};
|
|
1897
|
+
const unregister = (name, options = {}) => {
|
|
1898
|
+
for (const fieldName of name ? convertToArrayPayload(name) : _names.mount) {
|
|
1899
|
+
_names.mount.delete(fieldName);
|
|
1900
|
+
_names.array.delete(fieldName);
|
|
1901
|
+
if (!options.keepValue) {
|
|
1902
|
+
unset(_fields, fieldName);
|
|
1903
|
+
unset(_formValues, fieldName);
|
|
1904
|
+
}
|
|
1905
|
+
!options.keepError && unset(_formState.errors, fieldName);
|
|
1906
|
+
!options.keepDirty && unset(_formState.dirtyFields, fieldName);
|
|
1907
|
+
!options.keepTouched && unset(_formState.touchedFields, fieldName);
|
|
1908
|
+
!options.keepIsValidating &&
|
|
1909
|
+
unset(_formState.validatingFields, fieldName);
|
|
1910
|
+
!_options.shouldUnregister &&
|
|
1911
|
+
!options.keepDefaultValue &&
|
|
1912
|
+
unset(_defaultValues, fieldName);
|
|
1913
|
+
}
|
|
1914
|
+
_subjects.state.next({
|
|
1915
|
+
values: cloneObject(_formValues),
|
|
1916
|
+
});
|
|
1917
|
+
_subjects.state.next({
|
|
1918
|
+
..._formState,
|
|
1919
|
+
...(!options.keepDirty ? {} : { isDirty: _getDirty() }),
|
|
1920
|
+
});
|
|
1921
|
+
!options.keepIsValid && _setValid();
|
|
1922
|
+
};
|
|
1923
|
+
const _setDisabledField = ({ disabled, name, }) => {
|
|
1924
|
+
if ((isBoolean(disabled) && _state.mount) ||
|
|
1925
|
+
!!disabled ||
|
|
1926
|
+
_names.disabled.has(name)) {
|
|
1927
|
+
const wasDisabled = _names.disabled.has(name);
|
|
1928
|
+
const isDisabled = !!disabled;
|
|
1929
|
+
const disabledStateChanged = wasDisabled !== isDisabled;
|
|
1930
|
+
disabled ? _names.disabled.add(name) : _names.disabled.delete(name);
|
|
1931
|
+
disabledStateChanged && _state.mount && !_state.action && _setValid();
|
|
1932
|
+
}
|
|
1933
|
+
};
|
|
1934
|
+
const register = (name, options = {}) => {
|
|
1935
|
+
let field = get(_fields, name);
|
|
1936
|
+
const disabledIsDefined = isBoolean(options.disabled) || isBoolean(_options.disabled);
|
|
1937
|
+
set(_fields, name, {
|
|
1938
|
+
...(field || {}),
|
|
1939
|
+
_f: {
|
|
1940
|
+
...(field && field._f ? field._f : { ref: { name } }),
|
|
1941
|
+
name,
|
|
1942
|
+
mount: true,
|
|
1943
|
+
...options,
|
|
1944
|
+
},
|
|
1945
|
+
});
|
|
1946
|
+
_names.mount.add(name);
|
|
1947
|
+
if (field) {
|
|
1948
|
+
_setDisabledField({
|
|
1949
|
+
disabled: isBoolean(options.disabled)
|
|
1950
|
+
? options.disabled
|
|
1951
|
+
: _options.disabled,
|
|
1952
|
+
name,
|
|
1953
|
+
});
|
|
1954
|
+
}
|
|
1955
|
+
else {
|
|
1956
|
+
updateValidAndValue(name, true, options.value);
|
|
1957
|
+
}
|
|
1958
|
+
return {
|
|
1959
|
+
...(disabledIsDefined
|
|
1960
|
+
? { disabled: options.disabled || _options.disabled }
|
|
1961
|
+
: {}),
|
|
1962
|
+
...(_options.progressive
|
|
1963
|
+
? {
|
|
1964
|
+
required: !!options.required,
|
|
1965
|
+
min: getRuleValue(options.min),
|
|
1966
|
+
max: getRuleValue(options.max),
|
|
1967
|
+
minLength: getRuleValue(options.minLength),
|
|
1968
|
+
maxLength: getRuleValue(options.maxLength),
|
|
1969
|
+
pattern: getRuleValue(options.pattern),
|
|
1970
|
+
}
|
|
1971
|
+
: {}),
|
|
1972
|
+
name,
|
|
1973
|
+
onChange,
|
|
1974
|
+
onBlur: onChange,
|
|
1975
|
+
ref: (ref) => {
|
|
1976
|
+
if (ref) {
|
|
1977
|
+
register(name, options);
|
|
1978
|
+
field = get(_fields, name);
|
|
1979
|
+
const fieldRef = isUndefined(ref.value)
|
|
1980
|
+
? ref.querySelectorAll
|
|
1981
|
+
? ref.querySelectorAll('input,select,textarea')[0] || ref
|
|
1982
|
+
: ref
|
|
1983
|
+
: ref;
|
|
1984
|
+
const radioOrCheckbox = isRadioOrCheckbox(fieldRef);
|
|
1985
|
+
const refs = field._f.refs || [];
|
|
1986
|
+
if (radioOrCheckbox
|
|
1987
|
+
? refs.find((option) => option === fieldRef)
|
|
1988
|
+
: fieldRef === field._f.ref) {
|
|
1989
|
+
return;
|
|
1990
|
+
}
|
|
1991
|
+
set(_fields, name, {
|
|
1992
|
+
_f: {
|
|
1993
|
+
...field._f,
|
|
1994
|
+
...(radioOrCheckbox
|
|
1995
|
+
? {
|
|
1996
|
+
refs: [
|
|
1997
|
+
...refs.filter(live),
|
|
1998
|
+
fieldRef,
|
|
1999
|
+
...(Array.isArray(get(_defaultValues, name)) ? [{}] : []),
|
|
2000
|
+
],
|
|
2001
|
+
ref: { type: fieldRef.type, name },
|
|
2002
|
+
}
|
|
2003
|
+
: { ref: fieldRef }),
|
|
2004
|
+
},
|
|
2005
|
+
});
|
|
2006
|
+
updateValidAndValue(name, false, undefined, fieldRef);
|
|
2007
|
+
}
|
|
2008
|
+
else {
|
|
2009
|
+
field = get(_fields, name, {});
|
|
2010
|
+
if (field._f) {
|
|
2011
|
+
field._f.mount = false;
|
|
2012
|
+
}
|
|
2013
|
+
(_options.shouldUnregister || options.shouldUnregister) &&
|
|
2014
|
+
!(isNameInFieldArray(_names.array, name) && _state.action) &&
|
|
2015
|
+
_names.unMount.add(name);
|
|
2016
|
+
}
|
|
2017
|
+
},
|
|
2018
|
+
};
|
|
2019
|
+
};
|
|
2020
|
+
const _focusError = () => _options.shouldFocusError &&
|
|
2021
|
+
iterateFieldsByAction(_fields, _focusInput, _names.mount);
|
|
2022
|
+
const _disableForm = (disabled) => {
|
|
2023
|
+
if (isBoolean(disabled)) {
|
|
2024
|
+
_subjects.state.next({ disabled });
|
|
2025
|
+
iterateFieldsByAction(_fields, (ref, name) => {
|
|
2026
|
+
const currentField = get(_fields, name);
|
|
2027
|
+
if (currentField) {
|
|
2028
|
+
ref.disabled = currentField._f.disabled || disabled;
|
|
2029
|
+
if (Array.isArray(currentField._f.refs)) {
|
|
2030
|
+
currentField._f.refs.forEach((inputRef) => {
|
|
2031
|
+
inputRef.disabled = currentField._f.disabled || disabled;
|
|
2032
|
+
});
|
|
2033
|
+
}
|
|
2034
|
+
}
|
|
2035
|
+
}, 0, false);
|
|
2036
|
+
}
|
|
2037
|
+
};
|
|
2038
|
+
const handleSubmit = (onValid, onInvalid) => async (e) => {
|
|
2039
|
+
let onValidError = undefined;
|
|
2040
|
+
if (e) {
|
|
2041
|
+
e.preventDefault && e.preventDefault();
|
|
2042
|
+
e.persist &&
|
|
2043
|
+
e.persist();
|
|
2044
|
+
}
|
|
2045
|
+
let fieldValues = cloneObject(_formValues);
|
|
2046
|
+
_subjects.state.next({
|
|
2047
|
+
isSubmitting: true,
|
|
2048
|
+
});
|
|
2049
|
+
if (_options.resolver) {
|
|
2050
|
+
const { errors, values } = await _runSchema();
|
|
2051
|
+
_updateIsValidating();
|
|
2052
|
+
_formState.errors = errors;
|
|
2053
|
+
fieldValues = cloneObject(values);
|
|
2054
|
+
}
|
|
2055
|
+
else {
|
|
2056
|
+
await executeBuiltInValidation(_fields);
|
|
2057
|
+
}
|
|
2058
|
+
if (_names.disabled.size) {
|
|
2059
|
+
for (const name of _names.disabled) {
|
|
2060
|
+
unset(fieldValues, name);
|
|
2061
|
+
}
|
|
2062
|
+
}
|
|
2063
|
+
unset(_formState.errors, 'root');
|
|
2064
|
+
if (isEmptyObject(_formState.errors)) {
|
|
2065
|
+
_subjects.state.next({
|
|
2066
|
+
errors: {},
|
|
2067
|
+
});
|
|
2068
|
+
try {
|
|
2069
|
+
await onValid(fieldValues, e);
|
|
2070
|
+
}
|
|
2071
|
+
catch (error) {
|
|
2072
|
+
onValidError = error;
|
|
2073
|
+
}
|
|
2074
|
+
}
|
|
2075
|
+
else {
|
|
2076
|
+
if (onInvalid) {
|
|
2077
|
+
await onInvalid({ ..._formState.errors }, e);
|
|
2078
|
+
}
|
|
2079
|
+
_focusError();
|
|
2080
|
+
setTimeout(_focusError);
|
|
2081
|
+
}
|
|
2082
|
+
_subjects.state.next({
|
|
2083
|
+
isSubmitted: true,
|
|
2084
|
+
isSubmitting: false,
|
|
2085
|
+
isSubmitSuccessful: isEmptyObject(_formState.errors) && !onValidError,
|
|
2086
|
+
submitCount: _formState.submitCount + 1,
|
|
2087
|
+
errors: _formState.errors,
|
|
2088
|
+
});
|
|
2089
|
+
if (onValidError) {
|
|
2090
|
+
throw onValidError;
|
|
2091
|
+
}
|
|
2092
|
+
};
|
|
2093
|
+
const resetField = (name, options = {}) => {
|
|
2094
|
+
if (get(_fields, name)) {
|
|
2095
|
+
if (isUndefined(options.defaultValue)) {
|
|
2096
|
+
setValue(name, cloneObject(get(_defaultValues, name)));
|
|
2097
|
+
}
|
|
2098
|
+
else {
|
|
2099
|
+
setValue(name, options.defaultValue);
|
|
2100
|
+
set(_defaultValues, name, cloneObject(options.defaultValue));
|
|
2101
|
+
}
|
|
2102
|
+
if (!options.keepTouched) {
|
|
2103
|
+
unset(_formState.touchedFields, name);
|
|
2104
|
+
}
|
|
2105
|
+
if (!options.keepDirty) {
|
|
2106
|
+
unset(_formState.dirtyFields, name);
|
|
2107
|
+
_formState.isDirty = options.defaultValue
|
|
2108
|
+
? _getDirty(name, cloneObject(get(_defaultValues, name)))
|
|
2109
|
+
: _getDirty();
|
|
2110
|
+
}
|
|
2111
|
+
if (!options.keepError) {
|
|
2112
|
+
unset(_formState.errors, name);
|
|
2113
|
+
_proxyFormState.isValid && _setValid();
|
|
2114
|
+
}
|
|
2115
|
+
_subjects.state.next({ ..._formState });
|
|
2116
|
+
}
|
|
2117
|
+
};
|
|
2118
|
+
const _reset = (formValues, keepStateOptions = {}) => {
|
|
2119
|
+
const updatedValues = formValues ? cloneObject(formValues) : _defaultValues;
|
|
2120
|
+
const cloneUpdatedValues = cloneObject(updatedValues);
|
|
2121
|
+
const isEmptyResetValues = isEmptyObject(formValues);
|
|
2122
|
+
const values = isEmptyResetValues ? _defaultValues : cloneUpdatedValues;
|
|
2123
|
+
if (!keepStateOptions.keepDefaultValues) {
|
|
2124
|
+
_defaultValues = updatedValues;
|
|
2125
|
+
}
|
|
2126
|
+
if (!keepStateOptions.keepValues) {
|
|
2127
|
+
if (keepStateOptions.keepDirtyValues) {
|
|
2128
|
+
const fieldsToCheck = new Set([
|
|
2129
|
+
..._names.mount,
|
|
2130
|
+
...Object.keys(getDirtyFields(_defaultValues, _formValues)),
|
|
2131
|
+
]);
|
|
2132
|
+
for (const fieldName of Array.from(fieldsToCheck)) {
|
|
2133
|
+
const isDirty = get(_formState.dirtyFields, fieldName);
|
|
2134
|
+
const existingValue = get(_formValues, fieldName);
|
|
2135
|
+
const newValue = get(values, fieldName);
|
|
2136
|
+
if (isDirty && !isUndefined(existingValue)) {
|
|
2137
|
+
set(values, fieldName, existingValue);
|
|
2138
|
+
}
|
|
2139
|
+
else if (!isDirty && !isUndefined(newValue)) {
|
|
2140
|
+
setValue(fieldName, newValue);
|
|
2141
|
+
}
|
|
2142
|
+
}
|
|
2143
|
+
}
|
|
2144
|
+
else {
|
|
2145
|
+
if (isWeb && isUndefined(formValues)) {
|
|
2146
|
+
for (const name of _names.mount) {
|
|
2147
|
+
const field = get(_fields, name);
|
|
2148
|
+
if (field && field._f) {
|
|
2149
|
+
const fieldReference = Array.isArray(field._f.refs)
|
|
2150
|
+
? field._f.refs[0]
|
|
2151
|
+
: field._f.ref;
|
|
2152
|
+
if (isHTMLElement(fieldReference)) {
|
|
2153
|
+
const form = fieldReference.closest('form');
|
|
2154
|
+
if (form) {
|
|
2155
|
+
form.reset();
|
|
2156
|
+
break;
|
|
2157
|
+
}
|
|
2158
|
+
}
|
|
2159
|
+
}
|
|
2160
|
+
}
|
|
2161
|
+
}
|
|
2162
|
+
if (keepStateOptions.keepFieldsRef) {
|
|
2163
|
+
for (const fieldName of _names.mount) {
|
|
2164
|
+
setValue(fieldName, get(values, fieldName));
|
|
2165
|
+
}
|
|
2166
|
+
}
|
|
2167
|
+
else {
|
|
2168
|
+
_fields = {};
|
|
2169
|
+
}
|
|
2170
|
+
}
|
|
2171
|
+
_formValues = _options.shouldUnregister
|
|
2172
|
+
? keepStateOptions.keepDefaultValues
|
|
2173
|
+
? cloneObject(_defaultValues)
|
|
2174
|
+
: {}
|
|
2175
|
+
: cloneObject(values);
|
|
2176
|
+
_subjects.array.next({
|
|
2177
|
+
values: { ...values },
|
|
2178
|
+
});
|
|
2179
|
+
_subjects.state.next({
|
|
2180
|
+
values: { ...values },
|
|
2181
|
+
});
|
|
2182
|
+
}
|
|
2183
|
+
_names = {
|
|
2184
|
+
mount: keepStateOptions.keepDirtyValues ? _names.mount : new Set(),
|
|
2185
|
+
unMount: new Set(),
|
|
2186
|
+
array: new Set(),
|
|
2187
|
+
disabled: new Set(),
|
|
2188
|
+
watch: new Set(),
|
|
2189
|
+
watchAll: false,
|
|
2190
|
+
focus: '',
|
|
2191
|
+
};
|
|
2192
|
+
_state.mount =
|
|
2193
|
+
!_proxyFormState.isValid ||
|
|
2194
|
+
!!keepStateOptions.keepIsValid ||
|
|
2195
|
+
!!keepStateOptions.keepDirtyValues ||
|
|
2196
|
+
(!_options.shouldUnregister && !isEmptyObject(values));
|
|
2197
|
+
_state.watch = !!_options.shouldUnregister;
|
|
2198
|
+
_state.keepIsValid = !!keepStateOptions.keepIsValid;
|
|
2199
|
+
_state.action = false;
|
|
2200
|
+
// Clear errors synchronously to prevent validation errors on subsequent submissions
|
|
2201
|
+
// This fixes the issue where form.reset() causes validation errors on subsequent
|
|
2202
|
+
// submissions in Next.js 16 with Server Actions
|
|
2203
|
+
if (!keepStateOptions.keepErrors) {
|
|
2204
|
+
_formState.errors = {};
|
|
2205
|
+
}
|
|
2206
|
+
_subjects.state.next({
|
|
2207
|
+
submitCount: keepStateOptions.keepSubmitCount
|
|
2208
|
+
? _formState.submitCount
|
|
2209
|
+
: 0,
|
|
2210
|
+
isDirty: isEmptyResetValues
|
|
2211
|
+
? false
|
|
2212
|
+
: keepStateOptions.keepDirty
|
|
2213
|
+
? _formState.isDirty
|
|
2214
|
+
: !!(keepStateOptions.keepDefaultValues &&
|
|
2215
|
+
!deepEqual(formValues, _defaultValues)),
|
|
2216
|
+
isSubmitted: keepStateOptions.keepIsSubmitted
|
|
2217
|
+
? _formState.isSubmitted
|
|
2218
|
+
: false,
|
|
2219
|
+
dirtyFields: isEmptyResetValues
|
|
2220
|
+
? {}
|
|
2221
|
+
: keepStateOptions.keepDirtyValues
|
|
2222
|
+
? keepStateOptions.keepDefaultValues && _formValues
|
|
2223
|
+
? getDirtyFields(_defaultValues, _formValues)
|
|
2224
|
+
: _formState.dirtyFields
|
|
2225
|
+
: keepStateOptions.keepDefaultValues && formValues
|
|
2226
|
+
? getDirtyFields(_defaultValues, formValues)
|
|
2227
|
+
: keepStateOptions.keepDirty
|
|
2228
|
+
? _formState.dirtyFields
|
|
2229
|
+
: {},
|
|
2230
|
+
touchedFields: keepStateOptions.keepTouched
|
|
2231
|
+
? _formState.touchedFields
|
|
2232
|
+
: {},
|
|
2233
|
+
errors: keepStateOptions.keepErrors ? _formState.errors : {},
|
|
2234
|
+
isSubmitSuccessful: keepStateOptions.keepIsSubmitSuccessful
|
|
2235
|
+
? _formState.isSubmitSuccessful
|
|
2236
|
+
: false,
|
|
2237
|
+
isSubmitting: false,
|
|
2238
|
+
defaultValues: _defaultValues,
|
|
2239
|
+
});
|
|
2240
|
+
};
|
|
2241
|
+
const reset = (formValues, keepStateOptions) => _reset(isFunction(formValues)
|
|
2242
|
+
? formValues(_formValues)
|
|
2243
|
+
: formValues, { ..._options.resetOptions, ...keepStateOptions });
|
|
2244
|
+
const setFocus = (name, options = {}) => {
|
|
2245
|
+
const field = get(_fields, name);
|
|
2246
|
+
const fieldReference = field && field._f;
|
|
2247
|
+
if (fieldReference) {
|
|
2248
|
+
const fieldRef = fieldReference.refs
|
|
2249
|
+
? fieldReference.refs[0]
|
|
2250
|
+
: fieldReference.ref;
|
|
2251
|
+
if (fieldRef.focus) {
|
|
2252
|
+
// Use setTimeout to ensure focus happens after any pending state updates
|
|
2253
|
+
// This fixes the issue where setFocus doesn't work immediately after setError
|
|
2254
|
+
setTimeout(() => {
|
|
2255
|
+
fieldRef.focus();
|
|
2256
|
+
options.shouldSelect &&
|
|
2257
|
+
isFunction(fieldRef.select) &&
|
|
2258
|
+
fieldRef.select();
|
|
2259
|
+
});
|
|
2260
|
+
}
|
|
2261
|
+
}
|
|
2262
|
+
};
|
|
2263
|
+
const _setFormState = (updatedFormState) => {
|
|
2264
|
+
_formState = {
|
|
2265
|
+
..._formState,
|
|
2266
|
+
...updatedFormState,
|
|
2267
|
+
};
|
|
2268
|
+
};
|
|
2269
|
+
const _resetDefaultValues = () => isFunction(_options.defaultValues) &&
|
|
2270
|
+
_options.defaultValues().then((values) => {
|
|
2271
|
+
reset(values, _options.resetOptions);
|
|
2272
|
+
_subjects.state.next({
|
|
2273
|
+
isLoading: false,
|
|
2274
|
+
});
|
|
2275
|
+
});
|
|
2276
|
+
const methods = {
|
|
2277
|
+
control: {
|
|
2278
|
+
register,
|
|
2279
|
+
unregister,
|
|
2280
|
+
getFieldState,
|
|
2281
|
+
handleSubmit,
|
|
2282
|
+
setError,
|
|
2283
|
+
_subscribe,
|
|
2284
|
+
_runSchema,
|
|
2285
|
+
_updateIsValidating,
|
|
2286
|
+
_focusError,
|
|
2287
|
+
_getWatch,
|
|
2288
|
+
_getDirty,
|
|
2289
|
+
_setValid,
|
|
2290
|
+
_setFieldArray,
|
|
2291
|
+
_setDisabledField,
|
|
2292
|
+
_setErrors,
|
|
2293
|
+
_getFieldArray,
|
|
2294
|
+
_reset,
|
|
2295
|
+
_resetDefaultValues,
|
|
2296
|
+
_removeUnmounted,
|
|
2297
|
+
_disableForm,
|
|
2298
|
+
_subjects,
|
|
2299
|
+
_proxyFormState,
|
|
2300
|
+
get _fields() {
|
|
2301
|
+
return _fields;
|
|
2302
|
+
},
|
|
2303
|
+
get _formValues() {
|
|
2304
|
+
return _formValues;
|
|
2305
|
+
},
|
|
2306
|
+
get _state() {
|
|
2307
|
+
return _state;
|
|
2308
|
+
},
|
|
2309
|
+
set _state(value) {
|
|
2310
|
+
_state = value;
|
|
2311
|
+
},
|
|
2312
|
+
get _defaultValues() {
|
|
2313
|
+
return _defaultValues;
|
|
2314
|
+
},
|
|
2315
|
+
get _names() {
|
|
2316
|
+
return _names;
|
|
2317
|
+
},
|
|
2318
|
+
set _names(value) {
|
|
2319
|
+
_names = value;
|
|
2320
|
+
},
|
|
2321
|
+
get _formState() {
|
|
2322
|
+
return _formState;
|
|
2323
|
+
},
|
|
2324
|
+
get _options() {
|
|
2325
|
+
return _options;
|
|
2326
|
+
},
|
|
2327
|
+
set _options(value) {
|
|
2328
|
+
_options = {
|
|
2329
|
+
..._options,
|
|
2330
|
+
...value,
|
|
2331
|
+
};
|
|
2332
|
+
},
|
|
2333
|
+
},
|
|
2334
|
+
subscribe,
|
|
2335
|
+
trigger,
|
|
2336
|
+
register,
|
|
2337
|
+
handleSubmit,
|
|
2338
|
+
watch,
|
|
2339
|
+
setValue,
|
|
2340
|
+
getValues,
|
|
2341
|
+
reset,
|
|
2342
|
+
resetField,
|
|
2343
|
+
clearErrors,
|
|
2344
|
+
unregister,
|
|
2345
|
+
setError,
|
|
2346
|
+
setFocus,
|
|
2347
|
+
getFieldState,
|
|
2348
|
+
};
|
|
2349
|
+
return {
|
|
2350
|
+
...methods,
|
|
2351
|
+
formControl: methods,
|
|
2352
|
+
};
|
|
2353
|
+
}
|
|
2354
|
+
|
|
2355
|
+
/**
|
|
2356
|
+
* Custom hook to manage the entire form.
|
|
2357
|
+
*
|
|
2358
|
+
* @remarks
|
|
2359
|
+
* [API](https://react-hook-form.com/docs/useform) • [Demo](https://codesandbox.io/s/react-hook-form-get-started-ts-5ksmm) • [Video](https://www.youtube.com/watch?v=RkXv4AXXC_4)
|
|
2360
|
+
*
|
|
2361
|
+
* @param props - form configuration and validation parameters.
|
|
2362
|
+
*
|
|
2363
|
+
* @returns methods - individual functions to manage the form state. {@link UseFormReturn}
|
|
2364
|
+
*
|
|
2365
|
+
* @example
|
|
2366
|
+
* ```tsx
|
|
2367
|
+
* function App() {
|
|
2368
|
+
* const { register, handleSubmit, watch, formState: { errors } } = useForm();
|
|
2369
|
+
* const onSubmit = data => console.log(data);
|
|
2370
|
+
*
|
|
2371
|
+
* console.log(watch("example"));
|
|
2372
|
+
*
|
|
2373
|
+
* return (
|
|
2374
|
+
* <form onSubmit={handleSubmit(onSubmit)}>
|
|
2375
|
+
* <input defaultValue="test" {...register("example")} />
|
|
2376
|
+
* <input {...register("exampleRequired", { required: true })} />
|
|
2377
|
+
* {errors.exampleRequired && <span>This field is required</span>}
|
|
2378
|
+
* <button>Submit</button>
|
|
2379
|
+
* </form>
|
|
2380
|
+
* );
|
|
2381
|
+
* }
|
|
2382
|
+
* ```
|
|
2383
|
+
*/
|
|
2384
|
+
function useForm(props = {}) {
|
|
2385
|
+
const _formControl = React__default.useRef(undefined);
|
|
2386
|
+
const _values = React__default.useRef(undefined);
|
|
2387
|
+
const [formState, updateFormState] = React__default.useState({
|
|
2388
|
+
isDirty: false,
|
|
2389
|
+
isValidating: false,
|
|
2390
|
+
isLoading: isFunction(props.defaultValues),
|
|
2391
|
+
isSubmitted: false,
|
|
2392
|
+
isSubmitting: false,
|
|
2393
|
+
isSubmitSuccessful: false,
|
|
2394
|
+
isValid: false,
|
|
2395
|
+
submitCount: 0,
|
|
2396
|
+
dirtyFields: {},
|
|
2397
|
+
touchedFields: {},
|
|
2398
|
+
validatingFields: {},
|
|
2399
|
+
errors: props.errors || {},
|
|
2400
|
+
disabled: props.disabled || false,
|
|
2401
|
+
isReady: false,
|
|
2402
|
+
defaultValues: isFunction(props.defaultValues)
|
|
2403
|
+
? undefined
|
|
2404
|
+
: props.defaultValues,
|
|
2405
|
+
});
|
|
2406
|
+
if (!_formControl.current) {
|
|
2407
|
+
if (props.formControl) {
|
|
2408
|
+
_formControl.current = {
|
|
2409
|
+
...props.formControl,
|
|
2410
|
+
formState,
|
|
2411
|
+
};
|
|
2412
|
+
if (props.defaultValues && !isFunction(props.defaultValues)) {
|
|
2413
|
+
props.formControl.reset(props.defaultValues, props.resetOptions);
|
|
2414
|
+
}
|
|
2415
|
+
}
|
|
2416
|
+
else {
|
|
2417
|
+
const { formControl, ...rest } = createFormControl(props);
|
|
2418
|
+
_formControl.current = {
|
|
2419
|
+
...rest,
|
|
2420
|
+
formState,
|
|
2421
|
+
};
|
|
2422
|
+
}
|
|
2423
|
+
}
|
|
2424
|
+
const control = _formControl.current.control;
|
|
2425
|
+
control._options = props;
|
|
2426
|
+
useIsomorphicLayoutEffect(() => {
|
|
2427
|
+
const sub = control._subscribe({
|
|
2428
|
+
formState: control._proxyFormState,
|
|
2429
|
+
callback: () => updateFormState({ ...control._formState }),
|
|
2430
|
+
reRenderRoot: true,
|
|
2431
|
+
});
|
|
2432
|
+
updateFormState((data) => ({
|
|
2433
|
+
...data,
|
|
2434
|
+
isReady: true,
|
|
2435
|
+
}));
|
|
2436
|
+
control._formState.isReady = true;
|
|
2437
|
+
return sub;
|
|
2438
|
+
}, [control]);
|
|
2439
|
+
React__default.useEffect(() => control._disableForm(props.disabled), [control, props.disabled]);
|
|
2440
|
+
React__default.useEffect(() => {
|
|
2441
|
+
if (props.mode) {
|
|
2442
|
+
control._options.mode = props.mode;
|
|
2443
|
+
}
|
|
2444
|
+
if (props.reValidateMode) {
|
|
2445
|
+
control._options.reValidateMode = props.reValidateMode;
|
|
2446
|
+
}
|
|
2447
|
+
}, [control, props.mode, props.reValidateMode]);
|
|
2448
|
+
React__default.useEffect(() => {
|
|
2449
|
+
if (props.errors) {
|
|
2450
|
+
control._setErrors(props.errors);
|
|
2451
|
+
control._focusError();
|
|
2452
|
+
}
|
|
2453
|
+
}, [control, props.errors]);
|
|
2454
|
+
React__default.useEffect(() => {
|
|
2455
|
+
props.shouldUnregister &&
|
|
2456
|
+
control._subjects.state.next({
|
|
2457
|
+
values: control._getWatch(),
|
|
2458
|
+
});
|
|
2459
|
+
}, [control, props.shouldUnregister]);
|
|
2460
|
+
React__default.useEffect(() => {
|
|
2461
|
+
if (control._proxyFormState.isDirty) {
|
|
2462
|
+
const isDirty = control._getDirty();
|
|
2463
|
+
if (isDirty !== formState.isDirty) {
|
|
2464
|
+
control._subjects.state.next({
|
|
2465
|
+
isDirty,
|
|
2466
|
+
});
|
|
2467
|
+
}
|
|
2468
|
+
}
|
|
2469
|
+
}, [control, formState.isDirty]);
|
|
2470
|
+
React__default.useEffect(() => {
|
|
2471
|
+
var _a;
|
|
2472
|
+
if (props.values && !deepEqual(props.values, _values.current)) {
|
|
2473
|
+
control._reset(props.values, {
|
|
2474
|
+
keepFieldsRef: true,
|
|
2475
|
+
...control._options.resetOptions,
|
|
2476
|
+
});
|
|
2477
|
+
if (!((_a = control._options.resetOptions) === null || _a === void 0 ? void 0 : _a.keepIsValid)) {
|
|
2478
|
+
control._setValid();
|
|
2479
|
+
}
|
|
2480
|
+
_values.current = props.values;
|
|
2481
|
+
updateFormState((state) => ({ ...state }));
|
|
2482
|
+
}
|
|
2483
|
+
else {
|
|
2484
|
+
control._resetDefaultValues();
|
|
2485
|
+
}
|
|
2486
|
+
}, [control, props.values]);
|
|
2487
|
+
React__default.useEffect(() => {
|
|
2488
|
+
if (!control._state.mount) {
|
|
2489
|
+
control._setValid();
|
|
2490
|
+
control._state.mount = true;
|
|
2491
|
+
}
|
|
2492
|
+
if (control._state.watch) {
|
|
2493
|
+
control._state.watch = false;
|
|
2494
|
+
control._subjects.state.next({ ...control._formState });
|
|
2495
|
+
}
|
|
2496
|
+
control._removeUnmounted();
|
|
2497
|
+
});
|
|
2498
|
+
_formControl.current.formState = React__default.useMemo(() => getProxyFormState(formState, control), [control, formState]);
|
|
2499
|
+
return _formControl.current;
|
|
2500
|
+
}
|
|
2501
|
+
|
|
619
2502
|
function mapApiErrorsToForm(error, form, options = {}) {
|
|
620
2503
|
const { fieldMapping = {}, setRootError = true } = options;
|
|
621
2504
|
if (!error || typeof error !== "object") {
|
|
@@ -649,13 +2532,13 @@ function mapApiErrorsToForm(error, form, options = {}) {
|
|
|
649
2532
|
}
|
|
650
2533
|
}
|
|
651
2534
|
|
|
652
|
-
function processChildren(children, control, isSubmitting) {
|
|
653
|
-
return
|
|
654
|
-
if (!
|
|
2535
|
+
function processChildren(children, control, isSubmitting, setValue, onCancel, reset) {
|
|
2536
|
+
return Children.map(children, (child) => {
|
|
2537
|
+
if (!isValidElement(child)) {
|
|
655
2538
|
return child;
|
|
656
2539
|
}
|
|
657
2540
|
const childProps = child.props;
|
|
658
|
-
const isFragment = child.type ===
|
|
2541
|
+
const isFragment = child.type === Fragment;
|
|
659
2542
|
if (!isFragment && childProps.name && typeof childProps.name === "string") {
|
|
660
2543
|
const name = childProps.name;
|
|
661
2544
|
return /* @__PURE__ */ jsx(
|
|
@@ -666,40 +2549,63 @@ function processChildren(children, control, isSubmitting) {
|
|
|
666
2549
|
render: ({ field, fieldState }) => {
|
|
667
2550
|
const isCheckbox = child.type === Checkbox;
|
|
668
2551
|
const isSwitch = child.type === Switch;
|
|
2552
|
+
const isRadioGroup = child.type === RadioGroup;
|
|
2553
|
+
const isCheckboxGroup = child.type === CheckboxGroup;
|
|
2554
|
+
const isPhone = child.type === PhoneField;
|
|
669
2555
|
const fieldProps = isCheckbox || isSwitch ? {
|
|
670
2556
|
checked: field.value,
|
|
671
2557
|
onCheckedChange: field.onChange,
|
|
672
2558
|
onBlur: field.onBlur,
|
|
673
2559
|
ref: field.ref
|
|
2560
|
+
} : isRadioGroup || isCheckboxGroup ? {
|
|
2561
|
+
value: field.value,
|
|
2562
|
+
onValueChange: field.onChange,
|
|
2563
|
+
onBlur: field.onBlur
|
|
2564
|
+
} : isPhone ? {
|
|
2565
|
+
...field,
|
|
2566
|
+
onCountryChange: (country) => {
|
|
2567
|
+
setValue(`${name}Country`, country);
|
|
2568
|
+
}
|
|
674
2569
|
} : field;
|
|
675
|
-
|
|
2570
|
+
const isUploadFile = child.type === UploadFile;
|
|
2571
|
+
return cloneElement(child, {
|
|
676
2572
|
...childProps,
|
|
677
2573
|
...fieldProps,
|
|
678
2574
|
error: fieldState.error?.message || (fieldState.error ? "Invalid" : void 0),
|
|
679
|
-
name: void 0
|
|
2575
|
+
name: void 0,
|
|
680
2576
|
// Remove name to avoid passing it to the underlying input
|
|
2577
|
+
...isUploadFile ? { isLoading: isSubmitting } : {}
|
|
681
2578
|
});
|
|
682
2579
|
}
|
|
683
2580
|
},
|
|
684
2581
|
name
|
|
685
2582
|
);
|
|
686
2583
|
}
|
|
2584
|
+
if (childProps["data-cancel"] && onCancel && reset) {
|
|
2585
|
+
return cloneElement(child, {
|
|
2586
|
+
...childProps,
|
|
2587
|
+
onClick: () => {
|
|
2588
|
+
reset();
|
|
2589
|
+
onCancel();
|
|
2590
|
+
}
|
|
2591
|
+
});
|
|
2592
|
+
}
|
|
687
2593
|
if (childProps.type === "submit") {
|
|
688
2594
|
const isButtonElement = child.type === Button || typeof child.type === "function" && child.type.displayName === "Button";
|
|
689
2595
|
if (isButtonElement) {
|
|
690
|
-
return
|
|
2596
|
+
return cloneElement(child, {
|
|
691
2597
|
...childProps,
|
|
692
2598
|
isLoading: isSubmitting
|
|
693
2599
|
});
|
|
694
2600
|
}
|
|
695
2601
|
}
|
|
696
2602
|
if (isFragment) {
|
|
697
|
-
return processChildren(childProps.children, control, isSubmitting);
|
|
2603
|
+
return processChildren(childProps.children, control, isSubmitting, setValue, onCancel, reset);
|
|
698
2604
|
}
|
|
699
2605
|
if (childProps.children != null) {
|
|
700
|
-
return
|
|
2606
|
+
return cloneElement(child, {
|
|
701
2607
|
...childProps,
|
|
702
|
-
children: processChildren(childProps.children, control, isSubmitting)
|
|
2608
|
+
children: processChildren(childProps.children, control, isSubmitting, setValue, onCancel, reset)
|
|
703
2609
|
});
|
|
704
2610
|
}
|
|
705
2611
|
return child;
|
|
@@ -709,17 +2615,25 @@ function Form({
|
|
|
709
2615
|
form,
|
|
710
2616
|
onSubmit,
|
|
711
2617
|
children,
|
|
712
|
-
showRootError =
|
|
2618
|
+
showRootError = false,
|
|
713
2619
|
rootErrorPosition = "bottom",
|
|
714
2620
|
rootErrorClassName,
|
|
2621
|
+
rootErrorAction,
|
|
715
2622
|
fieldMapping,
|
|
716
2623
|
mutation,
|
|
717
2624
|
transformSubmit,
|
|
2625
|
+
resetOnSuccess,
|
|
2626
|
+
onCancel,
|
|
2627
|
+
className,
|
|
718
2628
|
...props
|
|
719
2629
|
}) {
|
|
720
2630
|
const isSubmitting = form.formState.isSubmitting || (mutation?.isPending ?? false);
|
|
721
|
-
const wrappedOnSubmit =
|
|
2631
|
+
const wrappedOnSubmit = useCallback(
|
|
722
2632
|
async (data) => {
|
|
2633
|
+
const interceptorId = axios.interceptors.request.use((config) => ({
|
|
2634
|
+
...config,
|
|
2635
|
+
showErrorToast: false
|
|
2636
|
+
}));
|
|
723
2637
|
try {
|
|
724
2638
|
if (mutation) {
|
|
725
2639
|
const variables = transformSubmit ? transformSubmit(data) : data;
|
|
@@ -727,25 +2641,29 @@ function Form({
|
|
|
727
2641
|
} else if (onSubmit) {
|
|
728
2642
|
await onSubmit(data);
|
|
729
2643
|
}
|
|
2644
|
+
if (resetOnSuccess !== false) form.reset();
|
|
730
2645
|
} catch (error) {
|
|
731
2646
|
mapApiErrorsToForm(error, form, {
|
|
732
2647
|
fieldMapping,
|
|
733
2648
|
setRootError: showRootError
|
|
734
2649
|
});
|
|
735
2650
|
console.error("[Form Submission Error]", error);
|
|
2651
|
+
} finally {
|
|
2652
|
+
axios.interceptors.request.eject(interceptorId);
|
|
736
2653
|
}
|
|
737
2654
|
},
|
|
738
|
-
[onSubmit, mutation, transformSubmit, fieldMapping, form, showRootError]
|
|
2655
|
+
[onSubmit, mutation, transformSubmit, fieldMapping, form, showRootError, resetOnSuccess]
|
|
739
2656
|
);
|
|
740
2657
|
const handleSubmit = form.handleSubmit(wrappedOnSubmit);
|
|
741
|
-
const processedChildren = processChildren(children, form.control, isSubmitting);
|
|
742
|
-
return /* @__PURE__ */ jsx(FormProvider, { ...form, children: /* @__PURE__ */ jsxs("form", { onSubmit: handleSubmit, ...props, children: [
|
|
2658
|
+
const processedChildren = processChildren(children, form.control, isSubmitting, form.setValue, onCancel, form.reset);
|
|
2659
|
+
return /* @__PURE__ */ jsx(FormProvider, { ...form, children: /* @__PURE__ */ jsxs("form", { onSubmit: handleSubmit, className: cn("space-y-4", className), ...props, children: [
|
|
743
2660
|
showRootError && rootErrorPosition === "top" && form.formState.errors.root && /* @__PURE__ */ jsx(
|
|
744
2661
|
Alert,
|
|
745
2662
|
{
|
|
746
2663
|
variant: "destructive",
|
|
747
2664
|
title: form.formState.errors.root.type || "Error",
|
|
748
2665
|
description: form.formState.errors.root.message,
|
|
2666
|
+
action: rootErrorAction,
|
|
749
2667
|
className: cn("mb-4", rootErrorClassName)
|
|
750
2668
|
}
|
|
751
2669
|
),
|
|
@@ -756,6 +2674,7 @@ function Form({
|
|
|
756
2674
|
variant: "destructive",
|
|
757
2675
|
title: form.formState.errors.root.type || "Error",
|
|
758
2676
|
description: form.formState.errors.root.message,
|
|
2677
|
+
action: rootErrorAction,
|
|
759
2678
|
className: cn("mt-4", rootErrorClassName)
|
|
760
2679
|
}
|
|
761
2680
|
)
|
|
@@ -763,5 +2682,5 @@ function Form({
|
|
|
763
2682
|
}
|
|
764
2683
|
Form.displayName = "Form";
|
|
765
2684
|
|
|
766
|
-
export { Controller as C, Form as F };
|
|
2685
|
+
export { Controller as C, Form as F, appendErrors as a, get as g, set as s, useForm as u };
|
|
767
2686
|
//# sourceMappingURL=Form.js.map
|