@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,215 @@
|
|
|
1
|
+
import { cn } from "../../utils/classes.js";
|
|
2
|
+
import { hostRequest } from "../../utils/hostBridge.js";
|
|
3
|
+
import "../../utils/index.js";
|
|
4
|
+
import { useTranslation } from "../../hooks/useTranslation.js";
|
|
5
|
+
import "../../hooks/index.js";
|
|
6
|
+
import { contentToValue } from "../../components/tiptap/variableSerialization.js";
|
|
7
|
+
import { TiptapEditor } from "../../components/TiptapEditor.js";
|
|
8
|
+
import "../../components/index.js";
|
|
9
|
+
import { FieldLayout } from "../Field.js";
|
|
10
|
+
import { useEngineField } from "../useEngineField.js";
|
|
11
|
+
import { useVariableCategoriesContext } from "../contexts/VariableCategoriesContext.js";
|
|
12
|
+
import { CalculationsToolbar } from "./CalculationsToolbar.js";
|
|
13
|
+
import { useMemo, useState } from "react";
|
|
14
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
15
|
+
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
|
|
16
|
+
import { faCheck } from "@fortawesome/pro-solid-svg-icons";
|
|
17
|
+
//#region src/forms/fields/CalculationsField.tsx
|
|
18
|
+
var flattenVariableOptions = (options = []) => {
|
|
19
|
+
const flat = [];
|
|
20
|
+
const visit = (nodes) => {
|
|
21
|
+
nodes.forEach((node) => {
|
|
22
|
+
flat.push(node);
|
|
23
|
+
if (Array.isArray(node?.children) && node.children.length) visit(node.children);
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
visit(options);
|
|
27
|
+
return flat;
|
|
28
|
+
};
|
|
29
|
+
var getAvailableVariableTokens = (variableCategories) => {
|
|
30
|
+
const flat = flattenVariableOptions(Object.values(variableCategories ?? {}).flatMap((items) => {
|
|
31
|
+
return Array.isArray(items) ? items : [];
|
|
32
|
+
}));
|
|
33
|
+
return Array.from(new Set(flat.map((item) => {
|
|
34
|
+
return typeof item?.value === "string" ? item.value.trim() : "";
|
|
35
|
+
}).filter(Boolean)));
|
|
36
|
+
};
|
|
37
|
+
var getVariableTokenLabelMap = (variableCategories) => {
|
|
38
|
+
return flattenVariableOptions(Object.values(variableCategories ?? {}).flatMap((items) => {
|
|
39
|
+
return Array.isArray(items) ? items : [];
|
|
40
|
+
})).reduce((map, item) => {
|
|
41
|
+
const token = typeof item?.value === "string" ? item.value.trim() : "";
|
|
42
|
+
if (!token) return map;
|
|
43
|
+
map[token] = (typeof item?.label === "string" ? item.label.trim() : "") || token;
|
|
44
|
+
return map;
|
|
45
|
+
}, {});
|
|
46
|
+
};
|
|
47
|
+
var getFormulaFromValue = (value) => {
|
|
48
|
+
if (typeof value === "string") return value;
|
|
49
|
+
if (Array.isArray(value)) return contentToValue(value);
|
|
50
|
+
if (value && typeof value === "object" && Array.isArray(value.content)) return contentToValue(value.content);
|
|
51
|
+
return "";
|
|
52
|
+
};
|
|
53
|
+
var getPageIndexFromScopePath = (scopePathValue) => {
|
|
54
|
+
const scopePath = typeof scopePathValue === "string" ? scopePathValue : "";
|
|
55
|
+
if (!scopePath) return null;
|
|
56
|
+
const match = scopePath.match(/(?:^|\\.)pages\\.(\\d+)(?:\\.|$)/);
|
|
57
|
+
if (!match) return null;
|
|
58
|
+
const pageIndex = Number.parseInt(match[1] || "", 10);
|
|
59
|
+
return Number.isInteger(pageIndex) ? pageIndex : null;
|
|
60
|
+
};
|
|
61
|
+
var getActivePageIndex = (pages, activePage) => {
|
|
62
|
+
if (!Array.isArray(pages) || !pages.length || typeof activePage !== "string" || !activePage) return null;
|
|
63
|
+
const pageIndex = pages.findIndex((page) => {
|
|
64
|
+
const resolvedPage = page && typeof page === "object" ? page : {};
|
|
65
|
+
return resolvedPage._handle === activePage || resolvedPage.handle === activePage;
|
|
66
|
+
});
|
|
67
|
+
return pageIndex >= 0 ? pageIndex : null;
|
|
68
|
+
};
|
|
69
|
+
var getValidationErrorDetails = (error, fallbackMessage) => {
|
|
70
|
+
const resolvedError = error && typeof error === "object" ? error : {};
|
|
71
|
+
const responseData = resolvedError.response?.data;
|
|
72
|
+
const message = responseData?.message || resolvedError.message || fallbackMessage;
|
|
73
|
+
return {
|
|
74
|
+
message: String(message),
|
|
75
|
+
technicalMessage: String(responseData?.technicalMessage ?? "")
|
|
76
|
+
};
|
|
77
|
+
};
|
|
78
|
+
var CalculationsField = ({ form, field }) => {
|
|
79
|
+
const t = useTranslation();
|
|
80
|
+
const { value, setValue, errors } = useEngineField(form, field.name);
|
|
81
|
+
const [guideOpen, setGuideOpen] = useState(false);
|
|
82
|
+
const [validating, setValidating] = useState(false);
|
|
83
|
+
const [validation, setValidation] = useState({
|
|
84
|
+
type: "idle",
|
|
85
|
+
message: ""
|
|
86
|
+
});
|
|
87
|
+
const { getVariableCategories, variableCategoryLabels, variableCategoryOrder, variableTransformerRegistry } = useVariableCategoriesContext();
|
|
88
|
+
const resolvedVariableCategories = useMemo(() => {
|
|
89
|
+
if (field.variableCategories) return field.variableCategories;
|
|
90
|
+
const { variableConfig } = field;
|
|
91
|
+
if (!variableConfig || !getVariableCategories) return;
|
|
92
|
+
const pages = form?.getFieldValue?.("pages");
|
|
93
|
+
const activePage = form?.getFieldValue?.("activePage");
|
|
94
|
+
const scopePageIndex = getPageIndexFromScopePath(field._scopePath);
|
|
95
|
+
const activePageIndex = getActivePageIndex(pages, activePage);
|
|
96
|
+
const currentPageIndex = Number.isInteger(scopePageIndex) ? scopePageIndex : activePageIndex;
|
|
97
|
+
return getVariableCategories({
|
|
98
|
+
...variableConfig,
|
|
99
|
+
...Number.isInteger(currentPageIndex) ? { currentPageIndex } : {}
|
|
100
|
+
}, { form });
|
|
101
|
+
}, [
|
|
102
|
+
field,
|
|
103
|
+
form,
|
|
104
|
+
getVariableCategories
|
|
105
|
+
]);
|
|
106
|
+
const availableVariableTokens = useMemo(() => {
|
|
107
|
+
return getAvailableVariableTokens(resolvedVariableCategories);
|
|
108
|
+
}, [resolvedVariableCategories]);
|
|
109
|
+
const tokenLabels = useMemo(() => {
|
|
110
|
+
return getVariableTokenLabelMap(resolvedVariableCategories);
|
|
111
|
+
}, [resolvedVariableCategories]);
|
|
112
|
+
const runValidation = async () => {
|
|
113
|
+
const formula = getFormulaFromValue(value).trim();
|
|
114
|
+
if (!formula) {
|
|
115
|
+
setValidation({
|
|
116
|
+
type: "error",
|
|
117
|
+
message: t("Enter a formula to test.")
|
|
118
|
+
});
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
setValidating(true);
|
|
122
|
+
setValidation({
|
|
123
|
+
type: "idle",
|
|
124
|
+
message: "",
|
|
125
|
+
technicalMessage: ""
|
|
126
|
+
});
|
|
127
|
+
try {
|
|
128
|
+
const response = await hostRequest("POST", field.validationAction || "plugin-kit/fields/validate-calculations-formula", { data: {
|
|
129
|
+
formula,
|
|
130
|
+
availableTokens: availableVariableTokens,
|
|
131
|
+
tokenLabels
|
|
132
|
+
} });
|
|
133
|
+
const payload = response?.data ?? response;
|
|
134
|
+
const isValid = Boolean(payload?.valid);
|
|
135
|
+
const message = String(payload?.message ?? "");
|
|
136
|
+
const technicalMessage = String(payload?.technicalMessage ?? "");
|
|
137
|
+
setValidation({
|
|
138
|
+
type: isValid ? "success" : "error",
|
|
139
|
+
message: message || (isValid ? t("Formula is valid.") : t("Formula is invalid.")),
|
|
140
|
+
technicalMessage
|
|
141
|
+
});
|
|
142
|
+
} catch (error) {
|
|
143
|
+
const { message, technicalMessage } = getValidationErrorDetails(error, t("Unable to validate formula."));
|
|
144
|
+
setValidation({
|
|
145
|
+
type: "error",
|
|
146
|
+
message: String(message),
|
|
147
|
+
technicalMessage
|
|
148
|
+
});
|
|
149
|
+
} finally {
|
|
150
|
+
setValidating(false);
|
|
151
|
+
}
|
|
152
|
+
};
|
|
153
|
+
return /* @__PURE__ */ jsx(FieldLayout, {
|
|
154
|
+
name: field.name,
|
|
155
|
+
label: field.label,
|
|
156
|
+
instructions: field.instructions,
|
|
157
|
+
warning: field.warning,
|
|
158
|
+
required: field.required,
|
|
159
|
+
errors,
|
|
160
|
+
withControl: false,
|
|
161
|
+
children: /* @__PURE__ */ jsxs("div", {
|
|
162
|
+
className: "space-y-2",
|
|
163
|
+
children: [/* @__PURE__ */ jsx(TiptapEditor, {
|
|
164
|
+
value: value ?? "",
|
|
165
|
+
onChange: setValue,
|
|
166
|
+
placeholder: field.placeholder,
|
|
167
|
+
rows: field.rows,
|
|
168
|
+
buttons: ["variableTag"],
|
|
169
|
+
toolbarContent: ({ editor, variableCategories, variableCategoryLabels, variableCategoryOrder, variablePickerOpen, onVariablePickerOpenChange }) => {
|
|
170
|
+
return /* @__PURE__ */ jsx(CalculationsToolbar, {
|
|
171
|
+
editor,
|
|
172
|
+
variableCategories,
|
|
173
|
+
variableCategoryLabels,
|
|
174
|
+
variableCategoryOrder,
|
|
175
|
+
variablePickerOpen,
|
|
176
|
+
onVariablePickerOpenChange,
|
|
177
|
+
guideOpen,
|
|
178
|
+
onGuideOpenChange: setGuideOpen,
|
|
179
|
+
validating,
|
|
180
|
+
onValidate: runValidation
|
|
181
|
+
});
|
|
182
|
+
},
|
|
183
|
+
disabled: field.disabled,
|
|
184
|
+
isInvalid: errors.length > 0,
|
|
185
|
+
variableCategories: resolvedVariableCategories,
|
|
186
|
+
variableCategoryLabels,
|
|
187
|
+
variableCategoryOrder,
|
|
188
|
+
variableTransformerRegistry,
|
|
189
|
+
variablePickerTriggerCharacters: field.variablePickerTriggerCharacters
|
|
190
|
+
}), validation.type !== "idle" && /* @__PURE__ */ jsxs("div", {
|
|
191
|
+
className: "space-y-1",
|
|
192
|
+
children: [/* @__PURE__ */ jsxs("p", {
|
|
193
|
+
className: cn("flex items-center gap-1", validation.type === "success" ? "text-emerald-700" : "text-rose-700"),
|
|
194
|
+
children: [validation.type === "success" ? /* @__PURE__ */ jsx(FontAwesomeIcon, {
|
|
195
|
+
icon: faCheck,
|
|
196
|
+
className: "size-3 mt-0.5"
|
|
197
|
+
}) : null, validation.message]
|
|
198
|
+
}), validation.type === "error" && validation.technicalMessage && validation.technicalMessage !== validation.message && /* @__PURE__ */ jsxs("details", {
|
|
199
|
+
className: "text-xs text-gray-500",
|
|
200
|
+
children: [/* @__PURE__ */ jsx("summary", {
|
|
201
|
+
className: "cursor-pointer select-none",
|
|
202
|
+
children: t("Show technical details")
|
|
203
|
+
}), /* @__PURE__ */ jsx("p", {
|
|
204
|
+
className: "mt-1 text-rose-700",
|
|
205
|
+
children: validation.technicalMessage
|
|
206
|
+
})]
|
|
207
|
+
})]
|
|
208
|
+
})]
|
|
209
|
+
})
|
|
210
|
+
});
|
|
211
|
+
};
|
|
212
|
+
//#endregion
|
|
213
|
+
export { CalculationsField };
|
|
214
|
+
|
|
215
|
+
//# sourceMappingURL=CalculationsField.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CalculationsField.js","names":[],"sources":["../../../src/forms/fields/CalculationsField.tsx"],"sourcesContent":["import { useMemo, useState } from 'react';\nimport { TiptapEditor } from '@verbb/plugin-kit-react/components';\nimport type { VariableCategories, VariableOption } from '@verbb/plugin-kit-react/components/tiptap/VariableDropdown';\nimport { contentToValue } from '@verbb/plugin-kit-react/components/tiptap/variableSerialization';\nimport { useTranslation } from '@verbb/plugin-kit-react/hooks';\nimport { hostRequest } from '@verbb/plugin-kit-react/utils';\nimport { FieldLayout } from '../Field';\nimport type { SchemaFormEngineApi } from '../engine/context';\nimport type { SchemaNode } from '../engine/SchemaIndex';\nimport type { VariableConfig } from '../contexts/VariableCategoriesContext';\nimport { useEngineField } from '../useEngineField';\nimport { useVariableCategoriesContext } from '../contexts/VariableCategoriesContext';\nimport { CalculationsToolbar } from './CalculationsToolbar';\n\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faCheck } from '@fortawesome/pro-solid-svg-icons';\n\nimport { cn } from '@verbb/plugin-kit-react/utils';\n\ntype CalculationsFieldProps = {\n form: SchemaFormEngineApi;\n field: SchemaNode & {\n name: string;\n label?: string;\n instructions?: string;\n warning?: string;\n placeholder?: string;\n required?: boolean;\n disabled?: boolean;\n variableConfig?: VariableConfig;\n variableCategories?: VariableCategories;\n variablePickerTriggerCharacters?: string[];\n validationAction?: string;\n rows?: number;\n };\n};\n\ntype ValidationState = {\n type: 'idle' | 'success' | 'error';\n message: string;\n technicalMessage?: string;\n};\n\ntype CalculationPage = {\n _handle?: string;\n handle?: string;\n};\n\ntype ValidationResponsePayload = {\n valid?: unknown;\n message?: unknown;\n technicalMessage?: unknown;\n};\n\ntype HostRequestError = {\n message?: string;\n response?: {\n data?: {\n message?: unknown;\n technicalMessage?: unknown;\n };\n };\n};\n\nconst flattenVariableOptions = (options: VariableOption[] = []): VariableOption[] => {\n const flat: VariableOption[] = [];\n\n const visit = (nodes: VariableOption[]) => {\n nodes.forEach((node) => {\n flat.push(node);\n\n if (Array.isArray(node?.children) && node.children.length) {\n visit(node.children);\n }\n });\n };\n\n visit(options);\n return flat;\n};\n\nconst getAvailableVariableTokens = (variableCategories?: VariableCategories): string[] => {\n const categoryOptions = Object.values(variableCategories ?? {}).flatMap((items) => {\n return Array.isArray(items) ? items : [];\n });\n\n const flat = flattenVariableOptions(categoryOptions);\n\n return Array.from(new Set(flat\n .map((item) => {\n return typeof item?.value === 'string' ? item.value.trim() : '';\n })\n .filter(Boolean)));\n};\n\nconst getVariableTokenLabelMap = (variableCategories?: VariableCategories): Record<string, string> => {\n const categoryOptions = Object.values(variableCategories ?? {}).flatMap((items) => {\n return Array.isArray(items) ? items : [];\n });\n\n const flat = flattenVariableOptions(categoryOptions);\n\n return flat.reduce((map, item) => {\n const token = typeof item?.value === 'string' ? item.value.trim() : '';\n if (!token) {\n return map;\n }\n\n const label = typeof item?.label === 'string' ? item.label.trim() : '';\n map[token] = label || token;\n\n return map;\n }, {} as Record<string, string>);\n};\n\nconst getFormulaFromValue = (value: unknown): string => {\n if (typeof value === 'string') {\n return value;\n }\n\n if (Array.isArray(value)) {\n return contentToValue(value);\n }\n\n if (value && typeof value === 'object' && Array.isArray((value as { content?: unknown[] }).content)) {\n return contentToValue((value as { content: unknown[] }).content);\n }\n\n return '';\n};\n\nconst getPageIndexFromScopePath = (scopePathValue: unknown): number | null => {\n const scopePath = typeof scopePathValue === 'string' ? scopePathValue : '';\n\n if (!scopePath) {\n return null;\n }\n\n const match = scopePath.match(/(?:^|\\\\.)pages\\\\.(\\\\d+)(?:\\\\.|$)/);\n if (!match) {\n return null;\n }\n\n const pageIndex = Number.parseInt(match[1] || '', 10);\n\n return Number.isInteger(pageIndex) ? pageIndex : null;\n};\n\nconst getActivePageIndex = (pages: unknown, activePage: unknown): number | null => {\n if (!Array.isArray(pages) || !pages.length || typeof activePage !== 'string' || !activePage) {\n return null;\n }\n\n const pageIndex = pages.findIndex((page) => {\n const resolvedPage = (page && typeof page === 'object') ? page as CalculationPage : {};\n return resolvedPage._handle === activePage || resolvedPage.handle === activePage;\n });\n\n return pageIndex >= 0 ? pageIndex : null;\n};\n\nconst getValidationErrorDetails = (error: unknown, fallbackMessage: string) => {\n const resolvedError = (error && typeof error === 'object') ? error as HostRequestError : {};\n const responseData = resolvedError.response?.data;\n const message = responseData?.message || resolvedError.message || fallbackMessage;\n\n return {\n message: String(message),\n technicalMessage: String(responseData?.technicalMessage ?? ''),\n };\n};\n\nexport const CalculationsField = ({ form, field }: CalculationsFieldProps) => {\n const t = useTranslation();\n const { value, setValue, errors } = useEngineField(form, field.name);\n const [guideOpen, setGuideOpen] = useState(false);\n const [validating, setValidating] = useState(false);\n const [validation, setValidation] = useState<ValidationState>({ type: 'idle', message: '' });\n const {\n getVariableCategories,\n variableCategoryLabels,\n variableCategoryOrder,\n variableTransformerRegistry,\n } = useVariableCategoriesContext();\n\n const resolvedVariableCategories = useMemo(() => {\n if (field.variableCategories) {\n return field.variableCategories;\n }\n\n const { variableConfig } = field;\n if (!variableConfig || !getVariableCategories) {\n return undefined;\n }\n\n const pages = form?.getFieldValue?.('pages');\n const activePage = form?.getFieldValue?.('activePage');\n const scopePageIndex = getPageIndexFromScopePath(field._scopePath);\n const activePageIndex = getActivePageIndex(pages, activePage);\n const currentPageIndex = Number.isInteger(scopePageIndex) ? scopePageIndex : activePageIndex;\n const scopedVariableConfig = {\n ...variableConfig,\n ...(Number.isInteger(currentPageIndex) ? { currentPageIndex } : {}),\n };\n\n return getVariableCategories(scopedVariableConfig, { form });\n }, [field, form, getVariableCategories]);\n\n const availableVariableTokens = useMemo(() => {\n return getAvailableVariableTokens(resolvedVariableCategories);\n }, [resolvedVariableCategories]);\n const tokenLabels = useMemo(() => {\n return getVariableTokenLabelMap(resolvedVariableCategories);\n }, [resolvedVariableCategories]);\n\n const runValidation = async () => {\n const formula = getFormulaFromValue(value).trim();\n if (!formula) {\n setValidation({ type: 'error', message: t('Enter a formula to test.') });\n return;\n }\n\n setValidating(true);\n setValidation({ type: 'idle', message: '', technicalMessage: '' });\n\n try {\n const action = field.validationAction || 'plugin-kit/fields/validate-calculations-formula';\n const response = await hostRequest('POST', action, {\n data: {\n formula,\n availableTokens: availableVariableTokens,\n tokenLabels,\n },\n });\n\n const payload = (response?.data ?? response) as ValidationResponsePayload;\n const isValid = Boolean(payload?.valid);\n const message = String(payload?.message ?? '');\n const technicalMessage = String(payload?.technicalMessage ?? '');\n\n setValidation({\n type: isValid ? 'success' : 'error',\n message: message || (isValid ? t('Formula is valid.') : t('Formula is invalid.')),\n technicalMessage,\n });\n } catch (error) {\n const { message, technicalMessage } = getValidationErrorDetails(error, t('Unable to validate formula.'));\n setValidation({\n type: 'error',\n message: String(message),\n technicalMessage,\n });\n } finally {\n setValidating(false);\n }\n };\n\n return (\n <FieldLayout\n name={field.name}\n label={field.label}\n instructions={field.instructions}\n warning={field.warning}\n required={field.required}\n errors={errors}\n withControl={false}\n >\n <div className=\"space-y-2\">\n <TiptapEditor\n value={value ?? ''}\n onChange={setValue}\n placeholder={field.placeholder}\n rows={field.rows}\n buttons={['variableTag']}\n toolbarContent={({ editor, variableCategories, variableCategoryLabels, variableCategoryOrder, variablePickerOpen, onVariablePickerOpenChange }) => {\n return (\n <CalculationsToolbar\n editor={editor}\n variableCategories={variableCategories}\n variableCategoryLabels={variableCategoryLabels}\n variableCategoryOrder={variableCategoryOrder}\n variablePickerOpen={variablePickerOpen}\n onVariablePickerOpenChange={onVariablePickerOpenChange}\n guideOpen={guideOpen}\n onGuideOpenChange={setGuideOpen}\n validating={validating}\n onValidate={runValidation}\n />\n );\n }}\n disabled={field.disabled}\n isInvalid={errors.length > 0}\n variableCategories={resolvedVariableCategories}\n variableCategoryLabels={variableCategoryLabels}\n variableCategoryOrder={variableCategoryOrder}\n variableTransformerRegistry={variableTransformerRegistry}\n variablePickerTriggerCharacters={field.variablePickerTriggerCharacters}\n />\n\n {validation.type !== 'idle' && (\n <div className=\"space-y-1\">\n <p className={cn(\n 'flex items-center gap-1',\n validation.type === 'success' ? 'text-emerald-700' : 'text-rose-700',\n )}>\n {validation.type === 'success' ? (\n <FontAwesomeIcon icon={faCheck} className=\"size-3 mt-0.5\" />\n ) : null}\n {validation.message}\n </p>\n\n {validation.type === 'error' && validation.technicalMessage && validation.technicalMessage !== validation.message && (\n <details className=\"text-xs text-gray-500\">\n <summary className=\"cursor-pointer select-none\">{t('Show technical details')}</summary>\n <p className=\"mt-1 text-rose-700\">{validation.technicalMessage}</p>\n </details>\n )}\n </div>\n )}\n </div>\n </FieldLayout>\n );\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Editor } from '@tiptap/core';
|
|
2
|
+
import { VariableCategories } from '../../components/tiptap/VariableDropdown';
|
|
3
|
+
type CalculationsToolbarProps = {
|
|
4
|
+
editor: Editor | null | undefined;
|
|
5
|
+
variableCategories: VariableCategories;
|
|
6
|
+
variableCategoryLabels?: Record<string, string>;
|
|
7
|
+
variableCategoryOrder?: string[];
|
|
8
|
+
variablePickerOpen: boolean;
|
|
9
|
+
onVariablePickerOpenChange: (open: boolean) => void;
|
|
10
|
+
guideOpen: boolean;
|
|
11
|
+
onGuideOpenChange: (open: boolean) => void;
|
|
12
|
+
validating: boolean;
|
|
13
|
+
onValidate: () => void;
|
|
14
|
+
};
|
|
15
|
+
export declare const CalculationsToolbar: ({ editor, variableCategories, variableCategoryLabels, variableCategoryOrder, variablePickerOpen, onVariablePickerOpenChange, guideOpen, onGuideOpenChange, validating, onValidate, }: CalculationsToolbarProps) => import("react/jsx-runtime").JSX.Element;
|
|
16
|
+
export {};
|
|
17
|
+
//# sourceMappingURL=CalculationsToolbar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CalculationsToolbar.d.ts","sourceRoot":"","sources":["../../../src/forms/fields/CalculationsToolbar.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAE3C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4DAA4D,CAAC;AA+DrG,KAAK,wBAAwB,GAAG;IAC5B,MAAM,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IAClC,kBAAkB,EAAE,kBAAkB,CAAC;IACvC,sBAAsB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChD,qBAAqB,CAAC,EAAE,MAAM,EAAE,CAAC;IACjC,kBAAkB,EAAE,OAAO,CAAC;IAC5B,0BAA0B,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACpD,SAAS,EAAE,OAAO,CAAC;IACnB,iBAAiB,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IAC3C,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,MAAM,IAAI,CAAC;CAC1B,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,sLAWjC,wBAAwB,4CA0D1B,CAAC"}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { useTranslation } from "../../hooks/useTranslation.js";
|
|
2
|
+
import "../../hooks/index.js";
|
|
3
|
+
import { Dialog, DialogContent, DialogDescription, DialogHeader, DialogTitle, DialogTrigger } from "../../components/Dialog.js";
|
|
4
|
+
import { VariableDropdown } from "../../components/tiptap/VariableDropdown.js";
|
|
5
|
+
import "../../components/index.js";
|
|
6
|
+
import { Button } from "../../components/Button.js";
|
|
7
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
8
|
+
//#region src/forms/fields/CalculationsToolbar.tsx
|
|
9
|
+
var OPERATOR_GROUPS = [
|
|
10
|
+
{
|
|
11
|
+
title: "Arithmetic",
|
|
12
|
+
items: [
|
|
13
|
+
["+", "Addition"],
|
|
14
|
+
["-", "Subtraction"],
|
|
15
|
+
["*", "Multiplication"],
|
|
16
|
+
["/", "Division"],
|
|
17
|
+
["%", "Modulus"],
|
|
18
|
+
["**", "Power"]
|
|
19
|
+
]
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
title: "Bitwise",
|
|
23
|
+
items: [
|
|
24
|
+
["&", "AND"],
|
|
25
|
+
["|", "OR"],
|
|
26
|
+
["^", "XOR"]
|
|
27
|
+
]
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
title: "Logical",
|
|
31
|
+
items: [
|
|
32
|
+
["!, not", "Not"],
|
|
33
|
+
["&&, and", "And"],
|
|
34
|
+
["||, or", "Or"]
|
|
35
|
+
]
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
title: "Comparison",
|
|
39
|
+
items: [
|
|
40
|
+
["==", "Equal"],
|
|
41
|
+
["===", "Identical"],
|
|
42
|
+
["!=", "Not equal"],
|
|
43
|
+
["!==", "Not identical"],
|
|
44
|
+
["<, >, <=, >=", "Relational"],
|
|
45
|
+
["matches", "Regex match"]
|
|
46
|
+
]
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
title: "Ternary",
|
|
50
|
+
items: [["a ? b : c", "Conditional"]]
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
title: "Array",
|
|
54
|
+
items: [["in", "Contains"], ["not in", "Does not contain"]]
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
title: "Numeric",
|
|
58
|
+
items: [["..", "Range"]]
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
title: "String",
|
|
62
|
+
items: [["~", "Concatenation"]]
|
|
63
|
+
}
|
|
64
|
+
];
|
|
65
|
+
var CalculationsToolbar = ({ editor, variableCategories, variableCategoryLabels, variableCategoryOrder, variablePickerOpen, onVariablePickerOpenChange, guideOpen, onGuideOpenChange, validating, onValidate }) => {
|
|
66
|
+
const t = useTranslation();
|
|
67
|
+
return /* @__PURE__ */ jsxs("div", {
|
|
68
|
+
className: "flex items-center justify-between relative z-10 px-[8px] py-[8px] border-b border-[rgba(96,125,159,0.4)] bg-white shadow-[0_2px_3px_rgba(49,49,93,.07)]",
|
|
69
|
+
children: [/* @__PURE__ */ jsx("div", {
|
|
70
|
+
className: "flex flex-wrap gap-1",
|
|
71
|
+
children: /* @__PURE__ */ jsx(VariableDropdown, {
|
|
72
|
+
editor,
|
|
73
|
+
variableCategories,
|
|
74
|
+
variableCategoryLabels,
|
|
75
|
+
variableCategoryOrder,
|
|
76
|
+
title: t("Insert Variable"),
|
|
77
|
+
buttonLabel: t("Insert Field"),
|
|
78
|
+
buttonVariant: "outline",
|
|
79
|
+
buttonSize: "sm",
|
|
80
|
+
buttonClassName: "h-auto [&_svg]:size-3",
|
|
81
|
+
open: variablePickerOpen,
|
|
82
|
+
onOpenChange: onVariablePickerOpenChange
|
|
83
|
+
})
|
|
84
|
+
}), /* @__PURE__ */ jsxs("div", {
|
|
85
|
+
className: "flex items-center gap-2",
|
|
86
|
+
children: [/* @__PURE__ */ jsxs(Dialog, {
|
|
87
|
+
open: guideOpen,
|
|
88
|
+
onOpenChange: onGuideOpenChange,
|
|
89
|
+
children: [/* @__PURE__ */ jsx(DialogTrigger, { render: /* @__PURE__ */ jsx(Button, {
|
|
90
|
+
variant: "outline",
|
|
91
|
+
size: "sm",
|
|
92
|
+
children: t("Syntax Guide")
|
|
93
|
+
}) }), /* @__PURE__ */ jsxs(DialogContent, {
|
|
94
|
+
className: "max-w-4xl",
|
|
95
|
+
showCloseButton: true,
|
|
96
|
+
children: [/* @__PURE__ */ jsxs(DialogHeader, { children: [/* @__PURE__ */ jsx(DialogTitle, { children: t("Syntax Guide") }), /* @__PURE__ */ jsx(DialogDescription, { children: t("Use field variables and expression syntax in formulas.") })] }), /* @__PURE__ */ jsx("div", {
|
|
97
|
+
className: "grid gap-4 p-4 text-sm md:grid-cols-2 xl:grid-cols-4",
|
|
98
|
+
children: OPERATOR_GROUPS.map((group) => {
|
|
99
|
+
return /* @__PURE__ */ jsxs("div", { children: [/* @__PURE__ */ jsx("p", {
|
|
100
|
+
className: "mb-2 font-semibold text-gray-700",
|
|
101
|
+
children: t(group.title)
|
|
102
|
+
}), /* @__PURE__ */ jsx("ul", {
|
|
103
|
+
className: "space-y-1 text-xs text-gray-600",
|
|
104
|
+
children: group.items.map(([token, label]) => {
|
|
105
|
+
return /* @__PURE__ */ jsxs("li", {
|
|
106
|
+
className: "flex items-center gap-2",
|
|
107
|
+
children: [/* @__PURE__ */ jsx("code", {
|
|
108
|
+
className: "rounded bg-gray-200 px-1.5 py-0.5 font-mono text-[11px]",
|
|
109
|
+
children: token
|
|
110
|
+
}), /* @__PURE__ */ jsx("span", { children: t(label) })]
|
|
111
|
+
}, `${group.title}-${token}`);
|
|
112
|
+
})
|
|
113
|
+
})] }, group.title);
|
|
114
|
+
})
|
|
115
|
+
})]
|
|
116
|
+
})]
|
|
117
|
+
}), /* @__PURE__ */ jsx(Button, {
|
|
118
|
+
variant: "secondary",
|
|
119
|
+
size: "sm",
|
|
120
|
+
loading: validating,
|
|
121
|
+
onClick: onValidate,
|
|
122
|
+
children: t("Test Formula")
|
|
123
|
+
})]
|
|
124
|
+
})]
|
|
125
|
+
});
|
|
126
|
+
};
|
|
127
|
+
//#endregion
|
|
128
|
+
export { CalculationsToolbar };
|
|
129
|
+
|
|
130
|
+
//# sourceMappingURL=CalculationsToolbar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CalculationsToolbar.js","names":[],"sources":["../../../src/forms/fields/CalculationsToolbar.tsx"],"sourcesContent":["import { Button, Dialog, DialogContent, DialogDescription, DialogHeader, DialogTitle, DialogTrigger } from '@verbb/plugin-kit-react/components';\nimport type { Editor } from '@tiptap/core';\nimport { VariableDropdown } from '@verbb/plugin-kit-react/components/tiptap/VariableDropdown';\nimport type { VariableCategories } from '@verbb/plugin-kit-react/components/tiptap/VariableDropdown';\nimport { useTranslation } from '@verbb/plugin-kit-react/hooks';\n\nconst OPERATOR_GROUPS = [\n {\n title: 'Arithmetic',\n items: [\n ['+', 'Addition'],\n ['-', 'Subtraction'],\n ['*', 'Multiplication'],\n ['/', 'Division'],\n ['%', 'Modulus'],\n ['**', 'Power'],\n ],\n },\n {\n title: 'Bitwise',\n items: [\n ['&', 'AND'],\n ['|', 'OR'],\n ['^', 'XOR'],\n ],\n },\n {\n title: 'Logical',\n items: [\n ['!, not', 'Not'],\n ['&&, and', 'And'],\n ['||, or', 'Or'],\n ],\n },\n {\n title: 'Comparison',\n items: [\n ['==', 'Equal'],\n ['===', 'Identical'],\n ['!=', 'Not equal'],\n ['!==', 'Not identical'],\n ['<, >, <=, >=', 'Relational'],\n ['matches', 'Regex match'],\n ],\n },\n {\n title: 'Ternary',\n items: [['a ? b : c', 'Conditional']],\n },\n {\n title: 'Array',\n items: [\n ['in', 'Contains'],\n ['not in', 'Does not contain'],\n ],\n },\n {\n title: 'Numeric',\n items: [['..', 'Range']],\n },\n {\n title: 'String',\n items: [['~', 'Concatenation']],\n },\n];\n\ntype CalculationsToolbarProps = {\n editor: Editor | null | undefined;\n variableCategories: VariableCategories;\n variableCategoryLabels?: Record<string, string>;\n variableCategoryOrder?: string[];\n variablePickerOpen: boolean;\n onVariablePickerOpenChange: (open: boolean) => void;\n guideOpen: boolean;\n onGuideOpenChange: (open: boolean) => void;\n validating: boolean;\n onValidate: () => void;\n};\n\nexport const CalculationsToolbar = ({\n editor,\n variableCategories,\n variableCategoryLabels,\n variableCategoryOrder,\n variablePickerOpen,\n onVariablePickerOpenChange,\n guideOpen,\n onGuideOpenChange,\n validating,\n onValidate,\n}: CalculationsToolbarProps) => {\n const t = useTranslation();\n\n return (\n <div className=\"flex items-center justify-between relative z-10 px-[8px] py-[8px] border-b border-[rgba(96,125,159,0.4)] bg-white shadow-[0_2px_3px_rgba(49,49,93,.07)]\">\n <div className=\"flex flex-wrap gap-1\">\n <VariableDropdown\n editor={editor}\n variableCategories={variableCategories}\n variableCategoryLabels={variableCategoryLabels}\n variableCategoryOrder={variableCategoryOrder}\n title={t('Insert Variable')}\n buttonLabel={t('Insert Field')}\n buttonVariant=\"outline\"\n buttonSize=\"sm\"\n buttonClassName=\"h-auto [&_svg]:size-3\"\n open={variablePickerOpen}\n onOpenChange={onVariablePickerOpenChange}\n />\n </div>\n\n <div className=\"flex items-center gap-2\">\n <Dialog open={guideOpen} onOpenChange={onGuideOpenChange}>\n <DialogTrigger render={<Button variant=\"outline\" size=\"sm\">{t('Syntax Guide')}</Button>} />\n <DialogContent className=\"max-w-4xl\" showCloseButton>\n <DialogHeader>\n <DialogTitle>{t('Syntax Guide')}</DialogTitle>\n <DialogDescription>{t('Use field variables and expression syntax in formulas.')}</DialogDescription>\n </DialogHeader>\n\n <div className=\"grid gap-4 p-4 text-sm md:grid-cols-2 xl:grid-cols-4\">\n {OPERATOR_GROUPS.map((group) => {\n return (\n <div key={group.title}>\n <p className=\"mb-2 font-semibold text-gray-700\">{t(group.title)}</p>\n <ul className=\"space-y-1 text-xs text-gray-600\">\n {group.items.map(([token, label]) => {\n return (\n <li key={`${group.title}-${token}`} className=\"flex items-center gap-2\">\n <code className=\"rounded bg-gray-200 px-1.5 py-0.5 font-mono text-[11px]\">{token}</code>\n <span>{t(label)}</span>\n </li>\n );\n })}\n </ul>\n </div>\n );\n })}\n </div>\n </DialogContent>\n </Dialog>\n\n <Button variant=\"secondary\" size=\"sm\" loading={validating} onClick={onValidate}>\n {t('Test Formula')}\n </Button>\n </div>\n </div>\n );\n};\n"],"mappings":";;;;;;;;AAMA,IAAM,kBAAkB;CACpB;EACI,OAAO;EACP,OAAO;GACH,CAAC,KAAK,WAAW;GACjB,CAAC,KAAK,cAAc;GACpB,CAAC,KAAK,iBAAiB;GACvB,CAAC,KAAK,WAAW;GACjB,CAAC,KAAK,UAAU;GAChB,CAAC,MAAM,QAAQ;GAClB;EACJ;CACD;EACI,OAAO;EACP,OAAO;GACH,CAAC,KAAK,MAAM;GACZ,CAAC,KAAK,KAAK;GACX,CAAC,KAAK,MAAM;GACf;EACJ;CACD;EACI,OAAO;EACP,OAAO;GACH,CAAC,UAAU,MAAM;GACjB,CAAC,WAAW,MAAM;GAClB,CAAC,UAAU,KAAK;GACnB;EACJ;CACD;EACI,OAAO;EACP,OAAO;GACH,CAAC,MAAM,QAAQ;GACf,CAAC,OAAO,YAAY;GACpB,CAAC,MAAM,YAAY;GACnB,CAAC,OAAO,gBAAgB;GACxB,CAAC,gBAAgB,aAAa;GAC9B,CAAC,WAAW,cAAc;GAC7B;EACJ;CACD;EACI,OAAO;EACP,OAAO,CAAC,CAAC,aAAa,cAAc,CAAC;EACxC;CACD;EACI,OAAO;EACP,OAAO,CACH,CAAC,MAAM,WAAW,EAClB,CAAC,UAAU,mBAAmB,CACjC;EACJ;CACD;EACI,OAAO;EACP,OAAO,CAAC,CAAC,MAAM,QAAQ,CAAC;EAC3B;CACD;EACI,OAAO;EACP,OAAO,CAAC,CAAC,KAAK,gBAAgB,CAAC;EAClC;CACJ;AAeD,IAAa,uBAAuB,EAChC,QACA,oBACA,wBACA,uBACA,oBACA,4BACA,WACA,mBACA,YACA,iBAC4B;CAC5B,MAAM,IAAI,gBAAgB;AAE1B,QACI,qBAAC,OAAD;EAAK,WAAU;YAAf,CACI,oBAAC,OAAD;GAAK,WAAU;aACX,oBAAC,kBAAD;IACY;IACY;IACI;IACD;IACvB,OAAO,EAAE,kBAAkB;IAC3B,aAAa,EAAE,eAAe;IAC9B,eAAc;IACd,YAAW;IACX,iBAAgB;IAChB,MAAM;IACN,cAAc;IAChB,CAAA;GACA,CAAA,EAEN,qBAAC,OAAD;GAAK,WAAU;aAAf,CACI,qBAAC,QAAD;IAAQ,MAAM;IAAW,cAAc;cAAvC,CACI,oBAAC,eAAD,EAAe,QAAQ,oBAAC,QAAD;KAAQ,SAAQ;KAAU,MAAK;eAAM,EAAE,eAAe;KAAU,CAAA,EAAI,CAAA,EAC3F,qBAAC,eAAD;KAAe,WAAU;KAAY,iBAAA;eAArC,CACI,qBAAC,cAAD,EAAA,UAAA,CACI,oBAAC,aAAD,EAAA,UAAc,EAAE,eAAe,EAAe,CAAA,EAC9C,oBAAC,mBAAD,EAAA,UAAoB,EAAE,yDAAyD,EAAqB,CAAA,CACzF,EAAA,CAAA,EAEf,oBAAC,OAAD;MAAK,WAAU;gBACV,gBAAgB,KAAK,UAAU;AAC5B,cACI,qBAAC,OAAD,EAAA,UAAA,CACI,oBAAC,KAAD;QAAG,WAAU;kBAAoC,EAAE,MAAM,MAAM;QAAK,CAAA,EACpE,oBAAC,MAAD;QAAI,WAAU;kBACT,MAAM,MAAM,KAAK,CAAC,OAAO,WAAW;AACjC,gBACI,qBAAC,MAAD;UAAoC,WAAU;oBAA9C,CACI,oBAAC,QAAD;WAAM,WAAU;qBAA2D;WAAa,CAAA,EACxF,oBAAC,QAAD,EAAA,UAAO,EAAE,MAAM,EAAQ,CAAA,CACtB;YAHI,GAAG,MAAM,MAAM,GAAG,QAGtB;UAEX;QACD,CAAA,CACH,EAAA,EAZI,MAAM,MAYV;QAEZ;MACA,CAAA,CACM;OACX;OAET,oBAAC,QAAD;IAAQ,SAAQ;IAAY,MAAK;IAAK,SAAS;IAAY,SAAS;cAC/D,EAAE,eAAe;IACb,CAAA,CACP;KACJ"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { CheckboxSelectOption } from '../../components/CheckboxSelect';
|
|
2
|
+
import { SchemaFormEngineApi } from '../engine/context';
|
|
3
|
+
type CheckboxSelectFieldProps = {
|
|
4
|
+
form: SchemaFormEngineApi;
|
|
5
|
+
field: {
|
|
6
|
+
name: string;
|
|
7
|
+
label?: string;
|
|
8
|
+
instructions?: string;
|
|
9
|
+
warning?: string;
|
|
10
|
+
options?: CheckboxSelectOption[];
|
|
11
|
+
showAllOption?: boolean;
|
|
12
|
+
allLabel?: string;
|
|
13
|
+
required?: boolean;
|
|
14
|
+
disabled?: boolean;
|
|
15
|
+
};
|
|
16
|
+
};
|
|
17
|
+
export declare const CheckboxSelectField: ({ form, field }: CheckboxSelectFieldProps) => import("react/jsx-runtime").JSX.Element;
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=CheckboxSelectField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CheckboxSelectField.d.ts","sourceRoot":"","sources":["../../../src/forms/fields/CheckboxSelectField.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAkB,KAAK,oBAAoB,EAA4B,MAAM,mDAAmD,CAAC;AAExI,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAG7D,KAAK,wBAAwB,GAAG;IAC5B,IAAI,EAAE,mBAAmB,CAAC;IAC1B,KAAK,EAAE;QACH,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,OAAO,CAAC,EAAE,oBAAoB,EAAE,CAAC;QACjC,aAAa,CAAC,EAAE,OAAO,CAAC;QACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;KACtB,CAAC;CACL,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,iBAAiB,wBAAwB,4CAsB5E,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { CheckboxSelect } from "../../components/CheckboxSelect.js";
|
|
2
|
+
import { FieldLayout } from "../Field.js";
|
|
3
|
+
import { useEngineField } from "../useEngineField.js";
|
|
4
|
+
import { jsx } from "react/jsx-runtime";
|
|
5
|
+
//#region src/forms/fields/CheckboxSelectField.tsx
|
|
6
|
+
var CheckboxSelectField = ({ form, field }) => {
|
|
7
|
+
const { value, setValue, errors } = useEngineField(form, field.name);
|
|
8
|
+
return /* @__PURE__ */ jsx(FieldLayout, {
|
|
9
|
+
name: field.name,
|
|
10
|
+
label: field.label,
|
|
11
|
+
instructions: field.instructions,
|
|
12
|
+
warning: field.warning,
|
|
13
|
+
required: field.required,
|
|
14
|
+
errors,
|
|
15
|
+
children: /* @__PURE__ */ jsx(CheckboxSelect, {
|
|
16
|
+
options: field.options || [],
|
|
17
|
+
value: value === void 0 || value === null ? [] : value,
|
|
18
|
+
onChange: (v) => {
|
|
19
|
+
return setValue(v);
|
|
20
|
+
},
|
|
21
|
+
showAllOption: field.showAllOption ?? false,
|
|
22
|
+
allLabel: field.allLabel,
|
|
23
|
+
disabled: field.disabled
|
|
24
|
+
})
|
|
25
|
+
});
|
|
26
|
+
};
|
|
27
|
+
//#endregion
|
|
28
|
+
export { CheckboxSelectField };
|
|
29
|
+
|
|
30
|
+
//# sourceMappingURL=CheckboxSelectField.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CheckboxSelectField.js","names":[],"sources":["../../../src/forms/fields/CheckboxSelectField.tsx"],"sourcesContent":["import { CheckboxSelect, type CheckboxSelectOption, type CheckboxSelectValue } from '@verbb/plugin-kit-react/components/CheckboxSelect';\nimport { FieldLayout } from '../Field';\nimport type { SchemaFormEngineApi } from '../engine/context';\nimport { useEngineField } from '../useEngineField';\n\ntype CheckboxSelectFieldProps = {\n form: SchemaFormEngineApi;\n field: {\n name: string;\n label?: string;\n instructions?: string;\n warning?: string;\n options?: CheckboxSelectOption[];\n showAllOption?: boolean;\n allLabel?: string;\n required?: boolean;\n disabled?: boolean;\n };\n};\n\nexport const CheckboxSelectField = ({ form, field }: CheckboxSelectFieldProps) => {\n const { value, setValue, errors } = useEngineField(form, field.name);\n\n return (\n <FieldLayout\n name={field.name}\n label={field.label}\n instructions={field.instructions}\n warning={field.warning}\n required={field.required}\n errors={errors}\n >\n <CheckboxSelect\n options={field.options || []}\n value={(value === undefined || value === null ? [] : value) as CheckboxSelectValue}\n onChange={(v) => { return setValue(v); }}\n showAllOption={field.showAllOption ?? false}\n allLabel={field.allLabel}\n disabled={field.disabled}\n />\n </FieldLayout>\n );\n};\n"],"mappings":";;;;;AAoBA,IAAa,uBAAuB,EAAE,MAAM,YAAsC;CAC9E,MAAM,EAAE,OAAO,UAAU,WAAW,eAAe,MAAM,MAAM,KAAK;AAEpE,QACI,oBAAC,aAAD;EACI,MAAM,MAAM;EACZ,OAAO,MAAM;EACb,cAAc,MAAM;EACpB,SAAS,MAAM;EACf,UAAU,MAAM;EACR;YAER,oBAAC,gBAAD;GACI,SAAS,MAAM,WAAW,EAAE;GAC5B,OAAQ,UAAU,KAAA,KAAa,UAAU,OAAO,EAAE,GAAG;GACrD,WAAW,MAAM;AAAE,WAAO,SAAS,EAAE;;GACrC,eAAe,MAAM,iBAAiB;GACtC,UAAU,MAAM;GAChB,UAAU,MAAM;GAClB,CAAA;EACQ,CAAA"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { SchemaFormEngineApi } from '../engine/context';
|
|
2
|
+
type ColorFieldProps = {
|
|
3
|
+
form: SchemaFormEngineApi;
|
|
4
|
+
field: {
|
|
5
|
+
name: string;
|
|
6
|
+
label?: string;
|
|
7
|
+
instructions?: string;
|
|
8
|
+
warning?: string;
|
|
9
|
+
required?: boolean;
|
|
10
|
+
disabled?: boolean;
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
export declare const ColorField: ({ form, field }: ColorFieldProps) => import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=ColorField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ColorField.d.ts","sourceRoot":"","sources":["../../../src/forms/fields/ColorField.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAG7D,KAAK,eAAe,GAAG;IACnB,IAAI,EAAE,mBAAmB,CAAC;IAC1B,KAAK,EAAE;QACH,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;KACtB,CAAC;CACL,CAAC;AAEF,eAAO,MAAM,UAAU,GAAI,iBAAiB,eAAe,4CAyB1D,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { ColorInput } from "../../components/ColorInput.js";
|
|
2
|
+
import "../../components/index.js";
|
|
3
|
+
import { FieldLayout } from "../Field.js";
|
|
4
|
+
import { useEngineField } from "../useEngineField.js";
|
|
5
|
+
import { jsx } from "react/jsx-runtime";
|
|
6
|
+
//#region src/forms/fields/ColorField.tsx
|
|
7
|
+
var ColorField = ({ form, field }) => {
|
|
8
|
+
const { value, setValue, setTouched, errors, isInvalid } = useEngineField(form, field.name);
|
|
9
|
+
return /* @__PURE__ */ jsx(FieldLayout, {
|
|
10
|
+
name: field.name,
|
|
11
|
+
label: field.label,
|
|
12
|
+
instructions: field.instructions,
|
|
13
|
+
warning: field.warning,
|
|
14
|
+
required: field.required,
|
|
15
|
+
errors,
|
|
16
|
+
children: /* @__PURE__ */ jsx(ColorInput, {
|
|
17
|
+
value: String(value || ""),
|
|
18
|
+
onValueChange: (nextValue) => {
|
|
19
|
+
setValue(nextValue || "");
|
|
20
|
+
},
|
|
21
|
+
onBlur: setTouched,
|
|
22
|
+
disabled: field.disabled,
|
|
23
|
+
isInvalid
|
|
24
|
+
})
|
|
25
|
+
});
|
|
26
|
+
};
|
|
27
|
+
//#endregion
|
|
28
|
+
export { ColorField };
|
|
29
|
+
|
|
30
|
+
//# sourceMappingURL=ColorField.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ColorField.js","names":[],"sources":["../../../src/forms/fields/ColorField.tsx"],"sourcesContent":["import { ColorInput } from '@verbb/plugin-kit-react/components';\nimport { FieldLayout } from '../Field';\nimport type { SchemaFormEngineApi } from '../engine/context';\nimport { useEngineField } from '../useEngineField';\n\ntype ColorFieldProps = {\n form: SchemaFormEngineApi;\n field: {\n name: string;\n label?: string;\n instructions?: string;\n warning?: string;\n required?: boolean;\n disabled?: boolean;\n };\n};\n\nexport const ColorField = ({ form, field }: ColorFieldProps) => {\n const {\n value, setValue, setTouched, errors, isInvalid,\n } = useEngineField(form, field.name);\n\n return (\n <FieldLayout\n name={field.name}\n label={field.label}\n instructions={field.instructions}\n warning={field.warning}\n required={field.required}\n errors={errors}\n >\n <ColorInput\n value={String(value || '')}\n onValueChange={(nextValue) => {\n setValue(nextValue || '');\n }}\n onBlur={setTouched}\n disabled={field.disabled}\n isInvalid={isInvalid}\n />\n </FieldLayout>\n );\n};\n"],"mappings":";;;;;;AAiBA,IAAa,cAAc,EAAE,MAAM,YAA6B;CAC5D,MAAM,EACF,OAAO,UAAU,YAAY,QAAQ,cACrC,eAAe,MAAM,MAAM,KAAK;AAEpC,QACI,oBAAC,aAAD;EACI,MAAM,MAAM;EACZ,OAAO,MAAM;EACb,cAAc,MAAM;EACpB,SAAS,MAAM;EACf,UAAU,MAAM;EACR;YAER,oBAAC,YAAD;GACI,OAAO,OAAO,SAAS,GAAG;GAC1B,gBAAgB,cAAc;AAC1B,aAAS,aAAa,GAAG;;GAE7B,QAAQ;GACR,UAAU,MAAM;GACL;GACb,CAAA;EACQ,CAAA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ComboboxInputOption } from '../../components/ComboboxInput';
|
|
2
|
+
import { SchemaFormEngineApi } from '../engine/context';
|
|
3
|
+
type ComboboxFieldProps = {
|
|
4
|
+
form: SchemaFormEngineApi;
|
|
5
|
+
field: {
|
|
6
|
+
name: string;
|
|
7
|
+
label?: string;
|
|
8
|
+
instructions?: string;
|
|
9
|
+
warning?: string;
|
|
10
|
+
placeholder?: string;
|
|
11
|
+
emptyMessage?: string;
|
|
12
|
+
options?: ComboboxInputOption[];
|
|
13
|
+
fetchOptions?: () => Promise<ComboboxInputOption[]>;
|
|
14
|
+
multiple?: boolean;
|
|
15
|
+
cacheKey?: string;
|
|
16
|
+
cacheTtlMs?: number;
|
|
17
|
+
required?: boolean;
|
|
18
|
+
disabled?: boolean;
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
export declare const ComboboxField: ({ form, field }: ComboboxFieldProps) => import("react/jsx-runtime").JSX.Element;
|
|
22
|
+
export {};
|
|
23
|
+
//# sourceMappingURL=ComboboxField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ComboboxField.d.ts","sourceRoot":"","sources":["../../../src/forms/fields/ComboboxField.tsx"],"names":[],"mappings":"AAAA,OAAO,EAEH,KAAK,mBAAmB,EAE3B,MAAM,kDAAkD,CAAC;AAE1D,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAG7D,KAAK,kBAAkB,GAAG;IACtB,IAAI,EAAE,mBAAmB,CAAC;IAC1B,KAAK,EAAE;QACH,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,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,OAAO,CAAC,EAAE,mBAAmB,EAAE,CAAC;QAChC,YAAY,CAAC,EAAE,MAAM,OAAO,CAAC,mBAAmB,EAAE,CAAC,CAAC;QACpD,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;KACtB,CAAC;CACL,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,iBAAiB,kBAAkB,4CAkChE,CAAC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { ComboboxInput } from "../../components/ComboboxInput.js";
|
|
2
|
+
import { FieldLayout } from "../Field.js";
|
|
3
|
+
import { useEngineField } from "../useEngineField.js";
|
|
4
|
+
import { jsx } from "react/jsx-runtime";
|
|
5
|
+
//#region src/forms/fields/ComboboxField.tsx
|
|
6
|
+
var ComboboxField = ({ form, field }) => {
|
|
7
|
+
const { value, setValue, setTouched, errors } = useEngineField(form, field.name);
|
|
8
|
+
const isInvalid = errors.length > 0;
|
|
9
|
+
return /* @__PURE__ */ jsx(FieldLayout, {
|
|
10
|
+
name: field.name,
|
|
11
|
+
label: field.label,
|
|
12
|
+
instructions: field.instructions,
|
|
13
|
+
warning: field.warning,
|
|
14
|
+
required: field.required,
|
|
15
|
+
errors,
|
|
16
|
+
children: /* @__PURE__ */ jsx(ComboboxInput, {
|
|
17
|
+
options: field.options,
|
|
18
|
+
fetchOptions: field.fetchOptions,
|
|
19
|
+
multiple: field.multiple,
|
|
20
|
+
value,
|
|
21
|
+
onValueChange: (nextValue) => {
|
|
22
|
+
setValue(nextValue);
|
|
23
|
+
setTouched();
|
|
24
|
+
},
|
|
25
|
+
disabled: field.disabled,
|
|
26
|
+
placeholder: field.placeholder,
|
|
27
|
+
emptyMessage: field.emptyMessage,
|
|
28
|
+
cacheKey: field.cacheKey,
|
|
29
|
+
cacheTtlMs: field.cacheTtlMs,
|
|
30
|
+
className: "w-full",
|
|
31
|
+
contentClassName: isInvalid ? "aria-invalid:border-destructive" : void 0
|
|
32
|
+
})
|
|
33
|
+
});
|
|
34
|
+
};
|
|
35
|
+
//#endregion
|
|
36
|
+
export { ComboboxField };
|
|
37
|
+
|
|
38
|
+
//# sourceMappingURL=ComboboxField.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ComboboxField.js","names":[],"sources":["../../../src/forms/fields/ComboboxField.tsx"],"sourcesContent":["import {\n ComboboxInput,\n type ComboboxInputOption,\n type ComboboxInputProps,\n} from '@verbb/plugin-kit-react/components/ComboboxInput';\nimport { FieldLayout } from '../Field';\nimport type { SchemaFormEngineApi } from '../engine/context';\nimport { useEngineField } from '../useEngineField';\n\ntype ComboboxFieldProps = {\n form: SchemaFormEngineApi;\n field: {\n name: string;\n label?: string;\n instructions?: string;\n warning?: string;\n placeholder?: string;\n emptyMessage?: string;\n options?: ComboboxInputOption[];\n fetchOptions?: () => Promise<ComboboxInputOption[]>;\n multiple?: boolean;\n cacheKey?: string;\n cacheTtlMs?: number;\n required?: boolean;\n disabled?: boolean;\n };\n};\n\nexport const ComboboxField = ({ form, field }: ComboboxFieldProps) => {\n const {\n value, setValue, setTouched, errors,\n } = useEngineField(form, field.name);\n const isInvalid = errors.length > 0;\n\n return (\n <FieldLayout\n name={field.name}\n label={field.label}\n instructions={field.instructions}\n warning={field.warning}\n required={field.required}\n errors={errors}\n >\n <ComboboxInput\n options={field.options}\n fetchOptions={field.fetchOptions}\n multiple={field.multiple}\n value={value as ComboboxInputProps['value']}\n onValueChange={(nextValue) => {\n setValue(nextValue);\n setTouched();\n }}\n disabled={field.disabled}\n placeholder={field.placeholder}\n emptyMessage={field.emptyMessage}\n cacheKey={field.cacheKey}\n cacheTtlMs={field.cacheTtlMs}\n className=\"w-full\"\n contentClassName={isInvalid ? 'aria-invalid:border-destructive' : undefined}\n />\n </FieldLayout>\n );\n};\n"],"mappings":";;;;;AA4BA,IAAa,iBAAiB,EAAE,MAAM,YAAgC;CAClE,MAAM,EACF,OAAO,UAAU,YAAY,WAC7B,eAAe,MAAM,MAAM,KAAK;CACpC,MAAM,YAAY,OAAO,SAAS;AAElC,QACI,oBAAC,aAAD;EACI,MAAM,MAAM;EACZ,OAAO,MAAM;EACb,cAAc,MAAM;EACpB,SAAS,MAAM;EACf,UAAU,MAAM;EACR;YAER,oBAAC,eAAD;GACI,SAAS,MAAM;GACf,cAAc,MAAM;GACpB,UAAU,MAAM;GACT;GACP,gBAAgB,cAAc;AAC1B,aAAS,UAAU;AACnB,gBAAY;;GAEhB,UAAU,MAAM;GAChB,aAAa,MAAM;GACnB,cAAc,MAAM;GACpB,UAAU,MAAM;GAChB,YAAY,MAAM;GAClB,WAAU;GACV,kBAAkB,YAAY,oCAAoC,KAAA;GACpE,CAAA;EACQ,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { SchemaFormEngineApi } from '../engine/context';
|
|
2
|
+
type DateTimeFieldProps = {
|
|
3
|
+
form: SchemaFormEngineApi;
|
|
4
|
+
field: {
|
|
5
|
+
name: string;
|
|
6
|
+
label?: string;
|
|
7
|
+
instructions?: string;
|
|
8
|
+
warning?: string;
|
|
9
|
+
required?: boolean;
|
|
10
|
+
};
|
|
11
|
+
};
|
|
12
|
+
export declare const DateTimeField: ({ form, field }: DateTimeFieldProps) => import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=DateTimeField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DateTimeField.d.ts","sourceRoot":"","sources":["../../../src/forms/fields/DateTimeField.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAG7D,KAAK,kBAAkB,GAAG;IACtB,IAAI,EAAE,mBAAmB,CAAC;IAC1B,KAAK,EAAE;QACH,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;KACtB,CAAC;CACL,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,iBAAiB,kBAAkB,4CAgDhE,CAAC"}
|