@verbb/plugin-kit-react 1.0.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/CHANGELOG.md +5 -0
- package/LICENSE.md +21 -0
- package/README.md +31 -0
- package/dist/_virtual/_rolldown/runtime.js +34 -0
- package/dist/components/Button.d.ts +26 -0
- package/dist/components/Button.d.ts.map +1 -0
- package/dist/components/Button.js +148 -0
- package/dist/components/Button.js.map +1 -0
- package/dist/components/ButtonGroup.d.ts +11 -0
- package/dist/components/ButtonGroup.d.ts.map +1 -0
- package/dist/components/ButtonGroup.js +59 -0
- package/dist/components/ButtonGroup.js.map +1 -0
- package/dist/components/Calendar.d.ts +11 -0
- package/dist/components/Calendar.d.ts.map +1 -0
- package/dist/components/Calendar.js +133 -0
- package/dist/components/Calendar.js.map +1 -0
- package/dist/components/Checkbox.d.ts +5 -0
- package/dist/components/Checkbox.d.ts.map +1 -0
- package/dist/components/Checkbox.js +41 -0
- package/dist/components/Checkbox.js.map +1 -0
- package/dist/components/CheckboxInput.d.ts +14 -0
- package/dist/components/CheckboxInput.d.ts.map +1 -0
- package/dist/components/CheckboxInput.js +31 -0
- package/dist/components/CheckboxInput.js.map +1 -0
- package/dist/components/CheckboxSelect.d.ts +19 -0
- package/dist/components/CheckboxSelect.d.ts.map +1 -0
- package/dist/components/CheckboxSelect.js +63 -0
- package/dist/components/CheckboxSelect.js.map +1 -0
- package/dist/components/ColorInput.d.ts +14 -0
- package/dist/components/ColorInput.d.ts.map +1 -0
- package/dist/components/ColorInput.js +148 -0
- package/dist/components/ColorInput.js.map +1 -0
- package/dist/components/Combobox.d.ts +40 -0
- package/dist/components/Combobox.d.ts.map +1 -0
- package/dist/components/Combobox.js +393 -0
- package/dist/components/Combobox.js.map +1 -0
- package/dist/components/ComboboxInput.d.ts +28 -0
- package/dist/components/ComboboxInput.d.ts.map +1 -0
- package/dist/components/ComboboxInput.js +165 -0
- package/dist/components/ComboboxInput.js.map +1 -0
- package/dist/components/Command.d.ts +26 -0
- package/dist/components/Command.d.ts.map +1 -0
- package/dist/components/Command.js +94 -0
- package/dist/components/Command.js.map +1 -0
- package/dist/components/CopyButton.d.ts +9 -0
- package/dist/components/CopyButton.d.ts.map +1 -0
- package/dist/components/CopyButton.js +40 -0
- package/dist/components/CopyButton.js.map +1 -0
- package/dist/components/DatePicker.d.ts +9 -0
- package/dist/components/DatePicker.d.ts.map +1 -0
- package/dist/components/DatePicker.js +46 -0
- package/dist/components/DatePicker.js.map +1 -0
- package/dist/components/Dialog.d.ts +21 -0
- package/dist/components/Dialog.d.ts.map +1 -0
- package/dist/components/Dialog.js +179 -0
- package/dist/components/Dialog.js.map +1 -0
- package/dist/components/DropdownMenu.d.ts +47 -0
- package/dist/components/DropdownMenu.d.ts.map +1 -0
- package/dist/components/DropdownMenu.js +240 -0
- package/dist/components/DropdownMenu.js.map +1 -0
- package/dist/components/EditableTable.d.ts +28 -0
- package/dist/components/EditableTable.d.ts.map +1 -0
- package/dist/components/EditableTable.js +145 -0
- package/dist/components/EditableTable.js.map +1 -0
- package/dist/components/FadeIn.d.ts +12 -0
- package/dist/components/FadeIn.d.ts.map +1 -0
- package/dist/components/FadeIn.js +24 -0
- package/dist/components/FadeIn.js.map +1 -0
- package/dist/components/Input.d.ts +9 -0
- package/dist/components/Input.d.ts.map +1 -0
- package/dist/components/Input.js +43 -0
- package/dist/components/Input.js.map +1 -0
- package/dist/components/InputGroup.d.ts +20 -0
- package/dist/components/InputGroup.d.ts.map +1 -0
- package/dist/components/InputGroup.js +111 -0
- package/dist/components/InputGroup.js.map +1 -0
- package/dist/components/Label.d.ts +4 -0
- package/dist/components/Label.d.ts.map +1 -0
- package/dist/components/Label.js +15 -0
- package/dist/components/Label.js.map +1 -0
- package/dist/components/Lightswitch.d.ts +9 -0
- package/dist/components/Lightswitch.d.ts.map +1 -0
- package/dist/components/Lightswitch.js +56 -0
- package/dist/components/Lightswitch.js.map +1 -0
- package/dist/components/Markdown.d.ts +11 -0
- package/dist/components/Markdown.d.ts.map +1 -0
- package/dist/components/Markdown.js +46 -0
- package/dist/components/Markdown.js.map +1 -0
- package/dist/components/MenuButton.d.ts +40 -0
- package/dist/components/MenuButton.d.ts.map +1 -0
- package/dist/components/MenuButton.js +122 -0
- package/dist/components/MenuButton.js.map +1 -0
- package/dist/components/ModalTabs.d.ts +8 -0
- package/dist/components/ModalTabs.d.ts.map +1 -0
- package/dist/components/ModalTabs.js +37 -0
- package/dist/components/ModalTabs.js.map +1 -0
- package/dist/components/PaneTabs.d.ts +8 -0
- package/dist/components/PaneTabs.d.ts.map +1 -0
- package/dist/components/PaneTabs.js +37 -0
- package/dist/components/PaneTabs.js.map +1 -0
- package/dist/components/Popover.d.ts +12 -0
- package/dist/components/Popover.d.ts.map +1 -0
- package/dist/components/Popover.js +70 -0
- package/dist/components/Popover.js.map +1 -0
- package/dist/components/RadioGroup.d.ts +6 -0
- package/dist/components/RadioGroup.d.ts.map +1 -0
- package/dist/components/RadioGroup.js +34 -0
- package/dist/components/RadioGroup.js.map +1 -0
- package/dist/components/ScrollArea.d.ts +16 -0
- package/dist/components/ScrollArea.d.ts.map +1 -0
- package/dist/components/ScrollArea.js +47 -0
- package/dist/components/ScrollArea.js.map +1 -0
- package/dist/components/Select.d.ts +23 -0
- package/dist/components/Select.d.ts.map +1 -0
- package/dist/components/Select.js +205 -0
- package/dist/components/Select.js.map +1 -0
- package/dist/components/SelectInput.d.ts +33 -0
- package/dist/components/SelectInput.d.ts.map +1 -0
- package/dist/components/SelectInput.js +85 -0
- package/dist/components/SelectInput.js.map +1 -0
- package/dist/components/Separator.d.ts +4 -0
- package/dist/components/Separator.d.ts.map +1 -0
- package/dist/components/Separator.js +17 -0
- package/dist/components/Separator.js.map +1 -0
- package/dist/components/SlideUp.d.ts +12 -0
- package/dist/components/SlideUp.d.ts.map +1 -0
- package/dist/components/SlideUp.js +36 -0
- package/dist/components/SlideUp.js.map +1 -0
- package/dist/components/Slot.d.ts +6 -0
- package/dist/components/Slot.d.ts.map +1 -0
- package/dist/components/Slot.js +52 -0
- package/dist/components/Slot.js.map +1 -0
- package/dist/components/Spinner.d.ts +9 -0
- package/dist/components/Spinner.d.ts.map +1 -0
- package/dist/components/Spinner.js +43 -0
- package/dist/components/Spinner.js.map +1 -0
- package/dist/components/Status.d.ts +8 -0
- package/dist/components/Status.d.ts.map +1 -0
- package/dist/components/Status.js +55 -0
- package/dist/components/Status.js.map +1 -0
- package/dist/components/Table.d.ts +10 -0
- package/dist/components/Table.d.ts.map +1 -0
- package/dist/components/Table.js +64 -0
- package/dist/components/Table.js.map +1 -0
- package/dist/components/Tabs.d.ts +8 -0
- package/dist/components/Tabs.d.ts.map +1 -0
- package/dist/components/Tabs.js +37 -0
- package/dist/components/Tabs.js.map +1 -0
- package/dist/components/Textarea.d.ts +8 -0
- package/dist/components/Textarea.d.ts.map +1 -0
- package/dist/components/Textarea.js +26 -0
- package/dist/components/Textarea.js.map +1 -0
- package/dist/components/TimePicker.d.ts +9 -0
- package/dist/components/TimePicker.d.ts.map +1 -0
- package/dist/components/TimePicker.js +40 -0
- package/dist/components/TimePicker.js.map +1 -0
- package/dist/components/TiptapContent.d.ts +9 -0
- package/dist/components/TiptapContent.d.ts.map +1 -0
- package/dist/components/TiptapContent.js +24 -0
- package/dist/components/TiptapContent.js.map +1 -0
- package/dist/components/TiptapEditor.d.ts +41 -0
- package/dist/components/TiptapEditor.d.ts.map +1 -0
- package/dist/components/TiptapEditor.js +555 -0
- package/dist/components/TiptapEditor.js.map +1 -0
- package/dist/components/TiptapInput.d.ts +15 -0
- package/dist/components/TiptapInput.d.ts.map +1 -0
- package/dist/components/TiptapInput.js +138 -0
- package/dist/components/TiptapInput.js.map +1 -0
- package/dist/components/Toggle.d.ts +9 -0
- package/dist/components/Toggle.d.ts.map +1 -0
- package/dist/components/Toggle.js +48 -0
- package/dist/components/Toggle.js.map +1 -0
- package/dist/components/ToggleGroup.d.ts +11 -0
- package/dist/components/ToggleGroup.d.ts.map +1 -0
- package/dist/components/ToggleGroup.js +70 -0
- package/dist/components/ToggleGroup.js.map +1 -0
- package/dist/components/Tooltip.d.ts +9 -0
- package/dist/components/Tooltip.d.ts.map +1 -0
- package/dist/components/Tooltip.js +51 -0
- package/dist/components/Tooltip.js.map +1 -0
- package/dist/components/VirtualizedScrollArea.d.ts +25 -0
- package/dist/components/VirtualizedScrollArea.d.ts.map +1 -0
- package/dist/components/VirtualizedScrollArea.js +80 -0
- package/dist/components/VirtualizedScrollArea.js.map +1 -0
- package/dist/components/editable-table/RowDataCells.d.ts +3 -0
- package/dist/components/editable-table/RowDataCells.d.ts.map +1 -0
- package/dist/components/editable-table/RowDataCells.js +33 -0
- package/dist/components/editable-table/RowDataCells.js.map +1 -0
- package/dist/components/editable-table/TableCell.d.ts +13 -0
- package/dist/components/editable-table/TableCell.d.ts.map +1 -0
- package/dist/components/editable-table/TableCell.js +415 -0
- package/dist/components/editable-table/TableCell.js.map +1 -0
- package/dist/components/editable-table/TableRow.d.ts +3 -0
- package/dist/components/editable-table/TableRow.d.ts.map +1 -0
- package/dist/components/editable-table/TableRow.js +163 -0
- package/dist/components/editable-table/TableRow.js.map +1 -0
- package/dist/components/editable-table/helpers.d.ts +12 -0
- package/dist/components/editable-table/helpers.d.ts.map +1 -0
- package/dist/components/editable-table/helpers.js +23 -0
- package/dist/components/editable-table/helpers.js.map +1 -0
- package/dist/components/editable-table/index.d.ts +4 -0
- package/dist/components/editable-table/index.d.ts.map +1 -0
- package/dist/components/editable-table/index.js +4 -0
- package/dist/components/editable-table/types.d.ts +43 -0
- package/dist/components/editable-table/types.d.ts.map +1 -0
- package/dist/components/editable-table/types.js +0 -0
- package/dist/components/editable-table/useEditableTableCellChange.d.ts +17 -0
- package/dist/components/editable-table/useEditableTableCellChange.d.ts.map +1 -0
- package/dist/components/editable-table/useEditableTableCellChange.js +152 -0
- package/dist/components/editable-table/useEditableTableCellChange.js.map +1 -0
- package/dist/components/editable-table/useEditableTableDnd.d.ts +18 -0
- package/dist/components/editable-table/useEditableTableDnd.d.ts.map +1 -0
- package/dist/components/editable-table/useEditableTableDnd.js +55 -0
- package/dist/components/editable-table/useEditableTableDnd.js.map +1 -0
- package/dist/components/editable-table/useEditableTableRows.d.ts +17 -0
- package/dist/components/editable-table/useEditableTableRows.d.ts.map +1 -0
- package/dist/components/editable-table/useEditableTableRows.js +108 -0
- package/dist/components/editable-table/useEditableTableRows.js.map +1 -0
- package/dist/components/index.d.ts +45 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +45 -0
- package/dist/components/tiptap/InlineVariablePickerPopover.d.ts +24 -0
- package/dist/components/tiptap/InlineVariablePickerPopover.d.ts.map +1 -0
- package/dist/components/tiptap/InlineVariablePickerPopover.js +63 -0
- package/dist/components/tiptap/InlineVariablePickerPopover.js.map +1 -0
- package/dist/components/tiptap/InsertLinkDialog.d.ts +14 -0
- package/dist/components/tiptap/InsertLinkDialog.d.ts.map +1 -0
- package/dist/components/tiptap/InsertLinkDialog.js +145 -0
- package/dist/components/tiptap/InsertLinkDialog.js.map +1 -0
- package/dist/components/tiptap/LinkBubbleMenu.d.ts +10 -0
- package/dist/components/tiptap/LinkBubbleMenu.d.ts.map +1 -0
- package/dist/components/tiptap/LinkBubbleMenu.js +106 -0
- package/dist/components/tiptap/LinkBubbleMenu.js.map +1 -0
- package/dist/components/tiptap/LinkDropdown.d.ts +53 -0
- package/dist/components/tiptap/LinkDropdown.d.ts.map +1 -0
- package/dist/components/tiptap/LinkDropdown.js +155 -0
- package/dist/components/tiptap/LinkDropdown.js.map +1 -0
- package/dist/components/tiptap/VariableCommandList.d.ts +37 -0
- package/dist/components/tiptap/VariableCommandList.d.ts.map +1 -0
- package/dist/components/tiptap/VariableCommandList.js +166 -0
- package/dist/components/tiptap/VariableCommandList.js.map +1 -0
- package/dist/components/tiptap/VariableDropdown.d.ts +33 -0
- package/dist/components/tiptap/VariableDropdown.d.ts.map +1 -0
- package/dist/components/tiptap/VariableDropdown.js +121 -0
- package/dist/components/tiptap/VariableDropdown.js.map +1 -0
- package/dist/components/tiptap/VariablePickerContext.d.ts +38 -0
- package/dist/components/tiptap/VariablePickerContext.d.ts.map +1 -0
- package/dist/components/tiptap/VariablePickerContext.js +30 -0
- package/dist/components/tiptap/VariablePickerContext.js.map +1 -0
- package/dist/components/tiptap/VariableTag.d.ts +6 -0
- package/dist/components/tiptap/VariableTag.d.ts.map +1 -0
- package/dist/components/tiptap/VariableTag.js +153 -0
- package/dist/components/tiptap/VariableTag.js.map +1 -0
- package/dist/components/tiptap/VariableTagView.d.ts +3 -0
- package/dist/components/tiptap/VariableTagView.d.ts.map +1 -0
- package/dist/components/tiptap/VariableTagView.js +445 -0
- package/dist/components/tiptap/VariableTagView.js.map +1 -0
- package/dist/components/tiptap/VariableTransformControls.d.ts +37 -0
- package/dist/components/tiptap/VariableTransformControls.d.ts.map +1 -0
- package/dist/components/tiptap/VariableTransformControls.js +157 -0
- package/dist/components/tiptap/VariableTransformControls.js.map +1 -0
- package/dist/components/tiptap/editorConfig.d.ts +15 -0
- package/dist/components/tiptap/editorConfig.d.ts.map +1 -0
- package/dist/components/tiptap/editorConfig.js +191 -0
- package/dist/components/tiptap/editorConfig.js.map +1 -0
- package/dist/components/tiptap/useInlineVariablePicker.d.ts +34 -0
- package/dist/components/tiptap/useInlineVariablePicker.d.ts.map +1 -0
- package/dist/components/tiptap/useInlineVariablePicker.js +240 -0
- package/dist/components/tiptap/useInlineVariablePicker.js.map +1 -0
- package/dist/components/tiptap/useVariablePicker.d.ts +28 -0
- package/dist/components/tiptap/useVariablePicker.d.ts.map +1 -0
- package/dist/components/tiptap/useVariablePicker.js +122 -0
- package/dist/components/tiptap/useVariablePicker.js.map +1 -0
- package/dist/components/tiptap/variablePickerUtils.d.ts +11 -0
- package/dist/components/tiptap/variablePickerUtils.d.ts.map +1 -0
- package/dist/components/tiptap/variablePickerUtils.js +63 -0
- package/dist/components/tiptap/variablePickerUtils.js.map +1 -0
- package/dist/components/tiptap/variableSerialization.d.ts +49 -0
- package/dist/components/tiptap/variableSerialization.d.ts.map +1 -0
- package/dist/components/tiptap/variableSerialization.js +250 -0
- package/dist/components/tiptap/variableSerialization.js.map +1 -0
- package/dist/css/core.css +288 -0
- package/dist/css/style.css +295 -0
- package/dist/forms/Field.d.ts +37 -0
- package/dist/forms/Field.d.ts.map +1 -0
- package/dist/forms/Field.js +159 -0
- package/dist/forms/Field.js.map +1 -0
- package/dist/forms/SchemaFormEngine.d.ts +23 -0
- package/dist/forms/SchemaFormEngine.d.ts.map +1 -0
- package/dist/forms/SchemaFormEngine.js +444 -0
- package/dist/forms/SchemaFormEngine.js.map +1 -0
- package/dist/forms/components/FieldWrap.d.ts +11 -0
- package/dist/forms/components/FieldWrap.d.ts.map +1 -0
- package/dist/forms/components/FieldWrap.js +84 -0
- package/dist/forms/components/FieldWrap.js.map +1 -0
- package/dist/forms/components/ModalTabs.d.ts +21 -0
- package/dist/forms/components/ModalTabs.d.ts.map +1 -0
- package/dist/forms/components/ModalTabs.js +84 -0
- package/dist/forms/components/ModalTabs.js.map +1 -0
- package/dist/forms/components/index.d.ts +3 -0
- package/dist/forms/components/index.d.ts.map +1 -0
- package/dist/forms/components/index.js +3 -0
- package/dist/forms/contexts/VariableCategoriesContext.d.ts +17 -0
- package/dist/forms/contexts/VariableCategoriesContext.d.ts.map +1 -0
- package/dist/forms/contexts/VariableCategoriesContext.js +18 -0
- package/dist/forms/contexts/VariableCategoriesContext.js.map +1 -0
- package/dist/forms/engine/FormStateStore.d.ts +24 -0
- package/dist/forms/engine/FormStateStore.d.ts.map +1 -0
- package/dist/forms/engine/FormStateStore.js +97 -0
- package/dist/forms/engine/FormStateStore.js.map +1 -0
- package/dist/forms/engine/SchemaIndex.d.ts +33 -0
- package/dist/forms/engine/SchemaIndex.d.ts.map +1 -0
- package/dist/forms/engine/SchemaIndex.js +21 -0
- package/dist/forms/engine/SchemaIndex.js.map +1 -0
- package/dist/forms/engine/ValidationEngine.d.ts +13 -0
- package/dist/forms/engine/ValidationEngine.d.ts.map +1 -0
- package/dist/forms/engine/ValidationEngine.js +155 -0
- package/dist/forms/engine/ValidationEngine.js.map +1 -0
- package/dist/forms/engine/buildGroupedMessage.d.ts +2 -0
- package/dist/forms/engine/buildGroupedMessage.d.ts.map +1 -0
- package/dist/forms/engine/buildGroupedMessage.js +20 -0
- package/dist/forms/engine/buildGroupedMessage.js.map +1 -0
- package/dist/forms/engine/context.d.ts +60 -0
- package/dist/forms/engine/context.d.ts.map +1 -0
- package/dist/forms/engine/context.js +12 -0
- package/dist/forms/engine/context.js.map +1 -0
- package/dist/forms/engine/rules/email.d.ts +2 -0
- package/dist/forms/engine/rules/email.d.ts.map +1 -0
- package/dist/forms/engine/rules/email.js +11 -0
- package/dist/forms/engine/rules/email.js.map +1 -0
- package/dist/forms/engine/rules/emailOrVariable.d.ts +2 -0
- package/dist/forms/engine/rules/emailOrVariable.d.ts.map +1 -0
- package/dist/forms/engine/rules/emailOrVariable.js +13 -0
- package/dist/forms/engine/rules/emailOrVariable.js.map +1 -0
- package/dist/forms/engine/rules/handle.d.ts +2 -0
- package/dist/forms/engine/rules/handle.d.ts.map +1 -0
- package/dist/forms/engine/rules/handle.js +12 -0
- package/dist/forms/engine/rules/handle.js.map +1 -0
- package/dist/forms/engine/rules/index.d.ts +9 -0
- package/dist/forms/engine/rules/index.d.ts.map +1 -0
- package/dist/forms/engine/rules/index.js +35 -0
- package/dist/forms/engine/rules/index.js.map +1 -0
- package/dist/forms/engine/rules/max.d.ts +2 -0
- package/dist/forms/engine/rules/max.d.ts.map +1 -0
- package/dist/forms/engine/rules/max.js +16 -0
- package/dist/forms/engine/rules/max.js.map +1 -0
- package/dist/forms/engine/rules/min.d.ts +2 -0
- package/dist/forms/engine/rules/min.d.ts.map +1 -0
- package/dist/forms/engine/rules/min.js +16 -0
- package/dist/forms/engine/rules/min.js.map +1 -0
- package/dist/forms/engine/rules/required.d.ts +2 -0
- package/dist/forms/engine/rules/required.d.ts.map +1 -0
- package/dist/forms/engine/rules/required.js +11 -0
- package/dist/forms/engine/rules/required.js.map +1 -0
- package/dist/forms/engine/rules/uniqueHandle.d.ts +9 -0
- package/dist/forms/engine/rules/uniqueHandle.d.ts.map +1 -0
- package/dist/forms/engine/rules/uniqueHandle.js +95 -0
- package/dist/forms/engine/rules/uniqueHandle.js.map +1 -0
- package/dist/forms/engine/rules/utils.d.ts +3 -0
- package/dist/forms/engine/rules/utils.d.ts.map +1 -0
- package/dist/forms/engine/rules/utils.js +21 -0
- package/dist/forms/engine/rules/utils.js.map +1 -0
- package/dist/forms/fields/CalculationsField.d.ts +24 -0
- package/dist/forms/fields/CalculationsField.d.ts.map +1 -0
- package/dist/forms/fields/CalculationsField.js +215 -0
- package/dist/forms/fields/CalculationsField.js.map +1 -0
- package/dist/forms/fields/CalculationsToolbar.d.ts +17 -0
- package/dist/forms/fields/CalculationsToolbar.d.ts.map +1 -0
- package/dist/forms/fields/CalculationsToolbar.js +130 -0
- package/dist/forms/fields/CalculationsToolbar.js.map +1 -0
- package/dist/forms/fields/CheckboxSelectField.d.ts +19 -0
- package/dist/forms/fields/CheckboxSelectField.d.ts.map +1 -0
- package/dist/forms/fields/CheckboxSelectField.js +30 -0
- package/dist/forms/fields/CheckboxSelectField.js.map +1 -0
- package/dist/forms/fields/ColorField.d.ts +15 -0
- package/dist/forms/fields/ColorField.d.ts.map +1 -0
- package/dist/forms/fields/ColorField.js +30 -0
- package/dist/forms/fields/ColorField.js.map +1 -0
- package/dist/forms/fields/ComboboxField.d.ts +23 -0
- package/dist/forms/fields/ComboboxField.d.ts.map +1 -0
- package/dist/forms/fields/ComboboxField.js +38 -0
- package/dist/forms/fields/ComboboxField.js.map +1 -0
- package/dist/forms/fields/DateTimeField.d.ts +14 -0
- package/dist/forms/fields/DateTimeField.d.ts.map +1 -0
- package/dist/forms/fields/DateTimeField.js +53 -0
- package/dist/forms/fields/DateTimeField.js.map +1 -0
- package/dist/forms/fields/EditableTableField.d.ts +22 -0
- package/dist/forms/fields/EditableTableField.d.ts.map +1 -0
- package/dist/forms/fields/EditableTableField.js +37 -0
- package/dist/forms/fields/EditableTableField.js.map +1 -0
- package/dist/forms/fields/ElementSelectField.d.ts +20 -0
- package/dist/forms/fields/ElementSelectField.d.ts.map +1 -0
- package/dist/forms/fields/ElementSelectField.js +215 -0
- package/dist/forms/fields/ElementSelectField.js.map +1 -0
- package/dist/forms/fields/GroupField.d.ts +19 -0
- package/dist/forms/fields/GroupField.d.ts.map +1 -0
- package/dist/forms/fields/GroupField.js +50 -0
- package/dist/forms/fields/GroupField.js.map +1 -0
- package/dist/forms/fields/HandleField.d.ts +20 -0
- package/dist/forms/fields/HandleField.d.ts.map +1 -0
- package/dist/forms/fields/HandleField.js +70 -0
- package/dist/forms/fields/HandleField.js.map +1 -0
- package/dist/forms/fields/LightswitchField.d.ts +14 -0
- package/dist/forms/fields/LightswitchField.d.ts.map +1 -0
- package/dist/forms/fields/LightswitchField.js +29 -0
- package/dist/forms/fields/LightswitchField.js.map +1 -0
- package/dist/forms/fields/ListField.d.ts +17 -0
- package/dist/forms/fields/ListField.d.ts.map +1 -0
- package/dist/forms/fields/ListField.js +51 -0
- package/dist/forms/fields/ListField.js.map +1 -0
- package/dist/forms/fields/NumberField.d.ts +17 -0
- package/dist/forms/fields/NumberField.d.ts.map +1 -0
- package/dist/forms/fields/NumberField.js +33 -0
- package/dist/forms/fields/NumberField.js.map +1 -0
- package/dist/forms/fields/RadioGroupField.d.ts +25 -0
- package/dist/forms/fields/RadioGroupField.d.ts.map +1 -0
- package/dist/forms/fields/RadioGroupField.js +102 -0
- package/dist/forms/fields/RadioGroupField.js.map +1 -0
- package/dist/forms/fields/RichTextField.d.ts +23 -0
- package/dist/forms/fields/RichTextField.d.ts.map +1 -0
- package/dist/forms/fields/RichTextField.js +50 -0
- package/dist/forms/fields/RichTextField.js.map +1 -0
- package/dist/forms/fields/SelectField.d.ts +25 -0
- package/dist/forms/fields/SelectField.d.ts.map +1 -0
- package/dist/forms/fields/SelectField.js +73 -0
- package/dist/forms/fields/SelectField.js.map +1 -0
- package/dist/forms/fields/StaticTableField.d.ts +34 -0
- package/dist/forms/fields/StaticTableField.d.ts.map +1 -0
- package/dist/forms/fields/StaticTableField.js +128 -0
- package/dist/forms/fields/StaticTableField.js.map +1 -0
- package/dist/forms/fields/TextField.d.ts +16 -0
- package/dist/forms/fields/TextField.d.ts.map +1 -0
- package/dist/forms/fields/TextField.js +31 -0
- package/dist/forms/fields/TextField.js.map +1 -0
- package/dist/forms/fields/TextareaField.d.ts +17 -0
- package/dist/forms/fields/TextareaField.d.ts.map +1 -0
- package/dist/forms/fields/TextareaField.js +32 -0
- package/dist/forms/fields/TextareaField.js.map +1 -0
- package/dist/forms/fields/VariablePickerField.d.ts +21 -0
- package/dist/forms/fields/VariablePickerField.d.ts.map +1 -0
- package/dist/forms/fields/VariablePickerField.js +49 -0
- package/dist/forms/fields/VariablePickerField.js.map +1 -0
- package/dist/forms/index.d.ts +8 -0
- package/dist/forms/index.d.ts.map +1 -0
- package/dist/forms/index.js +10 -0
- package/dist/forms/registry.d.ts +8 -0
- package/dist/forms/registry.d.ts.map +1 -0
- package/dist/forms/registry.js +76 -0
- package/dist/forms/registry.js.map +1 -0
- package/dist/forms/store/element-store.d.ts +11 -0
- package/dist/forms/store/element-store.d.ts.map +1 -0
- package/dist/forms/store/element-store.js +41 -0
- package/dist/forms/store/element-store.js.map +1 -0
- package/dist/forms/useEditableTableFieldBinding.d.ts +13 -0
- package/dist/forms/useEditableTableFieldBinding.d.ts.map +1 -0
- package/dist/forms/useEditableTableFieldBinding.js +91 -0
- package/dist/forms/useEditableTableFieldBinding.js.map +1 -0
- package/dist/forms/useEngineField.d.ts +9 -0
- package/dist/forms/useEngineField.d.ts.map +1 -0
- package/dist/forms/useEngineField.js +32 -0
- package/dist/forms/useEngineField.js.map +1 -0
- package/dist/hooks/index.d.ts +3 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +3 -0
- package/dist/hooks/useKeyboardShortcuts.d.ts +14 -0
- package/dist/hooks/useKeyboardShortcuts.d.ts.map +1 -0
- package/dist/hooks/useKeyboardShortcuts.js +67 -0
- package/dist/hooks/useKeyboardShortcuts.js.map +1 -0
- package/dist/hooks/useTranslation.d.ts +3 -0
- package/dist/hooks/useTranslation.d.ts.map +1 -0
- package/dist/hooks/useTranslation.js +12 -0
- package/dist/hooks/useTranslation.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/node_modules/@babel/runtime/helpers/arrayLikeToArray.js +15 -0
- package/dist/node_modules/@babel/runtime/helpers/arrayLikeToArray.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/arrayWithoutHoles.js +15 -0
- package/dist/node_modules/@babel/runtime/helpers/arrayWithoutHoles.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/classCallCheck.js +13 -0
- package/dist/node_modules/@babel/runtime/helpers/classCallCheck.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/createClass.js +21 -0
- package/dist/node_modules/@babel/runtime/helpers/createClass.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/defineProperty.js +20 -0
- package/dist/node_modules/@babel/runtime/helpers/defineProperty.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/interopRequireDefault.js +13 -0
- package/dist/node_modules/@babel/runtime/helpers/interopRequireDefault.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/iterableToArray.js +13 -0
- package/dist/node_modules/@babel/runtime/helpers/iterableToArray.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/nonIterableSpread.js +13 -0
- package/dist/node_modules/@babel/runtime/helpers/nonIterableSpread.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/toConsumableArray.js +21 -0
- package/dist/node_modules/@babel/runtime/helpers/toConsumableArray.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/toPrimitive.js +22 -0
- package/dist/node_modules/@babel/runtime/helpers/toPrimitive.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/toPropertyKey.js +18 -0
- package/dist/node_modules/@babel/runtime/helpers/toPropertyKey.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/typeof.js +18 -0
- package/dist/node_modules/@babel/runtime/helpers/typeof.js.map +1 -0
- package/dist/node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js +19 -0
- package/dist/node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js.map +1 -0
- package/dist/node_modules/jexl/dist/Expression.js +84 -0
- package/dist/node_modules/jexl/dist/Expression.js.map +1 -0
- package/dist/node_modules/jexl/dist/Jexl.js +165 -0
- package/dist/node_modules/jexl/dist/Jexl.js.map +1 -0
- package/dist/node_modules/jexl/dist/Lexer.js +152 -0
- package/dist/node_modules/jexl/dist/Lexer.js.map +1 -0
- package/dist/node_modules/jexl/dist/PromiseSync.js +87 -0
- package/dist/node_modules/jexl/dist/PromiseSync.js.map +1 -0
- package/dist/node_modules/jexl/dist/evaluator/Evaluator.js +98 -0
- package/dist/node_modules/jexl/dist/evaluator/Evaluator.js.map +1 -0
- package/dist/node_modules/jexl/dist/evaluator/handlers.js +162 -0
- package/dist/node_modules/jexl/dist/evaluator/handlers.js.map +1 -0
- package/dist/node_modules/jexl/dist/grammar.js +195 -0
- package/dist/node_modules/jexl/dist/grammar.js.map +1 -0
- package/dist/node_modules/jexl/dist/parser/Parser.js +135 -0
- package/dist/node_modules/jexl/dist/parser/Parser.js.map +1 -0
- package/dist/node_modules/jexl/dist/parser/handlers.js +205 -0
- package/dist/node_modules/jexl/dist/parser/handlers.js.map +1 -0
- package/dist/node_modules/jexl/dist/parser/states.js +158 -0
- package/dist/node_modules/jexl/dist/parser/states.js.map +1 -0
- package/dist/types/global.d.d.ts +1 -0
- package/dist/types/global.d.js +0 -0
- package/dist/utils/classes.d.ts +18 -0
- package/dist/utils/classes.d.ts.map +1 -0
- package/dist/utils/classes.js +25 -0
- package/dist/utils/classes.js.map +1 -0
- package/dist/utils/config.d.ts +14 -0
- package/dist/utils/config.d.ts.map +1 -0
- package/dist/utils/config.js +16 -0
- package/dist/utils/config.js.map +1 -0
- package/dist/utils/craftHostBridge.d.ts +16 -0
- package/dist/utils/craftHostBridge.d.ts.map +1 -0
- package/dist/utils/craftHostBridge.js +28 -0
- package/dist/utils/craftHostBridge.js.map +1 -0
- package/dist/utils/handle.d.ts +10 -0
- package/dist/utils/handle.d.ts.map +1 -0
- package/dist/utils/handle.js +51 -0
- package/dist/utils/handle.js.map +1 -0
- package/dist/utils/hostBridge.d.ts +40 -0
- package/dist/utils/hostBridge.d.ts.map +1 -0
- package/dist/utils/hostBridge.js +35 -0
- package/dist/utils/hostBridge.js.map +1 -0
- package/dist/utils/index.d.ts +18 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +66 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/portal.d.ts +17 -0
- package/dist/utils/portal.d.ts.map +1 -0
- package/dist/utils/portal.js +51 -0
- package/dist/utils/portal.js.map +1 -0
- package/dist/utils/schema.d.ts +17 -0
- package/dist/utils/schema.d.ts.map +1 -0
- package/dist/utils/schema.js +56 -0
- package/dist/utils/schema.js.map +1 -0
- package/dist/utils/schemaFieldNames.d.ts +2 -0
- package/dist/utils/schemaFieldNames.d.ts.map +1 -0
- package/dist/utils/schemaFieldNames.js +16 -0
- package/dist/utils/schemaFieldNames.js.map +1 -0
- package/dist/utils/schemaIndex.d.ts +6 -0
- package/dist/utils/schemaIndex.d.ts.map +1 -0
- package/dist/utils/schemaIndex.js +31 -0
- package/dist/utils/schemaIndex.js.map +1 -0
- package/dist/utils/schemaIndexCache.d.ts +6 -0
- package/dist/utils/schemaIndexCache.d.ts.map +1 -0
- package/dist/utils/schemaIndexCache.js +32 -0
- package/dist/utils/schemaIndexCache.js.map +1 -0
- package/dist/utils/schemaNormalize.d.ts +13 -0
- package/dist/utils/schemaNormalize.d.ts.map +1 -0
- package/dist/utils/schemaNormalize.js +17 -0
- package/dist/utils/schemaNormalize.js.map +1 -0
- package/dist/utils/store.d.ts +7 -0
- package/dist/utils/store.d.ts.map +1 -0
- package/dist/utils/store.js +6 -0
- package/dist/utils/store.js.map +1 -0
- package/dist/utils/timeOptions.d.ts +6 -0
- package/dist/utils/timeOptions.d.ts.map +1 -0
- package/dist/utils/timeOptions.js +42 -0
- package/dist/utils/timeOptions.js.map +1 -0
- package/dist/utils/tiptap.d.ts +13 -0
- package/dist/utils/tiptap.d.ts.map +1 -0
- package/dist/utils/tiptap.js +39 -0
- package/dist/utils/tiptap.js.map +1 -0
- package/dist/utils/translation.d.ts +5 -0
- package/dist/utils/translation.d.ts.map +1 -0
- package/dist/utils/translation.js +21 -0
- package/dist/utils/translation.js.map +1 -0
- package/dist/utils/validation.d.ts +4 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +253 -0
- package/dist/utils/validation.js.map +1 -0
- package/package.json +167 -0
- package/vite-dev.mjs +56 -0
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { cn } from "../../utils/classes.js";
|
|
2
|
+
import { hasSchemaErrorsCached } from "../../utils/schemaIndexCache.js";
|
|
3
|
+
import "../../utils/index.js";
|
|
4
|
+
import { ModalTabs as ModalTabs$1, ModalTabsContent as ModalTabsContent$1, ModalTabsList as ModalTabsList$1, ModalTabsTrigger as ModalTabsTrigger$1 } from "../../components/ModalTabs.js";
|
|
5
|
+
import "../../components/index.js";
|
|
6
|
+
import { SchemaEngineContext } from "../engine/context.js";
|
|
7
|
+
import { createContext, useCallback, useContext, useEffect, useState } from "react";
|
|
8
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
9
|
+
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
|
|
10
|
+
import { faTriangleExclamation } from "@fortawesome/pro-solid-svg-icons";
|
|
11
|
+
//#region src/forms/components/ModalTabs.tsx
|
|
12
|
+
var ModalTabsErrorsContext = createContext({});
|
|
13
|
+
var useModalTabsErrors = () => {
|
|
14
|
+
return useContext(ModalTabsErrorsContext);
|
|
15
|
+
};
|
|
16
|
+
var ModalTabs = Object.assign(({ children, schema, schemaNode, ...props }) => {
|
|
17
|
+
const form = useContext(SchemaEngineContext);
|
|
18
|
+
const node = schemaNode ?? schema;
|
|
19
|
+
const [tabErrors, setTabErrors] = useState({});
|
|
20
|
+
const getTabErrors = useCallback(() => {
|
|
21
|
+
const errors = {};
|
|
22
|
+
if (!node?.children || !form?.getErrorMapFields) return errors;
|
|
23
|
+
const formErrors = form.getErrorMapFields?.() || {};
|
|
24
|
+
Object.values(node.children).forEach((item) => {
|
|
25
|
+
if (typeof item !== "object" || item === null || Array.isArray(item)) return;
|
|
26
|
+
const childNode = item;
|
|
27
|
+
const value = typeof childNode.props?.value === "string" ? childNode.props.value : "";
|
|
28
|
+
if (childNode.$cmp === "ModalTabsContent" && value) errors[value] = hasSchemaErrorsCached(formErrors, childNode.children || []);
|
|
29
|
+
});
|
|
30
|
+
return errors;
|
|
31
|
+
}, [form, node]);
|
|
32
|
+
useEffect(() => {
|
|
33
|
+
if (!form?.store?.subscribe) {
|
|
34
|
+
setTabErrors(getTabErrors());
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
const update = () => {
|
|
38
|
+
setTabErrors(getTabErrors());
|
|
39
|
+
};
|
|
40
|
+
update();
|
|
41
|
+
return form.store.subscribe(update);
|
|
42
|
+
}, [form, getTabErrors]);
|
|
43
|
+
return /* @__PURE__ */ jsx(ModalTabsErrorsContext.Provider, {
|
|
44
|
+
value: tabErrors,
|
|
45
|
+
children: /* @__PURE__ */ jsx(ModalTabs$1, {
|
|
46
|
+
...props,
|
|
47
|
+
children
|
|
48
|
+
})
|
|
49
|
+
});
|
|
50
|
+
}, { usesSchemaNode: true });
|
|
51
|
+
function ModalTabsList({ children, ...props }) {
|
|
52
|
+
return /* @__PURE__ */ jsx(ModalTabsList$1, {
|
|
53
|
+
...props,
|
|
54
|
+
children
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
function ModalTabsTrigger({ children, value, ...props }) {
|
|
58
|
+
const tabErrors = useModalTabsErrors();
|
|
59
|
+
const hasErrors = Boolean(tabErrors[value]);
|
|
60
|
+
return /* @__PURE__ */ jsxs(ModalTabsTrigger$1, {
|
|
61
|
+
value,
|
|
62
|
+
"data-has-errors": hasErrors,
|
|
63
|
+
className: cn("flex items-center gap-1", hasErrors && "text-error"),
|
|
64
|
+
...props,
|
|
65
|
+
children: [children, hasErrors && /* @__PURE__ */ jsx(FontAwesomeIcon, {
|
|
66
|
+
icon: faTriangleExclamation,
|
|
67
|
+
className: "block size-3"
|
|
68
|
+
})]
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
function ModalTabsContent({ children, value, ...props }) {
|
|
72
|
+
return /* @__PURE__ */ jsx(ModalTabsContent$1, {
|
|
73
|
+
value,
|
|
74
|
+
...props,
|
|
75
|
+
children: /* @__PURE__ */ jsx("div", {
|
|
76
|
+
className: cn("grid grid-cols-1 gap-4"),
|
|
77
|
+
children
|
|
78
|
+
})
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
//#endregion
|
|
82
|
+
export { ModalTabs, ModalTabsContent, ModalTabsList, ModalTabsTrigger, useModalTabsErrors };
|
|
83
|
+
|
|
84
|
+
//# sourceMappingURL=ModalTabs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModalTabs.js","names":[],"sources":["../../../src/forms/components/ModalTabs.tsx"],"sourcesContent":["import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faTriangleExclamation } from '@fortawesome/pro-solid-svg-icons';\n\nimport {\n ModalTabs as BaseModalTabs,\n ModalTabsList as BaseModalTabsList,\n ModalTabsTrigger as BaseModalTabsTrigger,\n ModalTabsContent as BaseModalTabsContent,\n} from '../../components';\n\nimport { cn } from '../../utils';\nimport { hasSchemaErrorsCached } from '../../utils/schemaIndexCache';\n\nimport {\n createContext, useCallback, useContext, useEffect, useState,\n} from 'react';\n\nimport type { SchemaFormComponentProps } from '../engine/context';\nimport { SchemaEngineContext } from '../engine/context';\nimport type { SchemaNode } from '../engine/SchemaIndex';\n\n// Create a context to pass tab error information down\nconst ModalTabsErrorsContext = createContext<Record<string, boolean>>({});\n\nexport const useModalTabsErrors = () => {\n return useContext(ModalTabsErrorsContext);\n};\n\nconst ModalTabs = Object.assign(({\n children, schema, schemaNode, ...props\n}: SchemaFormComponentProps) => {\n const form = useContext(SchemaEngineContext);\n const node = schemaNode ?? schema;\n\n const [tabErrors, setTabErrors] = useState<Record<string, boolean>>({});\n\n const getTabErrors = useCallback(() => {\n const errors: Record<string, boolean> = {};\n\n if (!node?.children || !form?.getErrorMapFields) {\n return errors;\n }\n\n const formErrors = form.getErrorMapFields?.() || {};\n\n // Process schema children to find tab content\n Object.values(node.children as Record<string, unknown>).forEach((item) => {\n if (typeof item !== 'object' || item === null || Array.isArray(item)) {\n return;\n }\n\n const childNode = item as SchemaNode;\n const value = typeof childNode.props?.value === 'string' ? childNode.props.value : '';\n if (childNode.$cmp === 'ModalTabsContent' && value) {\n errors[value] = hasSchemaErrorsCached(formErrors, childNode.children || []);\n }\n });\n\n return errors;\n }, [form, node]);\n\n useEffect(() => {\n if (!form?.store?.subscribe) {\n setTabErrors(getTabErrors());\n return;\n }\n\n const update = () => {\n setTabErrors(getTabErrors());\n };\n\n update();\n const unsubscribe = form.store.subscribe(update);\n return unsubscribe;\n }, [form, getTabErrors]);\n\n return (\n <ModalTabsErrorsContext.Provider value={tabErrors}>\n <BaseModalTabs {...props}>{children}</BaseModalTabs>\n </ModalTabsErrorsContext.Provider>\n );\n}, { usesSchemaNode: true as const });\n\nfunction ModalTabsList({ children, ...props }) {\n return <BaseModalTabsList {...props}>{children}</BaseModalTabsList>;\n}\n\nfunction ModalTabsTrigger({ children, value, ...props }) {\n // Get tab errors from context\n const tabErrors = useModalTabsErrors();\n\n // Check if this specific tab has errors\n const hasErrors = Boolean(tabErrors[value]);\n\n return <BaseModalTabsTrigger\n value={value}\n data-has-errors={hasErrors}\n className={cn(\n 'flex items-center gap-1',\n hasErrors && 'text-error',\n )}\n {...props}\n >\n {children}\n\n {hasErrors && (\n <FontAwesomeIcon icon={faTriangleExclamation} className=\"block size-3\" />\n )}\n </BaseModalTabsTrigger>;\n}\n\nfunction ModalTabsContent({\n children, value, ...props\n}) {\n return (\n <BaseModalTabsContent value={value} {...props}>\n <div className={cn(\n 'grid grid-cols-1 gap-4',\n )}>{children}</div>\n </BaseModalTabsContent>\n );\n}\n\nexport {\n ModalTabs,\n ModalTabsList,\n ModalTabsTrigger,\n ModalTabsContent,\n};\n"],"mappings":";;;;;;;;;;;AAsBA,IAAM,yBAAyB,cAAuC,EAAE,CAAC;AAEzE,IAAa,2BAA2B;AACpC,QAAO,WAAW,uBAAuB;;AAG7C,IAAM,YAAY,OAAO,QAAQ,EAC7B,UAAU,QAAQ,YAAY,GAAG,YACL;CAC5B,MAAM,OAAO,WAAW,oBAAoB;CAC5C,MAAM,OAAO,cAAc;CAE3B,MAAM,CAAC,WAAW,gBAAgB,SAAkC,EAAE,CAAC;CAEvE,MAAM,eAAe,kBAAkB;EACnC,MAAM,SAAkC,EAAE;AAE1C,MAAI,CAAC,MAAM,YAAY,CAAC,MAAM,kBAC1B,QAAO;EAGX,MAAM,aAAa,KAAK,qBAAqB,IAAI,EAAE;AAGnD,SAAO,OAAO,KAAK,SAAoC,CAAC,SAAS,SAAS;AACtE,OAAI,OAAO,SAAS,YAAY,SAAS,QAAQ,MAAM,QAAQ,KAAK,CAChE;GAGJ,MAAM,YAAY;GAClB,MAAM,QAAQ,OAAO,UAAU,OAAO,UAAU,WAAW,UAAU,MAAM,QAAQ;AACnF,OAAI,UAAU,SAAS,sBAAsB,MACzC,QAAO,SAAS,sBAAsB,YAAY,UAAU,YAAY,EAAE,CAAC;IAEjF;AAEF,SAAO;IACR,CAAC,MAAM,KAAK,CAAC;AAEhB,iBAAgB;AACZ,MAAI,CAAC,MAAM,OAAO,WAAW;AACzB,gBAAa,cAAc,CAAC;AAC5B;;EAGJ,MAAM,eAAe;AACjB,gBAAa,cAAc,CAAC;;AAGhC,UAAQ;AAER,SADoB,KAAK,MAAM,UAAU,OAClC;IACR,CAAC,MAAM,aAAa,CAAC;AAExB,QACI,oBAAC,uBAAuB,UAAxB;EAAiC,OAAO;YACpC,oBAAC,aAAD;GAAe,GAAI;GAAQ;GAAyB,CAAA;EACtB,CAAA;GAEvC,EAAE,gBAAgB,MAAe,CAAC;AAErC,SAAS,cAAc,EAAE,UAAU,GAAG,SAAS;AAC3C,QAAO,oBAAC,iBAAD;EAAmB,GAAI;EAAQ;EAA6B,CAAA;;AAGvE,SAAS,iBAAiB,EAAE,UAAU,OAAO,GAAG,SAAS;CAErD,MAAM,YAAY,oBAAoB;CAGtC,MAAM,YAAY,QAAQ,UAAU,OAAO;AAE3C,QAAO,qBAAC,oBAAD;EACI;EACP,mBAAiB;EACjB,WAAW,GACP,2BACA,aAAa,aAChB;EACD,GAAI;YAPD,CASF,UAEA,aACG,oBAAC,iBAAD;GAAiB,MAAM;GAAuB,WAAU;GAAiB,CAAA,CAE1D;;;AAG3B,SAAS,iBAAiB,EACtB,UAAU,OAAO,GAAG,SACrB;AACC,QACI,oBAAC,oBAAD;EAA6B;EAAO,GAAI;YACpC,oBAAC,OAAD;GAAK,WAAW,GACZ,yBACH;GAAG;GAAe,CAAA;EACA,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/forms/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { VariableTransformerRegistry } from '../../components/tiptap/VariablePickerContext';
|
|
2
|
+
export type VariableConfig = Record<string, unknown>;
|
|
3
|
+
export type VariableCategoriesGetter = (variableConfig: VariableConfig, options?: {
|
|
4
|
+
form?: unknown;
|
|
5
|
+
}) => Record<string, Array<{
|
|
6
|
+
label: string;
|
|
7
|
+
value: string;
|
|
8
|
+
}>>;
|
|
9
|
+
export type VariableCategoriesContextValue = {
|
|
10
|
+
getVariableCategories: VariableCategoriesGetter | null;
|
|
11
|
+
variableCategoryLabels?: Record<string, string>;
|
|
12
|
+
variableCategoryOrder?: string[];
|
|
13
|
+
variableTransformerRegistry?: VariableTransformerRegistry;
|
|
14
|
+
};
|
|
15
|
+
export declare const VariableCategoriesProvider: import('react').Provider<VariableCategoriesContextValue | null>;
|
|
16
|
+
export declare const useVariableCategoriesContext: () => VariableCategoriesContextValue;
|
|
17
|
+
//# sourceMappingURL=VariableCategoriesContext.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VariableCategoriesContext.d.ts","sourceRoot":"","sources":["../../../src/forms/contexts/VariableCategoriesContext.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,iEAAiE,CAAC;AAEnH,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAErD,MAAM,MAAM,wBAAwB,GAAG,CACnC,cAAc,EAAE,cAAc,EAC9B,OAAO,CAAC,EAAE;IAAE,IAAI,CAAC,EAAE,OAAO,CAAA;CAAE,KAC3B,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC,CAAC;AAE7D,MAAM,MAAM,8BAA8B,GAAG;IACzC,qBAAqB,EAAE,wBAAwB,GAAG,IAAI,CAAC;IACvD,sBAAsB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChD,qBAAqB,CAAC,EAAE,MAAM,EAAE,CAAC;IACjC,2BAA2B,CAAC,EAAE,2BAA2B,CAAC;CAC7D,CAAC;AAIF,eAAO,MAAM,0BAA0B,iEAAqC,CAAC;AAE7E,eAAO,MAAM,4BAA4B,QAAO,8BAY/C,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { createContext, useContext } from "react";
|
|
2
|
+
//#region src/forms/contexts/VariableCategoriesContext.tsx
|
|
3
|
+
var VariableCategoriesContext = createContext(null);
|
|
4
|
+
var VariableCategoriesProvider = VariableCategoriesContext.Provider;
|
|
5
|
+
var useVariableCategoriesContext = () => {
|
|
6
|
+
const value = useContext(VariableCategoriesContext);
|
|
7
|
+
if (value == null) return { getVariableCategories: null };
|
|
8
|
+
return {
|
|
9
|
+
getVariableCategories: value.getVariableCategories ?? null,
|
|
10
|
+
variableCategoryLabels: value.variableCategoryLabels,
|
|
11
|
+
variableCategoryOrder: value.variableCategoryOrder,
|
|
12
|
+
variableTransformerRegistry: value.variableTransformerRegistry
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
//#endregion
|
|
16
|
+
export { VariableCategoriesProvider, useVariableCategoriesContext };
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=VariableCategoriesContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VariableCategoriesContext.js","names":[],"sources":["../../../src/forms/contexts/VariableCategoriesContext.tsx"],"sourcesContent":["import { createContext, useContext } from 'react';\nimport type { VariableTransformerRegistry } from '@verbb/plugin-kit-react/components/tiptap/VariablePickerContext';\n\nexport type VariableConfig = Record<string, unknown>;\n\nexport type VariableCategoriesGetter = (\n variableConfig: VariableConfig,\n options?: { form?: unknown },\n) => Record<string, Array<{ label: string; value: string }>>;\n\nexport type VariableCategoriesContextValue = {\n getVariableCategories: VariableCategoriesGetter | null;\n variableCategoryLabels?: Record<string, string>;\n variableCategoryOrder?: string[];\n variableTransformerRegistry?: VariableTransformerRegistry;\n};\n\nconst VariableCategoriesContext = createContext<VariableCategoriesContextValue | null>(null);\n\nexport const VariableCategoriesProvider = VariableCategoriesContext.Provider;\n\nexport const useVariableCategoriesContext = (): VariableCategoriesContextValue => {\n const value = useContext(VariableCategoriesContext);\n if (value == null) {\n return { getVariableCategories: null };\n }\n\n return {\n getVariableCategories: value.getVariableCategories ?? null,\n variableCategoryLabels: value.variableCategoryLabels,\n variableCategoryOrder: value.variableCategoryOrder,\n variableTransformerRegistry: value.variableTransformerRegistry,\n };\n};\n"],"mappings":";;AAiBA,IAAM,4BAA4B,cAAqD,KAAK;AAE5F,IAAa,6BAA6B,0BAA0B;AAEpE,IAAa,qCAAqE;CAC9E,MAAM,QAAQ,WAAW,0BAA0B;AACnD,KAAI,SAAS,KACT,QAAO,EAAE,uBAAuB,MAAM;AAG1C,QAAO;EACH,uBAAuB,MAAM,yBAAyB;EACtD,wBAAwB,MAAM;EAC9B,uBAAuB,MAAM;EAC7B,6BAA6B,MAAM;EACtC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
type FormSubscriber = () => void;
|
|
2
|
+
export type FormState = {
|
|
3
|
+
values: Record<string, unknown>;
|
|
4
|
+
errors: Record<string, string[]>;
|
|
5
|
+
touched: Set<string>;
|
|
6
|
+
dirty: Set<string>;
|
|
7
|
+
};
|
|
8
|
+
export declare class FormStateStore {
|
|
9
|
+
state: FormState;
|
|
10
|
+
private listeners;
|
|
11
|
+
private initialValues;
|
|
12
|
+
constructor(initialValues?: Record<string, unknown>);
|
|
13
|
+
subscribe(listener: FormSubscriber): () => void;
|
|
14
|
+
notify(): void;
|
|
15
|
+
getValue(path: string): unknown;
|
|
16
|
+
setValue(path: string, value: unknown): void;
|
|
17
|
+
setValues(values: Record<string, unknown>): void;
|
|
18
|
+
setErrors(errors: Record<string, string[]>): void;
|
|
19
|
+
clearErrors(): void;
|
|
20
|
+
setTouched(path: string, touched?: boolean): void;
|
|
21
|
+
reset(values?: Record<string, unknown>): void;
|
|
22
|
+
}
|
|
23
|
+
export {};
|
|
24
|
+
//# sourceMappingURL=FormStateStore.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FormStateStore.d.ts","sourceRoot":"","sources":["../../../src/forms/engine/FormStateStore.ts"],"names":[],"mappings":"AAEA,KAAK,cAAc,GAAG,MAAM,IAAI,CAAC;AAEjC,MAAM,MAAM,SAAS,GAAG;IACpB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;IACjC,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IACrB,KAAK,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;CACtB,CAAC;AAEF,qBAAa,cAAc;IACvB,KAAK,EAAE,SAAS,CAAC;IAEjB,OAAO,CAAC,SAAS,CAAkC;IAEnD,OAAO,CAAC,aAAa,CAA0B;gBAEnC,aAAa,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM;IAUvD,SAAS,CAAC,QAAQ,EAAE,cAAc,GAAG,MAAM,IAAI;IAO/C,MAAM;IAIN,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAI/B,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO;IA+BrC,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAQzC,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;IAQ1C,WAAW;IAQX,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,UAAO;IAoBvC,KAAK,CAAC,MAAM,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAsB;CAU7D"}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { get, set } from "lodash-es";
|
|
2
|
+
//#region src/forms/engine/FormStateStore.ts
|
|
3
|
+
var FormStateStore = class {
|
|
4
|
+
state;
|
|
5
|
+
listeners = /* @__PURE__ */ new Set();
|
|
6
|
+
initialValues;
|
|
7
|
+
constructor(initialValues = {}) {
|
|
8
|
+
this.initialValues = { ...initialValues };
|
|
9
|
+
this.state = {
|
|
10
|
+
values: { ...initialValues },
|
|
11
|
+
errors: {},
|
|
12
|
+
touched: /* @__PURE__ */ new Set(),
|
|
13
|
+
dirty: /* @__PURE__ */ new Set()
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
subscribe(listener) {
|
|
17
|
+
this.listeners.add(listener);
|
|
18
|
+
return () => {
|
|
19
|
+
this.listeners.delete(listener);
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
notify() {
|
|
23
|
+
this.listeners.forEach((listener) => {
|
|
24
|
+
listener();
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
getValue(path) {
|
|
28
|
+
return get(this.state.values, path);
|
|
29
|
+
}
|
|
30
|
+
setValue(path, value) {
|
|
31
|
+
const nextErrors = { ...this.state.errors };
|
|
32
|
+
if (path in nextErrors) delete nextErrors[path];
|
|
33
|
+
if (Array.isArray(value)) {
|
|
34
|
+
const descendantPrefix = `${path}.`;
|
|
35
|
+
Object.keys(nextErrors).forEach((key) => {
|
|
36
|
+
if (key.startsWith(descendantPrefix)) delete nextErrors[key];
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
this.state = {
|
|
40
|
+
...this.state,
|
|
41
|
+
values: (() => {
|
|
42
|
+
const cloneRoot = Array.isArray(this.state.values) ? [...this.state.values] : { ...this.state.values ?? {} };
|
|
43
|
+
set(cloneRoot, path, value);
|
|
44
|
+
return cloneRoot;
|
|
45
|
+
})(),
|
|
46
|
+
dirty: new Set(this.state.dirty).add(path),
|
|
47
|
+
errors: nextErrors
|
|
48
|
+
};
|
|
49
|
+
this.notify();
|
|
50
|
+
}
|
|
51
|
+
setValues(values) {
|
|
52
|
+
this.state = {
|
|
53
|
+
...this.state,
|
|
54
|
+
values: { ...values }
|
|
55
|
+
};
|
|
56
|
+
this.notify();
|
|
57
|
+
}
|
|
58
|
+
setErrors(errors) {
|
|
59
|
+
this.state = {
|
|
60
|
+
...this.state,
|
|
61
|
+
errors: { ...errors }
|
|
62
|
+
};
|
|
63
|
+
this.notify();
|
|
64
|
+
}
|
|
65
|
+
clearErrors() {
|
|
66
|
+
this.state = {
|
|
67
|
+
...this.state,
|
|
68
|
+
errors: {}
|
|
69
|
+
};
|
|
70
|
+
this.notify();
|
|
71
|
+
}
|
|
72
|
+
setTouched(path, touched = true) {
|
|
73
|
+
if (this.state.touched.has(path) === touched) return;
|
|
74
|
+
const nextTouched = new Set(this.state.touched);
|
|
75
|
+
if (touched) nextTouched.add(path);
|
|
76
|
+
else nextTouched.delete(path);
|
|
77
|
+
this.state = {
|
|
78
|
+
...this.state,
|
|
79
|
+
touched: nextTouched
|
|
80
|
+
};
|
|
81
|
+
this.notify();
|
|
82
|
+
}
|
|
83
|
+
reset(values = this.initialValues) {
|
|
84
|
+
this.initialValues = { ...values };
|
|
85
|
+
this.state = {
|
|
86
|
+
values: { ...values },
|
|
87
|
+
errors: {},
|
|
88
|
+
touched: /* @__PURE__ */ new Set(),
|
|
89
|
+
dirty: /* @__PURE__ */ new Set()
|
|
90
|
+
};
|
|
91
|
+
this.notify();
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
//#endregion
|
|
95
|
+
export { FormStateStore };
|
|
96
|
+
|
|
97
|
+
//# sourceMappingURL=FormStateStore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FormStateStore.js","names":[],"sources":["../../../src/forms/engine/FormStateStore.ts"],"sourcesContent":["import { get, set } from 'lodash-es';\n\ntype FormSubscriber = () => void;\n\nexport type FormState = {\n values: Record<string, unknown>;\n errors: Record<string, string[]>;\n touched: Set<string>;\n dirty: Set<string>;\n};\n\nexport class FormStateStore {\n state: FormState;\n\n private listeners: Set<FormSubscriber> = new Set();\n\n private initialValues: Record<string, unknown>;\n\n constructor(initialValues: Record<string, unknown> = {}) {\n this.initialValues = { ...initialValues };\n this.state = {\n values: { ...initialValues },\n errors: {},\n touched: new Set(),\n dirty: new Set(),\n };\n }\n\n subscribe(listener: FormSubscriber): () => void {\n this.listeners.add(listener);\n return () => {\n this.listeners.delete(listener);\n };\n }\n\n notify() {\n this.listeners.forEach((listener) => { listener(); });\n }\n\n getValue(path: string): unknown {\n return get(this.state.values, path);\n }\n\n setValue(path: string, value: unknown) {\n const nextErrors = { ...this.state.errors };\n if (path in nextErrors) {\n delete nextErrors[path];\n }\n // When replacing an array (e.g. options), clear errors for descendant paths\n // so indices stay in sync after add/remove/reorder\n if (Array.isArray(value)) {\n const descendantPrefix = `${path}.`;\n Object.keys(nextErrors).forEach((key) => {\n if (key.startsWith(descendantPrefix)) {\n delete nextErrors[key];\n }\n });\n }\n\n this.state = {\n ...this.state,\n values: (() => {\n const cloneRoot: Record<string, unknown> = Array.isArray(this.state.values)\n ? ([...this.state.values] as unknown as Record<string, unknown>)\n : { ...(this.state.values ?? {}) };\n set(cloneRoot, path, value);\n return cloneRoot;\n })(),\n dirty: new Set(this.state.dirty).add(path),\n errors: nextErrors,\n };\n this.notify();\n }\n\n setValues(values: Record<string, unknown>) {\n this.state = {\n ...this.state,\n values: { ...values },\n };\n this.notify();\n }\n\n setErrors(errors: Record<string, string[]>) {\n this.state = {\n ...this.state,\n errors: { ...errors },\n };\n this.notify();\n }\n\n clearErrors() {\n this.state = {\n ...this.state,\n errors: {},\n };\n this.notify();\n }\n\n setTouched(path: string, touched = true) {\n const currentlyTouched = this.state.touched.has(path);\n if (currentlyTouched === touched) {\n return;\n }\n\n const nextTouched = new Set(this.state.touched);\n if (touched) {\n nextTouched.add(path);\n } else {\n nextTouched.delete(path);\n }\n\n this.state = {\n ...this.state,\n touched: nextTouched,\n };\n this.notify();\n }\n\n reset(values: Record<string, unknown> = this.initialValues) {\n this.initialValues = { ...values };\n this.state = {\n values: { ...values },\n errors: {},\n touched: new Set(),\n dirty: new Set(),\n };\n this.notify();\n }\n}\n"],"mappings":";;AAWA,IAAa,iBAAb,MAA4B;CACxB;CAEA,4BAAyC,IAAI,KAAK;CAElD;CAEA,YAAY,gBAAyC,EAAE,EAAE;AACrD,OAAK,gBAAgB,EAAE,GAAG,eAAe;AACzC,OAAK,QAAQ;GACT,QAAQ,EAAE,GAAG,eAAe;GAC5B,QAAQ,EAAE;GACV,yBAAS,IAAI,KAAK;GAClB,uBAAO,IAAI,KAAK;GACnB;;CAGL,UAAU,UAAsC;AAC5C,OAAK,UAAU,IAAI,SAAS;AAC5B,eAAa;AACT,QAAK,UAAU,OAAO,SAAS;;;CAIvC,SAAS;AACL,OAAK,UAAU,SAAS,aAAa;AAAE,aAAU;IAAI;;CAGzD,SAAS,MAAuB;AAC5B,SAAO,IAAI,KAAK,MAAM,QAAQ,KAAK;;CAGvC,SAAS,MAAc,OAAgB;EACnC,MAAM,aAAa,EAAE,GAAG,KAAK,MAAM,QAAQ;AAC3C,MAAI,QAAQ,WACR,QAAO,WAAW;AAItB,MAAI,MAAM,QAAQ,MAAM,EAAE;GACtB,MAAM,mBAAmB,GAAG,KAAK;AACjC,UAAO,KAAK,WAAW,CAAC,SAAS,QAAQ;AACrC,QAAI,IAAI,WAAW,iBAAiB,CAChC,QAAO,WAAW;KAExB;;AAGN,OAAK,QAAQ;GACT,GAAG,KAAK;GACR,eAAe;IACX,MAAM,YAAqC,MAAM,QAAQ,KAAK,MAAM,OAAO,GACpE,CAAC,GAAG,KAAK,MAAM,OAAO,GACvB,EAAE,GAAI,KAAK,MAAM,UAAU,EAAE,EAAG;AACtC,QAAI,WAAW,MAAM,MAAM;AAC3B,WAAO;OACP;GACJ,OAAO,IAAI,IAAI,KAAK,MAAM,MAAM,CAAC,IAAI,KAAK;GAC1C,QAAQ;GACX;AACD,OAAK,QAAQ;;CAGjB,UAAU,QAAiC;AACvC,OAAK,QAAQ;GACT,GAAG,KAAK;GACR,QAAQ,EAAE,GAAG,QAAQ;GACxB;AACD,OAAK,QAAQ;;CAGjB,UAAU,QAAkC;AACxC,OAAK,QAAQ;GACT,GAAG,KAAK;GACR,QAAQ,EAAE,GAAG,QAAQ;GACxB;AACD,OAAK,QAAQ;;CAGjB,cAAc;AACV,OAAK,QAAQ;GACT,GAAG,KAAK;GACR,QAAQ,EAAE;GACb;AACD,OAAK,QAAQ;;CAGjB,WAAW,MAAc,UAAU,MAAM;AAErC,MADyB,KAAK,MAAM,QAAQ,IAAI,KAC5C,KAAqB,QACrB;EAGJ,MAAM,cAAc,IAAI,IAAI,KAAK,MAAM,QAAQ;AAC/C,MAAI,QACA,aAAY,IAAI,KAAK;MAErB,aAAY,OAAO,KAAK;AAG5B,OAAK,QAAQ;GACT,GAAG,KAAK;GACR,SAAS;GACZ;AACD,OAAK,QAAQ;;CAGjB,MAAM,SAAkC,KAAK,eAAe;AACxD,OAAK,gBAAgB,EAAE,GAAG,QAAQ;AAClC,OAAK,QAAQ;GACT,QAAQ,EAAE,GAAG,QAAQ;GACrB,QAAQ,EAAE;GACV,yBAAS,IAAI,KAAK;GAClB,uBAAO,IAAI,KAAK;GACnB;AACD,OAAK,QAAQ"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
export type SchemaNode = {
|
|
2
|
+
_id?: string;
|
|
3
|
+
_data?: Record<string, unknown>;
|
|
4
|
+
_scopePath?: string;
|
|
5
|
+
name?: string;
|
|
6
|
+
label?: string;
|
|
7
|
+
required?: boolean;
|
|
8
|
+
validation?: string;
|
|
9
|
+
columns?: unknown[];
|
|
10
|
+
children?: SchemaRenderable;
|
|
11
|
+
schema?: SchemaRenderable;
|
|
12
|
+
schemaChildPrefix?: string;
|
|
13
|
+
$field?: string;
|
|
14
|
+
$cmp?: string;
|
|
15
|
+
$el?: string;
|
|
16
|
+
type?: string;
|
|
17
|
+
if?: string;
|
|
18
|
+
hideOnIf?: boolean;
|
|
19
|
+
attrs?: Record<string, unknown>;
|
|
20
|
+
props?: Record<string, unknown>;
|
|
21
|
+
[key: string]: unknown;
|
|
22
|
+
};
|
|
23
|
+
export type SchemaRenderable = SchemaNode | string | SchemaRenderable[];
|
|
24
|
+
export type FieldEntry = {
|
|
25
|
+
path: string;
|
|
26
|
+
field: SchemaNode;
|
|
27
|
+
};
|
|
28
|
+
export type SchemaIndex = {
|
|
29
|
+
schema: SchemaRenderable;
|
|
30
|
+
fieldEntries: FieldEntry[];
|
|
31
|
+
};
|
|
32
|
+
export declare const normalizeSchema: (items: SchemaRenderable, path?: string) => SchemaRenderable;
|
|
33
|
+
//# sourceMappingURL=SchemaIndex.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SchemaIndex.d.ts","sourceRoot":"","sources":["../../../src/forms/engine/SchemaIndex.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG;IACrB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,EAAE,CAAC;IACpB,QAAQ,CAAC,EAAE,gBAAgB,CAAC;IAC5B,MAAM,CAAC,EAAE,gBAAgB,CAAC;IAC1B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CAC1B,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG,UAAU,GAAG,MAAM,GAAG,gBAAgB,EAAE,CAAC;AAExE,MAAM,MAAM,UAAU,GAAG;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,UAAU,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IACtB,MAAM,EAAE,gBAAgB,CAAC;IACzB,YAAY,EAAE,UAAU,EAAE,CAAC;CAC9B,CAAC;AAEF,eAAO,MAAM,eAAe,GAAI,OAAO,gBAAgB,EAAE,aAAa,KAAG,gBA+BxE,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
//#region src/forms/engine/SchemaIndex.ts
|
|
2
|
+
var normalizeSchema = (items, path = "root") => {
|
|
3
|
+
if (Array.isArray(items)) return items.map((item, index) => {
|
|
4
|
+
return normalizeSchema(item, `${path}.${index}`);
|
|
5
|
+
});
|
|
6
|
+
if (!items || typeof items !== "object") return items;
|
|
7
|
+
const itemWithId = { ...items };
|
|
8
|
+
const itemPath = path || "root";
|
|
9
|
+
if (!itemWithId._id) itemWithId._id = `schema_${itemPath}`;
|
|
10
|
+
if (Array.isArray(itemWithId.children)) itemWithId.children = itemWithId.children.map((child, index) => {
|
|
11
|
+
return normalizeSchema(child, `${itemPath}.children.${index}`);
|
|
12
|
+
});
|
|
13
|
+
if (Array.isArray(itemWithId.schema)) itemWithId.schema = itemWithId.schema.map((child, index) => {
|
|
14
|
+
return normalizeSchema(child, `${itemPath}.schema.${index}`);
|
|
15
|
+
});
|
|
16
|
+
return itemWithId;
|
|
17
|
+
};
|
|
18
|
+
//#endregion
|
|
19
|
+
export { normalizeSchema };
|
|
20
|
+
|
|
21
|
+
//# sourceMappingURL=SchemaIndex.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SchemaIndex.js","names":[],"sources":["../../../src/forms/engine/SchemaIndex.ts"],"sourcesContent":["export type SchemaNode = {\n _id?: string;\n _data?: Record<string, unknown>;\n _scopePath?: string;\n name?: string;\n label?: string;\n required?: boolean;\n validation?: string;\n columns?: unknown[];\n children?: SchemaRenderable;\n schema?: SchemaRenderable;\n schemaChildPrefix?: string;\n $field?: string;\n $cmp?: string;\n $el?: string;\n type?: string;\n if?: string;\n hideOnIf?: boolean;\n attrs?: Record<string, unknown>;\n props?: Record<string, unknown>;\n [key: string]: unknown;\n};\n\nexport type SchemaRenderable = SchemaNode | string | SchemaRenderable[];\n\nexport type FieldEntry = {\n path: string;\n field: SchemaNode;\n};\n\nexport type SchemaIndex = {\n schema: SchemaRenderable;\n fieldEntries: FieldEntry[];\n};\n\nexport const normalizeSchema = (items: SchemaRenderable, path = 'root'): SchemaRenderable => {\n if (Array.isArray(items)) {\n return items.map((item, index) => {\n return normalizeSchema(item, `${path}.${index}`);\n });\n }\n\n if (!items || typeof items !== 'object') {\n return items;\n }\n\n const itemWithId: SchemaNode = { ...items };\n const itemPath = path || 'root';\n\n if (!itemWithId._id) {\n itemWithId._id = `schema_${itemPath}`;\n }\n\n if (Array.isArray(itemWithId.children)) {\n itemWithId.children = itemWithId.children.map((child, index) => {\n return normalizeSchema(child, `${itemPath}.children.${index}`);\n });\n }\n\n if (Array.isArray(itemWithId.schema)) {\n itemWithId.schema = itemWithId.schema.map((child, index) => {\n return normalizeSchema(child, `${itemPath}.schema.${index}`);\n });\n }\n\n return itemWithId;\n};\n"],"mappings":";AAmCA,IAAa,mBAAmB,OAAyB,OAAO,WAA6B;AACzF,KAAI,MAAM,QAAQ,MAAM,CACpB,QAAO,MAAM,KAAK,MAAM,UAAU;AAC9B,SAAO,gBAAgB,MAAM,GAAG,KAAK,GAAG,QAAQ;GAClD;AAGN,KAAI,CAAC,SAAS,OAAO,UAAU,SAC3B,QAAO;CAGX,MAAM,aAAyB,EAAE,GAAG,OAAO;CAC3C,MAAM,WAAW,QAAQ;AAEzB,KAAI,CAAC,WAAW,IACZ,YAAW,MAAM,UAAU;AAG/B,KAAI,MAAM,QAAQ,WAAW,SAAS,CAClC,YAAW,WAAW,WAAW,SAAS,KAAK,OAAO,UAAU;AAC5D,SAAO,gBAAgB,OAAO,GAAG,SAAS,YAAY,QAAQ;GAChE;AAGN,KAAI,MAAM,QAAQ,WAAW,OAAO,CAChC,YAAW,SAAS,WAAW,OAAO,KAAK,OAAO,UAAU;AACxD,SAAO,gBAAgB,OAAO,GAAG,SAAS,UAAU,QAAQ;GAC9D;AAGN,QAAO"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { SchemaIndex, SchemaNode } from './SchemaIndex';
|
|
2
|
+
import { FormValues } from './context';
|
|
3
|
+
type ConditionDataResolver = (values: FormValues, field?: SchemaNode) => Record<string, unknown>;
|
|
4
|
+
export type ValidationResult = {
|
|
5
|
+
fields: Record<string, string[]>;
|
|
6
|
+
} | undefined;
|
|
7
|
+
export declare const createValidationEngine: (index: SchemaIndex, options?: {
|
|
8
|
+
conditionDataResolver?: ConditionDataResolver;
|
|
9
|
+
}) => {
|
|
10
|
+
validate: (values: FormValues) => ValidationResult;
|
|
11
|
+
};
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=ValidationEngine.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ValidationEngine.d.ts","sourceRoot":"","sources":["../../../src/forms/engine/ValidationEngine.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAc,WAAW,EAAE,UAAU,EAAoB,MAAM,eAAe,CAAC;AAG3F,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAU5C,KAAK,qBAAqB,GAAG,CAAC,MAAM,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,UAAU,KAAK,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAsMjG,MAAM,MAAM,gBAAgB,GAAG;IAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAA;CAAE,GAAG,SAAS,CAAC;AAEhF,eAAO,MAAM,sBAAsB,GAC/B,OAAO,WAAW,EAClB,UAAS;IAAE,qBAAqB,CAAC,EAAE,qBAAqB,CAAA;CAAO;uBAUrC,UAAU,KAAG,gBAAgB;CAmC1D,CAAC"}
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import { evaluateCondition } from "../../utils/schema.js";
|
|
2
|
+
import { isEmptyValue } from "./rules/utils.js";
|
|
3
|
+
import { ruleHandlers } from "./rules/index.js";
|
|
4
|
+
import { get } from "lodash-es";
|
|
5
|
+
//#region src/forms/engine/ValidationEngine.ts
|
|
6
|
+
var isRecord = (value) => {
|
|
7
|
+
return Boolean(value) && typeof value === "object" && !Array.isArray(value);
|
|
8
|
+
};
|
|
9
|
+
var parseRules = (field) => {
|
|
10
|
+
const tokens = (typeof field.validation === "string" ? field.validation : "").split("|").map((token) => {
|
|
11
|
+
return token.trim();
|
|
12
|
+
}).filter(Boolean);
|
|
13
|
+
const hasRequiredRule = tokens.some((rule) => {
|
|
14
|
+
return rule === "required" || rule.startsWith("required");
|
|
15
|
+
});
|
|
16
|
+
if (field.required && !hasRequiredRule) tokens.unshift("required");
|
|
17
|
+
return tokens.map((token) => {
|
|
18
|
+
const [name, ...rest] = token.split(":");
|
|
19
|
+
return {
|
|
20
|
+
name,
|
|
21
|
+
args: rest.length > 0 ? rest.join(":").split(",") : []
|
|
22
|
+
};
|
|
23
|
+
});
|
|
24
|
+
};
|
|
25
|
+
var expandWildcardPaths = (values, path) => {
|
|
26
|
+
if (!path.includes("*")) return [path];
|
|
27
|
+
const parts = path.split(".");
|
|
28
|
+
const results = [];
|
|
29
|
+
const walk = (current, index, acc) => {
|
|
30
|
+
if (index >= parts.length) {
|
|
31
|
+
results.push(acc.join("."));
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
const part = parts[index];
|
|
35
|
+
if (part === "*") {
|
|
36
|
+
if (Array.isArray(current)) current.forEach((item, idx) => {
|
|
37
|
+
walk(item, index + 1, [...acc, String(idx)]);
|
|
38
|
+
});
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
if (isRecord(current) && part in current) {
|
|
42
|
+
walk(current[part], index + 1, [...acc, part]);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
walk(void 0, index + 1, [...acc, part]);
|
|
46
|
+
};
|
|
47
|
+
walk(values, 0, []);
|
|
48
|
+
return results;
|
|
49
|
+
};
|
|
50
|
+
var validateValue = (field, rules, value, context) => {
|
|
51
|
+
const label = String(field.label || field.name || "");
|
|
52
|
+
const isRequired = rules.some((rule) => {
|
|
53
|
+
return rule.name === "required";
|
|
54
|
+
});
|
|
55
|
+
for (const rule of rules) {
|
|
56
|
+
const { name, args } = rule;
|
|
57
|
+
if (!isRequired && isEmptyValue(value)) continue;
|
|
58
|
+
const handler = ruleHandlers[name];
|
|
59
|
+
if (!handler) continue;
|
|
60
|
+
const message = handler(value, label, args, context);
|
|
61
|
+
if (message) return message;
|
|
62
|
+
}
|
|
63
|
+
return null;
|
|
64
|
+
};
|
|
65
|
+
var buildConditionData = (field, values, conditionDataResolver) => {
|
|
66
|
+
const scopePath = typeof field?._scopePath === "string" ? field._scopePath : "";
|
|
67
|
+
const scopedValues = scopePath ? get(values, scopePath) : null;
|
|
68
|
+
const scopedObject = isRecord(scopedValues) ? scopedValues : {};
|
|
69
|
+
const conditionContext = conditionDataResolver?.(values, field);
|
|
70
|
+
const normalizedConditionContext = isRecord(conditionContext) ? conditionContext : {};
|
|
71
|
+
const fieldData = isRecord(field._data) ? field._data : {};
|
|
72
|
+
return {
|
|
73
|
+
...values,
|
|
74
|
+
...scopedObject,
|
|
75
|
+
...fieldData,
|
|
76
|
+
...normalizedConditionContext
|
|
77
|
+
};
|
|
78
|
+
};
|
|
79
|
+
var shouldValidateField = (field, values, conditionDataResolver) => {
|
|
80
|
+
const condition = field?.if;
|
|
81
|
+
if (!condition) return true;
|
|
82
|
+
try {
|
|
83
|
+
return evaluateCondition(condition, buildConditionData(field, values, conditionDataResolver));
|
|
84
|
+
} catch {
|
|
85
|
+
return true;
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
var collectPathConditions = (schema) => {
|
|
89
|
+
const pathConditions = /* @__PURE__ */ new Map();
|
|
90
|
+
const walk = (node, currentPath = "", inherited = []) => {
|
|
91
|
+
if (Array.isArray(node)) {
|
|
92
|
+
node.forEach((child) => {
|
|
93
|
+
walk(child, currentPath, inherited);
|
|
94
|
+
});
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
if (!isRecord(node)) return;
|
|
98
|
+
const name = typeof node.name === "string" && node.name ? node.name : "";
|
|
99
|
+
let nodePath = currentPath;
|
|
100
|
+
if (name) nodePath = currentPath ? `${currentPath}.${name}` : name;
|
|
101
|
+
const ownCondition = typeof node.if === "string" && node.if ? [{
|
|
102
|
+
condition: node.if,
|
|
103
|
+
field: node
|
|
104
|
+
}] : [];
|
|
105
|
+
const nextInherited = [...inherited, ...ownCondition];
|
|
106
|
+
if (nodePath && nextInherited.length) pathConditions.set(nodePath, nextInherited);
|
|
107
|
+
if (Array.isArray(node.children)) walk(node.children, nodePath, nextInherited);
|
|
108
|
+
if (Array.isArray(node.schema)) walk(node.schema, nodePath, nextInherited);
|
|
109
|
+
};
|
|
110
|
+
walk(schema, "", []);
|
|
111
|
+
return pathConditions;
|
|
112
|
+
};
|
|
113
|
+
var shouldValidatePathConditions = (path, fallbackField, values, pathConditions, conditionDataResolver) => {
|
|
114
|
+
const conditions = pathConditions.get(path) || [];
|
|
115
|
+
if (!conditions.length) return true;
|
|
116
|
+
return conditions.every(({ condition, field }) => {
|
|
117
|
+
try {
|
|
118
|
+
return evaluateCondition(condition, buildConditionData(field || fallbackField, values, conditionDataResolver));
|
|
119
|
+
} catch {
|
|
120
|
+
return true;
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
};
|
|
124
|
+
var createValidationEngine = (index, options = {}) => {
|
|
125
|
+
const { conditionDataResolver } = options;
|
|
126
|
+
const fieldRules = /* @__PURE__ */ new Map();
|
|
127
|
+
const pathConditions = collectPathConditions(index.schema);
|
|
128
|
+
index.fieldEntries.forEach((entry) => {
|
|
129
|
+
fieldRules.set(entry, parseRules(entry.field));
|
|
130
|
+
});
|
|
131
|
+
const validate = (values) => {
|
|
132
|
+
const fieldErrors = {};
|
|
133
|
+
index.fieldEntries.forEach((entry) => {
|
|
134
|
+
const rules = fieldRules.get(entry) || [];
|
|
135
|
+
if (!rules.length) return;
|
|
136
|
+
if (!shouldValidateField(entry.field, values, conditionDataResolver)) return;
|
|
137
|
+
expandWildcardPaths(values, entry.path).forEach((path) => {
|
|
138
|
+
if (!shouldValidatePathConditions(path, entry.field, values, pathConditions, conditionDataResolver)) return;
|
|
139
|
+
const value = get(values, path);
|
|
140
|
+
const message = validateValue(entry.field, rules, value, {
|
|
141
|
+
path,
|
|
142
|
+
values,
|
|
143
|
+
field: entry.field
|
|
144
|
+
});
|
|
145
|
+
if (message) fieldErrors[path] = [message];
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
return Object.keys(fieldErrors).length > 0 ? { fields: fieldErrors } : void 0;
|
|
149
|
+
};
|
|
150
|
+
return { validate };
|
|
151
|
+
};
|
|
152
|
+
//#endregion
|
|
153
|
+
export { createValidationEngine };
|
|
154
|
+
|
|
155
|
+
//# sourceMappingURL=ValidationEngine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ValidationEngine.js","names":[],"sources":["../../../src/forms/engine/ValidationEngine.ts"],"sourcesContent":["import { get } from 'lodash-es';\nimport { evaluateCondition } from '@verbb/plugin-kit-react/utils/schema';\n\nimport type { FieldEntry, SchemaIndex, SchemaNode, SchemaRenderable } from './SchemaIndex';\nimport { ruleHandlers, RuleHandlerContext } from './rules';\nimport { isEmptyValue } from './rules/utils';\nimport type { FormValues } from './context';\n\ntype RuleToken = {\n name: string;\n args: string[];\n};\ntype ConditionContext = {\n condition: string;\n field: SchemaNode;\n};\ntype ConditionDataResolver = (values: FormValues, field?: SchemaNode) => Record<string, unknown>;\n\nconst isRecord = (value: unknown): value is Record<string, unknown> => {\n return Boolean(value) && typeof value === 'object' && !Array.isArray(value);\n};\n\nconst parseRules = (field: { validation?: string; required?: boolean }): RuleToken[] => {\n const rawRules = typeof field.validation === 'string' ? field.validation : '';\n const tokens = rawRules\n .split('|')\n .map((token) => { return token.trim(); })\n .filter(Boolean);\n\n const hasRequiredRule = tokens.some((rule) => { return rule === 'required' || rule.startsWith('required'); });\n if (field.required && !hasRequiredRule) {\n tokens.unshift('required');\n }\n\n return tokens.map((token) => {\n const [name, ...rest] = token.split(':');\n const args = rest.length > 0 ? rest.join(':').split(',') : [];\n return { name, args };\n });\n};\n\nconst expandWildcardPaths = (values: FormValues, path: string) => {\n if (!path.includes('*')) {\n return [path];\n }\n\n const parts = path.split('.');\n const results: string[] = [];\n\n const walk = (current: unknown, index: number, acc: string[]) => {\n if (index >= parts.length) {\n results.push(acc.join('.'));\n return;\n }\n\n const part = parts[index];\n if (part === '*') {\n if (Array.isArray(current)) {\n current.forEach((item, idx) => {\n walk(item, index + 1, [...acc, String(idx)]);\n });\n }\n return;\n }\n\n if (isRecord(current) && part in current) {\n walk(current[part], index + 1, [...acc, part]);\n return;\n }\n\n walk(undefined, index + 1, [...acc, part]);\n };\n\n walk(values, 0, []);\n return results;\n};\n\nconst validateValue = (\n field: SchemaNode,\n rules: RuleToken[],\n value: unknown,\n context: RuleHandlerContext,\n) => {\n const label = String(field.label || field.name || '');\n const isRequired = rules.some((rule) => { return rule.name === 'required'; });\n\n for (const rule of rules) {\n const { name, args } = rule;\n const shouldSkip = !isRequired && isEmptyValue(value);\n\n if (shouldSkip) {\n continue;\n }\n\n const handler = ruleHandlers[name];\n if (!handler) {\n continue;\n }\n\n const message = handler(value, label, args, context);\n if (message) {\n return message;\n }\n }\n\n return null;\n};\n\nconst buildConditionData = (\n field: SchemaNode,\n values: FormValues,\n conditionDataResolver?: ConditionDataResolver,\n) => {\n const scopePath = typeof field?._scopePath === 'string' ? field._scopePath : '';\n const scopedValues = scopePath ? get(values, scopePath) : null;\n const scopedObject = isRecord(scopedValues) ? scopedValues : {};\n const conditionContext = conditionDataResolver?.(values, field);\n const normalizedConditionContext = isRecord(conditionContext) ? conditionContext : {};\n const fieldData = isRecord(field._data) ? field._data : {};\n\n return {\n ...values,\n ...scopedObject,\n ...fieldData,\n ...normalizedConditionContext,\n };\n};\n\nconst shouldValidateField = (\n field: SchemaNode,\n values: FormValues,\n conditionDataResolver?: ConditionDataResolver,\n) => {\n const condition = field?.if;\n\n if (!condition) {\n return true;\n }\n\n try {\n return evaluateCondition(condition, buildConditionData(field, values, conditionDataResolver));\n } catch {\n // Fail-open to avoid accidentally blocking saves due to malformed conditions.\n return true;\n }\n};\n\nconst collectPathConditions = (schema: SchemaRenderable) => {\n const pathConditions = new Map<string, ConditionContext[]>();\n\n const walk = (node: SchemaRenderable, currentPath = '', inherited: ConditionContext[] = []) => {\n if (Array.isArray(node)) {\n node.forEach((child) => {\n walk(child, currentPath, inherited);\n });\n return;\n }\n\n if (!isRecord(node)) {\n return;\n }\n\n const name = typeof node.name === 'string' && node.name ? node.name : '';\n let nodePath = currentPath;\n if (name) {\n nodePath = currentPath ? `${currentPath}.${name}` : name;\n }\n\n const ownCondition = typeof node.if === 'string' && node.if\n ? [{ condition: node.if, field: node }]\n : [];\n const nextInherited = [...inherited, ...ownCondition];\n\n if (nodePath && nextInherited.length) {\n pathConditions.set(nodePath, nextInherited);\n }\n\n if (Array.isArray(node.children)) {\n walk(node.children, nodePath, nextInherited);\n }\n\n if (Array.isArray(node.schema)) {\n walk(node.schema, nodePath, nextInherited);\n }\n };\n\n walk(schema, '', []);\n\n return pathConditions;\n};\n\nconst shouldValidatePathConditions = (\n path: string,\n fallbackField: SchemaNode,\n values: FormValues,\n pathConditions: Map<string, ConditionContext[]>,\n conditionDataResolver?: ConditionDataResolver,\n) => {\n const conditions = pathConditions.get(path) || [];\n\n if (!conditions.length) {\n return true;\n }\n\n return conditions.every(({ condition, field }) => {\n try {\n return evaluateCondition(condition, buildConditionData(field || fallbackField, values, conditionDataResolver));\n } catch {\n // Fail-open to avoid accidental save blocking on malformed conditions.\n return true;\n }\n });\n};\n\nexport type ValidationResult = { fields: Record<string, string[]> } | undefined;\n\nexport const createValidationEngine = (\n index: SchemaIndex,\n options: { conditionDataResolver?: ConditionDataResolver } = {},\n) => {\n const { conditionDataResolver } = options;\n const fieldRules = new Map<FieldEntry, RuleToken[]>();\n const pathConditions = collectPathConditions(index.schema);\n\n index.fieldEntries.forEach((entry) => {\n fieldRules.set(entry, parseRules(entry.field));\n });\n\n const validate = (values: FormValues): ValidationResult => {\n const fieldErrors: Record<string, string[]> = {};\n index.fieldEntries.forEach((entry) => {\n const rules = fieldRules.get(entry) || [];\n if (!rules.length) {\n return;\n }\n\n if (!shouldValidateField(entry.field, values, conditionDataResolver)) {\n return;\n }\n\n const paths = expandWildcardPaths(values, entry.path);\n paths.forEach((path) => {\n if (!shouldValidatePathConditions(path, entry.field, values, pathConditions, conditionDataResolver)) {\n return;\n }\n\n const value = get(values, path);\n const message = validateValue(entry.field, rules, value, {\n path,\n values,\n field: entry.field,\n });\n if (message) {\n fieldErrors[path] = [message];\n\n }\n });\n });\n\n return Object.keys(fieldErrors).length > 0 ? { fields: fieldErrors } : undefined;\n };\n\n return { validate };\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildGroupedMessage.d.ts","sourceRoot":"","sources":["../../../src/forms/engine/buildGroupedMessage.ts"],"names":[],"mappings":"AAWA,eAAO,MAAM,mBAAmB,GAC5B,SAAS,MAAM,EACf,cAAc,MAAM,EACpB,aAAa,MAAM,WAkBtB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
//#region src/forms/engine/buildGroupedMessage.ts
|
|
2
|
+
var buildGroupLabel = (parentLabel, childLabel) => {
|
|
3
|
+
if (parentLabel && childLabel) return `${parentLabel}: ${childLabel}`;
|
|
4
|
+
return parentLabel || childLabel || "";
|
|
5
|
+
};
|
|
6
|
+
var ATTRIBUTE_MESSAGE_PATTERN = /^(.+?) (cannot be blank\.|must be .+)$/;
|
|
7
|
+
var buildGroupedMessage = (message, parentLabel, childLabel) => {
|
|
8
|
+
const groupLabel = buildGroupLabel(parentLabel, childLabel);
|
|
9
|
+
if (!groupLabel) return message;
|
|
10
|
+
const match = String(message).match(ATTRIBUTE_MESSAGE_PATTERN);
|
|
11
|
+
if (match) {
|
|
12
|
+
const [, attribute, suffix] = match;
|
|
13
|
+
return `${buildGroupLabel(parentLabel, (childLabel && attribute !== childLabel ? attribute : childLabel) || attribute)} ${suffix}`;
|
|
14
|
+
}
|
|
15
|
+
return `${groupLabel} ${message}`;
|
|
16
|
+
};
|
|
17
|
+
//#endregion
|
|
18
|
+
export { buildGroupedMessage };
|
|
19
|
+
|
|
20
|
+
//# sourceMappingURL=buildGroupedMessage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildGroupedMessage.js","names":[],"sources":["../../../src/forms/engine/buildGroupedMessage.ts"],"sourcesContent":["const buildGroupLabel = (parentLabel?: string, childLabel?: string) => {\n if (parentLabel && childLabel) {\n return `${parentLabel}: ${childLabel}`;\n }\n\n return parentLabel || childLabel || '';\n};\n\n// Matches \"{attribute} cannot be blank.\" and similar validation messages\nconst ATTRIBUTE_MESSAGE_PATTERN = /^(.+?) (cannot be blank\\.|must be .+)$/;\n\nexport const buildGroupedMessage = (\n message: string,\n parentLabel?: string,\n childLabel?: string,\n) => {\n const groupLabel = buildGroupLabel(parentLabel, childLabel);\n if (!groupLabel) {\n return message;\n }\n\n const match = String(message).match(ATTRIBUTE_MESSAGE_PATTERN);\n if (match) {\n const [, attribute, suffix] = match;\n // Use attribute in groupLabel (fixes \"label\" -> \"Option Label\") and only append suffix\n // to avoid \"Options: Option Label Option Label cannot be blank.\"\n const displayLabel = (childLabel && attribute !== childLabel) ? attribute : childLabel;\n const finalGroupLabel = buildGroupLabel(parentLabel, displayLabel || attribute);\n return `${finalGroupLabel} ${suffix}`;\n }\n\n return `${groupLabel} ${message}`;\n};\n"],"mappings":";AAAA,IAAM,mBAAmB,aAAsB,eAAwB;AACnE,KAAI,eAAe,WACf,QAAO,GAAG,YAAY,IAAI;AAG9B,QAAO,eAAe,cAAc;;AAIxC,IAAM,4BAA4B;AAElC,IAAa,uBACT,SACA,aACA,eACC;CACD,MAAM,aAAa,gBAAgB,aAAa,WAAW;AAC3D,KAAI,CAAC,WACD,QAAO;CAGX,MAAM,QAAQ,OAAO,QAAQ,CAAC,MAAM,0BAA0B;AAC9D,KAAI,OAAO;EACP,MAAM,GAAG,WAAW,UAAU;AAK9B,SAAO,GADiB,gBAAgB,cADlB,cAAc,cAAc,aAAc,YAAY,eACP,UAC3D,CAAgB,GAAG;;AAGjC,QAAO,GAAG,WAAW,GAAG"}
|