@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,60 @@
|
|
|
1
|
+
import { FormStateStore } from './FormStateStore';
|
|
2
|
+
import { SchemaIndex, SchemaNode, SchemaRenderable } from './SchemaIndex';
|
|
3
|
+
export type FormValues = Record<string, unknown>;
|
|
4
|
+
export type SchemaFieldApi = {
|
|
5
|
+
state: {
|
|
6
|
+
value: unknown;
|
|
7
|
+
};
|
|
8
|
+
handleChange: (valueOrEvent: unknown) => void;
|
|
9
|
+
handleBlur: () => void;
|
|
10
|
+
errors: string[];
|
|
11
|
+
};
|
|
12
|
+
export type SchemaFieldRenderProps = {
|
|
13
|
+
name: string;
|
|
14
|
+
children: (fieldApi: SchemaFieldApi) => React.ReactNode;
|
|
15
|
+
};
|
|
16
|
+
export type SchemaFormFieldComponentProps = {
|
|
17
|
+
schema: SchemaNode;
|
|
18
|
+
field: SchemaNode;
|
|
19
|
+
form: SchemaFormEngineApi;
|
|
20
|
+
children?: React.ReactNode;
|
|
21
|
+
};
|
|
22
|
+
export type SchemaFormFieldComponent = React.ComponentType<SchemaFormFieldComponentProps>;
|
|
23
|
+
export type SchemaFormComponentProps = Record<string, unknown> & {
|
|
24
|
+
children?: React.ReactNode;
|
|
25
|
+
schemaNode?: SchemaNode;
|
|
26
|
+
};
|
|
27
|
+
export type SchemaFormComponent = React.ComponentType<SchemaFormComponentProps> & {
|
|
28
|
+
usesSchemaNode?: boolean;
|
|
29
|
+
};
|
|
30
|
+
export type NestedFormApi = {
|
|
31
|
+
path: string;
|
|
32
|
+
validate: () => {
|
|
33
|
+
fields: Record<string, string[]>;
|
|
34
|
+
} | undefined;
|
|
35
|
+
getValues: () => FormValues;
|
|
36
|
+
};
|
|
37
|
+
export type SchemaFormEngineApi = {
|
|
38
|
+
schema: SchemaRenderable;
|
|
39
|
+
store: FormStateStore;
|
|
40
|
+
index: SchemaIndex;
|
|
41
|
+
Field: React.ComponentType<SchemaFieldRenderProps>;
|
|
42
|
+
getFieldValue: (path: string) => unknown;
|
|
43
|
+
setFieldValue: (path: string, value: unknown) => void;
|
|
44
|
+
getErrorMapFields: () => Record<string, string[]>;
|
|
45
|
+
handleSubmit: () => Promise<void>;
|
|
46
|
+
onChange: (handler: ((value: FormValues) => void) | null) => void;
|
|
47
|
+
onSubmit: (handler: ((value: FormValues) => Promise<void> | void) | null) => void;
|
|
48
|
+
onError: (handler: ((errors: Record<string, unknown>) => void) | null) => void;
|
|
49
|
+
onSuccess: (handler: ((value: FormValues) => void) | null) => void;
|
|
50
|
+
registerNestedForm: (path: string, api: NestedFormApi) => void;
|
|
51
|
+
unregisterNestedForm: (path: string) => void;
|
|
52
|
+
getGroupedErrorsForPath?: (path: string) => string[];
|
|
53
|
+
SchemaRenderer?: React.ComponentType<{
|
|
54
|
+
schema: SchemaRenderable;
|
|
55
|
+
}>;
|
|
56
|
+
getConditionContext?: (values: FormValues, field?: SchemaNode) => Record<string, unknown>;
|
|
57
|
+
};
|
|
58
|
+
export declare const SchemaEngineContext: import('react').Context<SchemaFormEngineApi | null>;
|
|
59
|
+
export declare const useSchemaEngineContext: () => SchemaFormEngineApi;
|
|
60
|
+
//# sourceMappingURL=context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../src/forms/engine/context.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { createContext, useContext } from "react";
|
|
2
|
+
//#region src/forms/engine/context.ts
|
|
3
|
+
var SchemaEngineContext = createContext(null);
|
|
4
|
+
var useSchemaEngineContext = () => {
|
|
5
|
+
const context = useContext(SchemaEngineContext);
|
|
6
|
+
if (!context) throw new Error("useSchemaEngineContext must be used within a SchemaEngineProvider");
|
|
7
|
+
return context;
|
|
8
|
+
};
|
|
9
|
+
//#endregion
|
|
10
|
+
export { SchemaEngineContext, useSchemaEngineContext };
|
|
11
|
+
|
|
12
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","names":[],"sources":["../../../src/forms/engine/context.ts"],"sourcesContent":["import { createContext, useContext } from 'react';\nimport type { FormStateStore } from './FormStateStore';\nimport type { SchemaIndex, SchemaNode, SchemaRenderable } from './SchemaIndex';\n\nexport type FormValues = Record<string, unknown>;\n\nexport type SchemaFieldApi = {\n state: { value: unknown };\n handleChange: (valueOrEvent: unknown) => void;\n handleBlur: () => void;\n errors: string[];\n};\n\nexport type SchemaFieldRenderProps = {\n name: string;\n children: (fieldApi: SchemaFieldApi) => React.ReactNode;\n};\n\nexport type SchemaFormFieldComponentProps = {\n schema: SchemaNode;\n field: SchemaNode;\n form: SchemaFormEngineApi;\n children?: React.ReactNode;\n};\n\nexport type SchemaFormFieldComponent = React.ComponentType<SchemaFormFieldComponentProps>;\n\nexport type SchemaFormComponentProps = Record<string, unknown> & {\n children?: React.ReactNode;\n schemaNode?: SchemaNode;\n};\n\nexport type SchemaFormComponent = React.ComponentType<SchemaFormComponentProps> & {\n usesSchemaNode?: boolean;\n};\n\nexport type NestedFormApi = {\n path: string;\n validate: () => { fields: Record<string, string[]> } | undefined;\n getValues: () => FormValues;\n};\n\nexport type SchemaFormEngineApi = {\n schema: SchemaRenderable;\n store: FormStateStore;\n index: SchemaIndex;\n Field: React.ComponentType<SchemaFieldRenderProps>;\n getFieldValue: (path: string) => unknown;\n setFieldValue: (path: string, value: unknown) => void;\n getErrorMapFields: () => Record<string, string[]>;\n handleSubmit: () => Promise<void>;\n onChange: (handler: ((value: FormValues) => void) | null) => void;\n onSubmit: (handler: ((value: FormValues) => Promise<void> | void) | null) => void;\n onError: (handler: ((errors: Record<string, unknown>) => void) | null) => void;\n onSuccess: (handler: ((value: FormValues) => void) | null) => void;\n registerNestedForm: (path: string, api: NestedFormApi) => void;\n unregisterNestedForm: (path: string) => void;\n getGroupedErrorsForPath?: (path: string) => string[];\n SchemaRenderer?: React.ComponentType<{ schema: SchemaRenderable }>;\n getConditionContext?: (values: FormValues, field?: SchemaNode) => Record<string, unknown>;\n};\n\nexport const SchemaEngineContext = createContext<SchemaFormEngineApi | null>(null);\n\nexport const useSchemaEngineContext = () => {\n const context = useContext(SchemaEngineContext);\n\n if (!context) {\n throw new Error('useSchemaEngineContext must be used within a SchemaEngineProvider');\n }\n\n return context;\n};\n"],"mappings":";;AA8DA,IAAa,sBAAsB,cAA0C,KAAK;AAElF,IAAa,+BAA+B;CACxC,MAAM,UAAU,WAAW,oBAAoB;AAE/C,KAAI,CAAC,QACD,OAAM,IAAI,MAAM,oEAAoE;AAGxF,QAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"email.d.ts","sourceRoot":"","sources":["../../../../src/forms/engine/rules/email.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,SAAS,GAAI,OAAO,OAAO,EAAE,OAAO,MAAM,kBAKtD,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { translate } from "../../../utils/translation.js";
|
|
2
|
+
//#region src/forms/engine/rules/email.ts
|
|
3
|
+
var emailRegex = /(^$|^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$)/;
|
|
4
|
+
var emailRule = (value, label) => {
|
|
5
|
+
if (!emailRegex.test(String(value))) return translate("{attribute} must be a valid email address.", { attribute: label });
|
|
6
|
+
return null;
|
|
7
|
+
};
|
|
8
|
+
//#endregion
|
|
9
|
+
export { emailRule };
|
|
10
|
+
|
|
11
|
+
//# sourceMappingURL=email.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"email.js","names":[],"sources":["../../../../src/forms/engine/rules/email.ts"],"sourcesContent":["import { translate } from '@verbb/plugin-kit-react/utils/translation';\n\nconst emailRegex = /(^$|^(([^<>()[\\]\\\\.,;:\\s@\"]+(\\.[^<>()[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$)/;\n\nexport const emailRule = (value: unknown, label: string) => {\n if (!emailRegex.test(String(value))) {\n return translate('{attribute} must be a valid email address.', { attribute: label });\n }\n return null;\n};\n"],"mappings":";;AAEA,IAAM,aAAa;AAEnB,IAAa,aAAa,OAAgB,UAAkB;AACxD,KAAI,CAAC,WAAW,KAAK,OAAO,MAAM,CAAC,CAC/B,QAAO,UAAU,8CAA8C,EAAE,WAAW,OAAO,CAAC;AAExF,QAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"emailOrVariable.d.ts","sourceRoot":"","sources":["../../../../src/forms/engine/rules/emailOrVariable.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,mBAAmB,GAAI,OAAO,OAAO,EAAE,OAAO,MAAM,kBAMhE,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { translate } from "../../../utils/translation.js";
|
|
2
|
+
//#region src/forms/engine/rules/emailOrVariable.ts
|
|
3
|
+
var emailRegex = /(^$|^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$)/;
|
|
4
|
+
var variableRegex = /({.*?})/;
|
|
5
|
+
var emailOrVariableRule = (value, label) => {
|
|
6
|
+
const text = String(value);
|
|
7
|
+
if (!variableRegex.test(text) && !emailRegex.test(text)) return translate("{attribute} must be a valid email address or variable.", { attribute: label });
|
|
8
|
+
return null;
|
|
9
|
+
};
|
|
10
|
+
//#endregion
|
|
11
|
+
export { emailOrVariableRule };
|
|
12
|
+
|
|
13
|
+
//# sourceMappingURL=emailOrVariable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"emailOrVariable.js","names":[],"sources":["../../../../src/forms/engine/rules/emailOrVariable.ts"],"sourcesContent":["import { translate } from '@verbb/plugin-kit-react/utils/translation';\n\nconst emailRegex = /(^$|^(([^<>()[\\]\\\\.,;:\\s@\"]+(\\.[^<>()[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$)/;\nconst variableRegex = /({.*?})/;\n\nexport const emailOrVariableRule = (value: unknown, label: string) => {\n const text = String(value);\n if (!variableRegex.test(text) && !emailRegex.test(text)) {\n return translate('{attribute} must be a valid email address or variable.', { attribute: label });\n }\n return null;\n};\n"],"mappings":";;AAEA,IAAM,aAAa;AACnB,IAAM,gBAAgB;AAEtB,IAAa,uBAAuB,OAAgB,UAAkB;CAClE,MAAM,OAAO,OAAO,MAAM;AAC1B,KAAI,CAAC,cAAc,KAAK,KAAK,IAAI,CAAC,WAAW,KAAK,KAAK,CACnD,QAAO,UAAU,0DAA0D,EAAE,WAAW,OAAO,CAAC;AAEpG,QAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handle.d.ts","sourceRoot":"","sources":["../../../../src/forms/engine/rules/handle.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,UAAU,GAAI,OAAO,OAAO,kBAQxC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { translate } from "../../../utils/translation.js";
|
|
2
|
+
//#region src/forms/engine/rules/handle.ts
|
|
3
|
+
var handleRegex = /^[a-zA-Z][a-zA-Z0-9_]*$/;
|
|
4
|
+
var handleRule = (value) => {
|
|
5
|
+
const handle = String(value ?? "");
|
|
6
|
+
if (!handleRegex.test(handle)) return translate("“{handle}” isn’t a valid handle.", { handle });
|
|
7
|
+
return null;
|
|
8
|
+
};
|
|
9
|
+
//#endregion
|
|
10
|
+
export { handleRule };
|
|
11
|
+
|
|
12
|
+
//# sourceMappingURL=handle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handle.js","names":[],"sources":["../../../../src/forms/engine/rules/handle.ts"],"sourcesContent":["import { translate } from '@verbb/plugin-kit-react/utils/translation';\n\nconst handleRegex = /^[a-zA-Z][a-zA-Z0-9_]*$/;\n\nexport const handleRule = (value: unknown) => {\n const handle = String(value ?? '');\n\n if (!handleRegex.test(handle)) {\n return translate('“{handle}” isn’t a valid handle.', { handle });\n }\n\n return null;\n};\n"],"mappings":";;AAEA,IAAM,cAAc;AAEpB,IAAa,cAAc,UAAmB;CAC1C,MAAM,SAAS,OAAO,SAAS,GAAG;AAElC,KAAI,CAAC,YAAY,KAAK,OAAO,CACzB,QAAO,UAAU,oCAAoC,EAAE,QAAQ,CAAC;AAGpE,QAAO"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { SchemaNode } from '../SchemaIndex';
|
|
2
|
+
export type RuleHandlerContext = {
|
|
3
|
+
path: string;
|
|
4
|
+
values: Record<string, unknown>;
|
|
5
|
+
field: SchemaNode;
|
|
6
|
+
};
|
|
7
|
+
export type RuleHandler = (value: unknown, label: string, args: string[], context?: RuleHandlerContext) => string | null;
|
|
8
|
+
export declare const ruleHandlers: Record<string, RuleHandler>;
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/forms/engine/rules/index.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD,MAAM,MAAM,kBAAkB,GAAG;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,KAAK,EAAE,UAAU,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,OAAO,CAAC,EAAE,kBAAkB,KAAK,MAAM,GAAG,IAAI,CAAC;AAEzH,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAQpD,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { emailRule } from "./email.js";
|
|
2
|
+
import { emailOrVariableRule } from "./emailOrVariable.js";
|
|
3
|
+
import { handleRule } from "./handle.js";
|
|
4
|
+
import { maxRule } from "./max.js";
|
|
5
|
+
import { minRule } from "./min.js";
|
|
6
|
+
import { requiredRule } from "./required.js";
|
|
7
|
+
import { uniqueHandleRule } from "./uniqueHandle.js";
|
|
8
|
+
//#region src/forms/engine/rules/index.ts
|
|
9
|
+
var ruleHandlers = {
|
|
10
|
+
required: (value, label) => {
|
|
11
|
+
return requiredRule(value, label);
|
|
12
|
+
},
|
|
13
|
+
min: (value, label, args) => {
|
|
14
|
+
return minRule(value, label, args);
|
|
15
|
+
},
|
|
16
|
+
max: (value, label, args) => {
|
|
17
|
+
return maxRule(value, label, args);
|
|
18
|
+
},
|
|
19
|
+
email: (value, label) => {
|
|
20
|
+
return emailRule(value, label);
|
|
21
|
+
},
|
|
22
|
+
emailOrVariable: (value, label) => {
|
|
23
|
+
return emailOrVariableRule(value, label);
|
|
24
|
+
},
|
|
25
|
+
handle: (value) => {
|
|
26
|
+
return handleRule(value);
|
|
27
|
+
},
|
|
28
|
+
uniqueHandle: (value, label, args, context) => {
|
|
29
|
+
return uniqueHandleRule(value, label, args, context);
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
//#endregion
|
|
33
|
+
export { ruleHandlers };
|
|
34
|
+
|
|
35
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../../../../src/forms/engine/rules/index.ts"],"sourcesContent":["import { emailRule } from './email';\nimport { emailOrVariableRule } from './emailOrVariable';\nimport { handleRule } from './handle';\nimport { maxRule } from './max';\nimport { minRule } from './min';\nimport { requiredRule } from './required';\nimport { uniqueHandleRule } from './uniqueHandle';\n\nimport type { SchemaNode } from '../SchemaIndex';\n\nexport type RuleHandlerContext = {\n path: string;\n values: Record<string, unknown>;\n field: SchemaNode;\n};\n\nexport type RuleHandler = (value: unknown, label: string, args: string[], context?: RuleHandlerContext) => string | null;\n\nexport const ruleHandlers: Record<string, RuleHandler> = {\n required: (value, label) => { return requiredRule(value, label); },\n min: (value, label, args) => { return minRule(value, label, args); },\n max: (value, label, args) => { return maxRule(value, label, args); },\n email: (value, label) => { return emailRule(value, label); },\n emailOrVariable: (value, label) => { return emailOrVariableRule(value, label); },\n handle: (value) => { return handleRule(value); },\n uniqueHandle: (value, label, args, context) => { return uniqueHandleRule(value, label, args, context); },\n};\n"],"mappings":";;;;;;;;AAkBA,IAAa,eAA4C;CACrD,WAAW,OAAO,UAAU;AAAE,SAAO,aAAa,OAAO,MAAM;;CAC/D,MAAM,OAAO,OAAO,SAAS;AAAE,SAAO,QAAQ,OAAO,OAAO,KAAK;;CACjE,MAAM,OAAO,OAAO,SAAS;AAAE,SAAO,QAAQ,OAAO,OAAO,KAAK;;CACjE,QAAQ,OAAO,UAAU;AAAE,SAAO,UAAU,OAAO,MAAM;;CACzD,kBAAkB,OAAO,UAAU;AAAE,SAAO,oBAAoB,OAAO,MAAM;;CAC7E,SAAS,UAAU;AAAE,SAAO,WAAW,MAAM;;CAC7C,eAAe,OAAO,OAAO,MAAM,YAAY;AAAE,SAAO,iBAAiB,OAAO,OAAO,MAAM,QAAQ;;CACxG"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"max.d.ts","sourceRoot":"","sources":["../../../../src/forms/engine/rules/max.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,OAAO,GAAI,OAAO,OAAO,EAAE,OAAO,MAAM,EAAE,MAAM,MAAM,EAAE,kBAOpE,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { translate } from "../../../utils/translation.js";
|
|
2
|
+
import { getValueSize } from "./utils.js";
|
|
3
|
+
//#region src/forms/engine/rules/max.ts
|
|
4
|
+
var maxRule = (value, label, args) => {
|
|
5
|
+
const max = Number(args[0]);
|
|
6
|
+
const size = getValueSize(value);
|
|
7
|
+
if (!Number.isFinite(size) || size > max) return translate("{attribute} must be at most {max}.", {
|
|
8
|
+
attribute: label,
|
|
9
|
+
max: String(args[0])
|
|
10
|
+
});
|
|
11
|
+
return null;
|
|
12
|
+
};
|
|
13
|
+
//#endregion
|
|
14
|
+
export { maxRule };
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=max.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"max.js","names":[],"sources":["../../../../src/forms/engine/rules/max.ts"],"sourcesContent":["import { translate } from '@verbb/plugin-kit-react/utils/translation';\nimport { getValueSize } from './utils';\n\nexport const maxRule = (value: unknown, label: string, args: string[]) => {\n const max = Number(args[0]);\n const size = getValueSize(value);\n if (!Number.isFinite(size) || size > max) {\n return translate('{attribute} must be at most {max}.', { attribute: label, max: String(args[0]) });\n }\n return null;\n};\n"],"mappings":";;;AAGA,IAAa,WAAW,OAAgB,OAAe,SAAmB;CACtE,MAAM,MAAM,OAAO,KAAK,GAAG;CAC3B,MAAM,OAAO,aAAa,MAAM;AAChC,KAAI,CAAC,OAAO,SAAS,KAAK,IAAI,OAAO,IACjC,QAAO,UAAU,sCAAsC;EAAE,WAAW;EAAO,KAAK,OAAO,KAAK,GAAG;EAAE,CAAC;AAEtG,QAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"min.d.ts","sourceRoot":"","sources":["../../../../src/forms/engine/rules/min.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,OAAO,GAAI,OAAO,OAAO,EAAE,OAAO,MAAM,EAAE,MAAM,MAAM,EAAE,kBAOpE,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { translate } from "../../../utils/translation.js";
|
|
2
|
+
import { getValueSize } from "./utils.js";
|
|
3
|
+
//#region src/forms/engine/rules/min.ts
|
|
4
|
+
var minRule = (value, label, args) => {
|
|
5
|
+
const min = Number(args[0]);
|
|
6
|
+
const size = getValueSize(value);
|
|
7
|
+
if (!Number.isFinite(size) || size < min) return translate("{attribute} must be at least {min}.", {
|
|
8
|
+
attribute: label,
|
|
9
|
+
min: String(args[0])
|
|
10
|
+
});
|
|
11
|
+
return null;
|
|
12
|
+
};
|
|
13
|
+
//#endregion
|
|
14
|
+
export { minRule };
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=min.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"min.js","names":[],"sources":["../../../../src/forms/engine/rules/min.ts"],"sourcesContent":["import { translate } from '@verbb/plugin-kit-react/utils/translation';\nimport { getValueSize } from './utils';\n\nexport const minRule = (value: unknown, label: string, args: string[]) => {\n const min = Number(args[0]);\n const size = getValueSize(value);\n if (!Number.isFinite(size) || size < min) {\n return translate('{attribute} must be at least {min}.', { attribute: label, min: String(args[0]) });\n }\n return null;\n};\n"],"mappings":";;;AAGA,IAAa,WAAW,OAAgB,OAAe,SAAmB;CACtE,MAAM,MAAM,OAAO,KAAK,GAAG;CAC3B,MAAM,OAAO,aAAa,MAAM;AAChC,KAAI,CAAC,OAAO,SAAS,KAAK,IAAI,OAAO,IACjC,QAAO,UAAU,uCAAuC;EAAE,WAAW;EAAO,KAAK,OAAO,KAAK,GAAG;EAAE,CAAC;AAEvG,QAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"required.d.ts","sourceRoot":"","sources":["../../../../src/forms/engine/rules/required.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,YAAY,GAAI,OAAO,OAAO,EAAE,OAAO,MAAM,kBAKzD,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { translate } from "../../../utils/translation.js";
|
|
2
|
+
import { isEmptyValue } from "./utils.js";
|
|
3
|
+
//#region src/forms/engine/rules/required.ts
|
|
4
|
+
var requiredRule = (value, label) => {
|
|
5
|
+
if (isEmptyValue(value)) return translate("{attribute} cannot be blank.", { attribute: label });
|
|
6
|
+
return null;
|
|
7
|
+
};
|
|
8
|
+
//#endregion
|
|
9
|
+
export { requiredRule };
|
|
10
|
+
|
|
11
|
+
//# sourceMappingURL=required.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"required.js","names":[],"sources":["../../../../src/forms/engine/rules/required.ts"],"sourcesContent":["import { translate } from '@verbb/plugin-kit-react/utils/translation';\nimport { isEmptyValue } from './utils';\n\nexport const requiredRule = (value: unknown, label: string) => {\n if (isEmptyValue(value)) {\n return translate('{attribute} cannot be blank.', { attribute: label });\n }\n return null;\n};\n"],"mappings":";;;AAGA,IAAa,gBAAgB,OAAgB,UAAkB;AAC3D,KAAI,aAAa,MAAM,CACnB,QAAO,UAAU,gCAAgC,EAAE,WAAW,OAAO,CAAC;AAE1E,QAAO"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { SchemaNode } from '../SchemaIndex';
|
|
2
|
+
type RuleContext = {
|
|
3
|
+
path: string;
|
|
4
|
+
values: Record<string, unknown>;
|
|
5
|
+
field: SchemaNode;
|
|
6
|
+
};
|
|
7
|
+
export declare const uniqueHandleRule: (value: unknown, label: string, args: string[], context?: RuleContext) => string | null;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=uniqueHandle.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"uniqueHandle.d.ts","sourceRoot":"","sources":["../../../../src/forms/engine/rules/uniqueHandle.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEjD,KAAK,WAAW,GAAG;IACf,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,KAAK,EAAE,UAAU,CAAC;CACrB,CAAC;AA+HF,eAAO,MAAM,gBAAgB,GAAI,OAAO,OAAO,EAAE,OAAO,MAAM,EAAE,MAAM,MAAM,EAAE,EAAE,UAAU,WAAW,kBAmCpG,CAAC"}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { translate } from "../../../utils/translation.js";
|
|
2
|
+
import { get } from "lodash-es";
|
|
3
|
+
//#region src/forms/engine/rules/uniqueHandle.ts
|
|
4
|
+
var isRecord = (value) => {
|
|
5
|
+
return Boolean(value) && typeof value === "object" && !Array.isArray(value);
|
|
6
|
+
};
|
|
7
|
+
var getHandleValue = (value) => {
|
|
8
|
+
if (!isRecord(value)) return "";
|
|
9
|
+
const settings = isRecord(value.settings) ? value.settings : {};
|
|
10
|
+
return String(value.handle || settings.handle || "").trim();
|
|
11
|
+
};
|
|
12
|
+
var collectTopLevelFieldHandles = (values) => {
|
|
13
|
+
const entries = [];
|
|
14
|
+
(Array.isArray(values?.pages) ? values.pages : []).forEach((page, pageIndex) => {
|
|
15
|
+
(Array.isArray(page?.rows) ? page.rows : []).forEach((row, rowIndex) => {
|
|
16
|
+
(Array.isArray(row?.fields) ? row.fields : []).forEach((field, fieldIndex) => {
|
|
17
|
+
const handle = getHandleValue(field);
|
|
18
|
+
if (!handle) return;
|
|
19
|
+
entries.push({
|
|
20
|
+
path: `pages.${pageIndex}.rows.${rowIndex}.fields.${fieldIndex}.handle`,
|
|
21
|
+
handle
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
return entries;
|
|
27
|
+
};
|
|
28
|
+
var collectNestedFieldHandles = (values, parentFieldPath) => {
|
|
29
|
+
const entries = [];
|
|
30
|
+
const rows = get(values, `${parentFieldPath}.rows`, []);
|
|
31
|
+
(Array.isArray(rows) ? rows : []).forEach((row, nestedRowIndex) => {
|
|
32
|
+
(Array.isArray(row?.fields) ? row.fields : []).forEach((field, nestedFieldIndex) => {
|
|
33
|
+
const handle = getHandleValue(field);
|
|
34
|
+
if (!handle) return;
|
|
35
|
+
entries.push({
|
|
36
|
+
path: `${parentFieldPath}.rows.${nestedRowIndex}.fields.${nestedFieldIndex}.handle`,
|
|
37
|
+
handle
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
return entries;
|
|
42
|
+
};
|
|
43
|
+
var collectNotificationHandles = (values) => {
|
|
44
|
+
const entries = [];
|
|
45
|
+
(Array.isArray(values?.notifications) ? values.notifications : []).forEach((notification, index) => {
|
|
46
|
+
const handle = String(notification?.handle || "").trim();
|
|
47
|
+
if (!handle) return;
|
|
48
|
+
entries.push({
|
|
49
|
+
path: `notifications.${index}.handle`,
|
|
50
|
+
handle
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
return entries;
|
|
54
|
+
};
|
|
55
|
+
var getScopedHandleEntries = (context) => {
|
|
56
|
+
const { path, values } = context;
|
|
57
|
+
const explicitScope = context?.field?.uniqueHandleScope;
|
|
58
|
+
if (explicitScope === "topLevelFields") return collectTopLevelFieldHandles(values);
|
|
59
|
+
if (explicitScope === "notifications") return collectNotificationHandles(values);
|
|
60
|
+
if (explicitScope === "nestedSiblings") {
|
|
61
|
+
const parentFieldPath = context?.field?.uniqueHandleScopePath;
|
|
62
|
+
if (typeof parentFieldPath === "string" && parentFieldPath.trim() !== "") return collectNestedFieldHandles(values, parentFieldPath);
|
|
63
|
+
}
|
|
64
|
+
const nestedMatch = path.match(/^(pages\.\d+\.rows\.\d+\.fields\.\d+(?:\.rows\.\d+\.fields\.\d+)*)\.rows\.\d+\.fields\.\d+\.handle$/);
|
|
65
|
+
if (nestedMatch) {
|
|
66
|
+
const [, parentFieldPath] = nestedMatch;
|
|
67
|
+
return collectNestedFieldHandles(values, parentFieldPath);
|
|
68
|
+
}
|
|
69
|
+
if (/^pages\.\d+\.rows\.\d+\.fields\.\d+\.handle$/.test(path)) return collectTopLevelFieldHandles(values);
|
|
70
|
+
if (/^notifications\.\d+\.handle$/.test(path)) return collectNotificationHandles(values);
|
|
71
|
+
return [];
|
|
72
|
+
};
|
|
73
|
+
var uniqueHandleRule = (value, label, args, context) => {
|
|
74
|
+
if (!context?.path || !context?.values) return null;
|
|
75
|
+
const handle = String(value ?? "").trim();
|
|
76
|
+
if (!handle) return null;
|
|
77
|
+
const entries = getScopedHandleEntries(context);
|
|
78
|
+
const normalizedHandle = handle.toLowerCase();
|
|
79
|
+
const scopedDuplicate = entries.some((entry) => {
|
|
80
|
+
if (entry.path === context.path) return false;
|
|
81
|
+
return entry.handle.toLowerCase() === normalizedHandle;
|
|
82
|
+
});
|
|
83
|
+
const reservedDuplicate = (Array.isArray(context.field?.reservedHandles) ? context.field.reservedHandles : []).some((reservedHandle) => {
|
|
84
|
+
return String(reservedHandle || "").toLowerCase() === normalizedHandle;
|
|
85
|
+
});
|
|
86
|
+
if (!(scopedDuplicate || reservedDuplicate)) return null;
|
|
87
|
+
return translate("{attribute} \"{value}\" has already been taken.", {
|
|
88
|
+
attribute: label,
|
|
89
|
+
value: handle
|
|
90
|
+
});
|
|
91
|
+
};
|
|
92
|
+
//#endregion
|
|
93
|
+
export { uniqueHandleRule };
|
|
94
|
+
|
|
95
|
+
//# sourceMappingURL=uniqueHandle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"uniqueHandle.js","names":[],"sources":["../../../../src/forms/engine/rules/uniqueHandle.ts"],"sourcesContent":["import { get } from 'lodash-es';\nimport { translate } from '@verbb/plugin-kit-react/utils/translation';\nimport type { SchemaNode } from '../SchemaIndex';\n\ntype RuleContext = {\n path: string;\n values: Record<string, unknown>;\n field: SchemaNode;\n};\n\ntype HandleEntry = {\n path: string;\n handle: string;\n};\n\nconst isRecord = (value: unknown): value is Record<string, unknown> => {\n return Boolean(value) && typeof value === 'object' && !Array.isArray(value);\n};\n\nconst getHandleValue = (value: unknown) => {\n if (!isRecord(value)) {\n return '';\n }\n\n const settings = isRecord(value.settings) ? value.settings : {};\n return String(value.handle || settings.handle || '').trim();\n};\n\nconst collectTopLevelFieldHandles = (values: Record<string, unknown>) => {\n const entries: HandleEntry[] = [];\n const pages = Array.isArray(values?.pages) ? values.pages : [];\n\n pages.forEach((page, pageIndex) => {\n const rows = Array.isArray(page?.rows) ? page.rows : [];\n\n rows.forEach((row, rowIndex) => {\n const fields = Array.isArray(row?.fields) ? row.fields : [];\n\n fields.forEach((field, fieldIndex) => {\n const handle = getHandleValue(field);\n if (!handle) {\n return;\n }\n\n entries.push({\n path: `pages.${pageIndex}.rows.${rowIndex}.fields.${fieldIndex}.handle`,\n handle,\n });\n });\n });\n });\n\n return entries;\n};\n\nconst collectNestedFieldHandles = (values: Record<string, unknown>, parentFieldPath: string) => {\n const entries: HandleEntry[] = [];\n const rows = get(values, `${parentFieldPath}.rows`, []);\n const nestedRows = Array.isArray(rows) ? rows : [];\n\n nestedRows.forEach((row, nestedRowIndex) => {\n const fields = Array.isArray(row?.fields) ? row.fields : [];\n\n fields.forEach((field, nestedFieldIndex) => {\n const handle = getHandleValue(field);\n if (!handle) {\n return;\n }\n\n entries.push({\n path: `${parentFieldPath}.rows.${nestedRowIndex}.fields.${nestedFieldIndex}.handle`,\n handle,\n });\n });\n });\n\n return entries;\n};\n\nconst collectNotificationHandles = (values: Record<string, unknown>) => {\n const entries: HandleEntry[] = [];\n const notifications = Array.isArray(values?.notifications) ? values.notifications : [];\n\n notifications.forEach((notification, index) => {\n const handle = String(notification?.handle || '').trim();\n if (!handle) {\n return;\n }\n\n entries.push({\n path: `notifications.${index}.handle`,\n handle,\n });\n });\n\n return entries;\n};\n\nconst getScopedHandleEntries = (context: RuleContext) => {\n const { path, values } = context;\n const explicitScope = context?.field?.uniqueHandleScope;\n\n if (explicitScope === 'topLevelFields') {\n return collectTopLevelFieldHandles(values);\n }\n\n if (explicitScope === 'notifications') {\n return collectNotificationHandles(values);\n }\n\n if (explicitScope === 'nestedSiblings') {\n const parentFieldPath = context?.field?.uniqueHandleScopePath;\n\n if (typeof parentFieldPath === 'string' && parentFieldPath.trim() !== '') {\n return collectNestedFieldHandles(values, parentFieldPath);\n }\n }\n\n const nestedMatch = path.match(/^(pages\\.\\d+\\.rows\\.\\d+\\.fields\\.\\d+(?:\\.rows\\.\\d+\\.fields\\.\\d+)*)\\.rows\\.\\d+\\.fields\\.\\d+\\.handle$/);\n if (nestedMatch) {\n const [, parentFieldPath] = nestedMatch;\n return collectNestedFieldHandles(values, parentFieldPath);\n }\n\n if (/^pages\\.\\d+\\.rows\\.\\d+\\.fields\\.\\d+\\.handle$/.test(path)) {\n return collectTopLevelFieldHandles(values);\n }\n\n if (/^notifications\\.\\d+\\.handle$/.test(path)) {\n return collectNotificationHandles(values);\n }\n\n return [];\n};\n\nexport const uniqueHandleRule = (value: unknown, label: string, args: string[], context?: RuleContext) => {\n if (!context?.path || !context?.values) {\n return null;\n }\n\n const handle = String(value ?? '').trim();\n if (!handle) {\n return null;\n }\n\n const entries = getScopedHandleEntries(context);\n const normalizedHandle = handle.toLowerCase();\n const scopedDuplicate = entries.some((entry) => {\n if (entry.path === context.path) {\n return false;\n }\n\n return entry.handle.toLowerCase() === normalizedHandle;\n });\n\n const reservedHandles = Array.isArray(context.field?.reservedHandles) ? context.field.reservedHandles : [];\n const reservedDuplicate = reservedHandles.some((reservedHandle) => {\n return String(reservedHandle || '').toLowerCase() === normalizedHandle;\n });\n\n const duplicate = scopedDuplicate || reservedDuplicate;\n\n if (!duplicate) {\n return null;\n }\n\n return translate('{attribute} \"{value}\" has already been taken.', {\n attribute: label,\n value: handle,\n });\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/forms/engine/rules/utils.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,YAAY,GAAI,OAAO,OAAO,YAc1C,CAAC;AAEF,eAAO,MAAM,YAAY,GAAI,OAAO,OAAO,WAmB1C,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
//#region src/forms/engine/rules/utils.ts
|
|
2
|
+
var isEmptyValue = (value) => {
|
|
3
|
+
if (value === void 0 || value === null) return true;
|
|
4
|
+
if (typeof value === "string") return value === "";
|
|
5
|
+
if (Array.isArray(value)) return value.length === 0;
|
|
6
|
+
return false;
|
|
7
|
+
};
|
|
8
|
+
var getValueSize = (value) => {
|
|
9
|
+
if (typeof value === "number") return value;
|
|
10
|
+
if (typeof value === "string") {
|
|
11
|
+
const trimmed = value.trim();
|
|
12
|
+
if (trimmed !== "" && Number.isFinite(Number(trimmed))) return Number(trimmed);
|
|
13
|
+
return value.length;
|
|
14
|
+
}
|
|
15
|
+
if (Array.isArray(value)) return value.length;
|
|
16
|
+
return NaN;
|
|
17
|
+
};
|
|
18
|
+
//#endregion
|
|
19
|
+
export { getValueSize, isEmptyValue };
|
|
20
|
+
|
|
21
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","names":[],"sources":["../../../../src/forms/engine/rules/utils.ts"],"sourcesContent":["export const isEmptyValue = (value: unknown) => {\n if (value === undefined || value === null) {\n return true;\n }\n\n if (typeof value === 'string') {\n return value === '';\n }\n\n if (Array.isArray(value)) {\n return value.length === 0;\n }\n\n return false;\n};\n\nexport const getValueSize = (value: unknown) => {\n if (typeof value === 'number') {\n return value;\n }\n\n if (typeof value === 'string') {\n const trimmed = value.trim();\n if (trimmed !== '' && Number.isFinite(Number(trimmed))) {\n return Number(trimmed);\n }\n\n return value.length;\n }\n\n if (Array.isArray(value)) {\n return value.length;\n }\n\n return NaN;\n};\n"],"mappings":";AAAA,IAAa,gBAAgB,UAAmB;AAC5C,KAAI,UAAU,KAAA,KAAa,UAAU,KACjC,QAAO;AAGX,KAAI,OAAO,UAAU,SACjB,QAAO,UAAU;AAGrB,KAAI,MAAM,QAAQ,MAAM,CACpB,QAAO,MAAM,WAAW;AAG5B,QAAO;;AAGX,IAAa,gBAAgB,UAAmB;AAC5C,KAAI,OAAO,UAAU,SACjB,QAAO;AAGX,KAAI,OAAO,UAAU,UAAU;EAC3B,MAAM,UAAU,MAAM,MAAM;AAC5B,MAAI,YAAY,MAAM,OAAO,SAAS,OAAO,QAAQ,CAAC,CAClD,QAAO,OAAO,QAAQ;AAG1B,SAAO,MAAM;;AAGjB,KAAI,MAAM,QAAQ,MAAM,CACpB,QAAO,MAAM;AAGjB,QAAO"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { VariableCategories } from '../../components/tiptap/VariableDropdown';
|
|
2
|
+
import { SchemaFormEngineApi } from '../engine/context';
|
|
3
|
+
import { SchemaNode } from '../engine/SchemaIndex';
|
|
4
|
+
import { VariableConfig } from '../contexts/VariableCategoriesContext';
|
|
5
|
+
type CalculationsFieldProps = {
|
|
6
|
+
form: SchemaFormEngineApi;
|
|
7
|
+
field: SchemaNode & {
|
|
8
|
+
name: string;
|
|
9
|
+
label?: string;
|
|
10
|
+
instructions?: string;
|
|
11
|
+
warning?: string;
|
|
12
|
+
placeholder?: string;
|
|
13
|
+
required?: boolean;
|
|
14
|
+
disabled?: boolean;
|
|
15
|
+
variableConfig?: VariableConfig;
|
|
16
|
+
variableCategories?: VariableCategories;
|
|
17
|
+
variablePickerTriggerCharacters?: string[];
|
|
18
|
+
validationAction?: string;
|
|
19
|
+
rows?: number;
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
export declare const CalculationsField: ({ form, field }: CalculationsFieldProps) => import("react/jsx-runtime").JSX.Element;
|
|
23
|
+
export {};
|
|
24
|
+
//# sourceMappingURL=CalculationsField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CalculationsField.d.ts","sourceRoot":"","sources":["../../../src/forms/fields/CalculationsField.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,kBAAkB,EAAkB,MAAM,4DAA4D,CAAC;AAKrH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AAU5E,KAAK,sBAAsB,GAAG;IAC1B,IAAI,EAAE,mBAAmB,CAAC;IAC1B,KAAK,EAAE,UAAU,GAAG;QAChB,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,cAAc,CAAC,EAAE,cAAc,CAAC;QAChC,kBAAkB,CAAC,EAAE,kBAAkB,CAAC;QACxC,+BAA+B,CAAC,EAAE,MAAM,EAAE,CAAC;QAC3C,gBAAgB,CAAC,EAAE,MAAM,CAAC;QAC1B,IAAI,CAAC,EAAE,MAAM,CAAC;KACjB,CAAC;CACL,CAAC;AAyIF,eAAO,MAAM,iBAAiB,GAAI,iBAAiB,sBAAsB,4CAsJxE,CAAC"}
|