@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,155 @@
|
|
|
1
|
+
import { cn } from "../../utils/classes.js";
|
|
2
|
+
import { hostOpenElementSelector } from "../../utils/hostBridge.js";
|
|
3
|
+
import "../../utils/index.js";
|
|
4
|
+
import { useTranslation } from "../../hooks/useTranslation.js";
|
|
5
|
+
import "../../hooks/index.js";
|
|
6
|
+
import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuSeparator, DropdownMenuTrigger } from "../DropdownMenu.js";
|
|
7
|
+
import { Tooltip, TooltipContent, TooltipTrigger } from "../Tooltip.js";
|
|
8
|
+
import { Button } from "../Button.js";
|
|
9
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
10
|
+
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
|
|
11
|
+
import { faLink } from "@fortawesome/pro-solid-svg-icons";
|
|
12
|
+
import { useEditorState } from "@tiptap/react";
|
|
13
|
+
//#region src/components/tiptap/LinkDropdown.tsx
|
|
14
|
+
function openCraftElementModal(config, elementSiteId, linkSelectorStorageKeyPrefix, onSelect, getSelectedText) {
|
|
15
|
+
if (!linkSelectorStorageKeyPrefix) throw new Error("LinkDropdown requires \"linkSelectorStorageKeyPrefix\" when using element selector links.");
|
|
16
|
+
hostOpenElementSelector(config.elementType, {
|
|
17
|
+
storageKey: `${linkSelectorStorageKeyPrefix}.${config.elementType}`,
|
|
18
|
+
sources: config.sources,
|
|
19
|
+
criteria: config.criteria,
|
|
20
|
+
defaultSiteId: elementSiteId,
|
|
21
|
+
autoFocusSearchBox: false,
|
|
22
|
+
onSelect: (elements) => {
|
|
23
|
+
if (elements?.length) {
|
|
24
|
+
const [element] = elements;
|
|
25
|
+
onSelect(`${element.url || ""}#${config.refHandle}:${element.id}@${element.siteId}`, getSelectedText() || element.label || "");
|
|
26
|
+
}
|
|
27
|
+
},
|
|
28
|
+
closeOtherModals: false
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
function isLinkOptionsArray(value) {
|
|
32
|
+
return Array.isArray(value) && value.length > 0;
|
|
33
|
+
}
|
|
34
|
+
function getCraftOptionsFromLinkOptions(linkOptions) {
|
|
35
|
+
if (!linkOptions) return [];
|
|
36
|
+
if (isLinkOptionsArray(linkOptions)) return linkOptions;
|
|
37
|
+
const items = [];
|
|
38
|
+
if (linkOptions.linkToEntry) items.push({
|
|
39
|
+
...linkOptions.linkToEntry,
|
|
40
|
+
optionTitle: "Link to an entry"
|
|
41
|
+
});
|
|
42
|
+
if (linkOptions.linkToAsset) items.push({
|
|
43
|
+
...linkOptions.linkToAsset,
|
|
44
|
+
optionTitle: "Link to an asset"
|
|
45
|
+
});
|
|
46
|
+
if (linkOptions.linkToCategory) items.push({
|
|
47
|
+
...linkOptions.linkToCategory,
|
|
48
|
+
optionTitle: "Link to a category"
|
|
49
|
+
});
|
|
50
|
+
return items;
|
|
51
|
+
}
|
|
52
|
+
function LinkDropdown({ editor, linkOptions = {}, linkSelectorStorageKeyPrefix, openInsertLinkDialog, title }) {
|
|
53
|
+
const t = useTranslation();
|
|
54
|
+
const craftOptions = getCraftOptionsFromLinkOptions(linkOptions);
|
|
55
|
+
const elementSiteId = !isLinkOptionsArray(linkOptions) ? linkOptions?.elementSiteId : void 0;
|
|
56
|
+
const getSelectedText = () => {
|
|
57
|
+
if (!editor) return "";
|
|
58
|
+
const { from, to } = editor.state.selection;
|
|
59
|
+
return editor.state.doc.textBetween(from, to, " ");
|
|
60
|
+
};
|
|
61
|
+
const handleCraftElementSelect = (url, text) => {
|
|
62
|
+
openInsertLinkDialog({
|
|
63
|
+
url,
|
|
64
|
+
text
|
|
65
|
+
});
|
|
66
|
+
};
|
|
67
|
+
const handleCraftOption = (config) => {
|
|
68
|
+
openCraftElementModal(config, elementSiteId, linkSelectorStorageKeyPrefix, handleCraftElementSelect, getSelectedText);
|
|
69
|
+
};
|
|
70
|
+
const handleLinkToEntry = () => {
|
|
71
|
+
const config = !isLinkOptionsArray(linkOptions) ? linkOptions?.linkToEntry : void 0;
|
|
72
|
+
if (config) handleCraftOption(config);
|
|
73
|
+
else openInsertLinkDialog();
|
|
74
|
+
};
|
|
75
|
+
const handleLinkToAsset = () => {
|
|
76
|
+
const config = !isLinkOptionsArray(linkOptions) ? linkOptions?.linkToAsset : void 0;
|
|
77
|
+
if (config) handleCraftOption(config);
|
|
78
|
+
else openInsertLinkDialog();
|
|
79
|
+
};
|
|
80
|
+
const handleLinkToCategory = () => {
|
|
81
|
+
const config = !isLinkOptionsArray(linkOptions) ? linkOptions?.linkToCategory : void 0;
|
|
82
|
+
if (config) handleCraftOption(config);
|
|
83
|
+
else openInsertLinkDialog();
|
|
84
|
+
};
|
|
85
|
+
const handleUnlink = () => {
|
|
86
|
+
editor?.chain().focus().extendMarkRange("link").unsetLink().run();
|
|
87
|
+
};
|
|
88
|
+
const isLinkActive = useEditorState({
|
|
89
|
+
editor,
|
|
90
|
+
selector: ({ editor: ed }) => {
|
|
91
|
+
return (ed?.isFocused && ed?.isActive("link")) ?? false;
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
const showCraftOptions = !isLinkOptionsArray(linkOptions) && (linkOptions?.linkToEntry || linkOptions?.linkToAsset || linkOptions?.linkToCategory) || craftOptions.length > 0;
|
|
95
|
+
const triggerButton = /* @__PURE__ */ jsx(Button, {
|
|
96
|
+
variant: "transparent",
|
|
97
|
+
className: cn("w-[32px] h-[32px]", "text-[#1c2e36]", "hover:bg-slate-100!", isLinkActive && "bg-slate-250! hover:bg-slate-250!"),
|
|
98
|
+
children: /* @__PURE__ */ jsx(FontAwesomeIcon, {
|
|
99
|
+
icon: faLink,
|
|
100
|
+
className: "size-4"
|
|
101
|
+
})
|
|
102
|
+
});
|
|
103
|
+
return /* @__PURE__ */ jsxs(DropdownMenu, { children: [title ? /* @__PURE__ */ jsxs(Tooltip, { children: [/* @__PURE__ */ jsx(TooltipTrigger, { render: /* @__PURE__ */ jsx(DropdownMenuTrigger, { render: triggerButton }) }), /* @__PURE__ */ jsx(TooltipContent, {
|
|
104
|
+
sideOffset: 4,
|
|
105
|
+
children: title
|
|
106
|
+
})] }) : /* @__PURE__ */ jsx(DropdownMenuTrigger, { render: triggerButton }), /* @__PURE__ */ jsxs(DropdownMenuContent, {
|
|
107
|
+
align: "start",
|
|
108
|
+
side: "bottom",
|
|
109
|
+
children: [
|
|
110
|
+
showCraftOptions && /* @__PURE__ */ jsxs(Fragment, { children: [craftOptions.length > 0 ? craftOptions.map((option, index) => {
|
|
111
|
+
return /* @__PURE__ */ jsx(DropdownMenuItem, {
|
|
112
|
+
onClick: () => {
|
|
113
|
+
return handleCraftOption(option);
|
|
114
|
+
},
|
|
115
|
+
children: option.optionTitle
|
|
116
|
+
}, index);
|
|
117
|
+
}) : /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
118
|
+
!isLinkOptionsArray(linkOptions) && linkOptions?.linkToEntry && /* @__PURE__ */ jsx(DropdownMenuItem, {
|
|
119
|
+
onClick: handleLinkToEntry,
|
|
120
|
+
children: t("Link to an entry")
|
|
121
|
+
}),
|
|
122
|
+
!isLinkOptionsArray(linkOptions) && linkOptions?.linkToAsset && /* @__PURE__ */ jsx(DropdownMenuItem, {
|
|
123
|
+
onClick: handleLinkToAsset,
|
|
124
|
+
children: t("Link to an asset")
|
|
125
|
+
}),
|
|
126
|
+
!isLinkOptionsArray(linkOptions) && linkOptions?.linkToCategory && /* @__PURE__ */ jsx(DropdownMenuItem, {
|
|
127
|
+
onClick: handleLinkToCategory,
|
|
128
|
+
children: t("Link to a category")
|
|
129
|
+
})
|
|
130
|
+
] }), /* @__PURE__ */ jsx(DropdownMenuSeparator, {})] }),
|
|
131
|
+
/* @__PURE__ */ jsx(DropdownMenuItem, {
|
|
132
|
+
onClick: () => {
|
|
133
|
+
const selected = getSelectedText();
|
|
134
|
+
const { from, to } = editor?.state.selection ?? {};
|
|
135
|
+
openInsertLinkDialog(typeof from === "number" && typeof to === "number" && from !== to ? {
|
|
136
|
+
text: selected,
|
|
137
|
+
from,
|
|
138
|
+
to
|
|
139
|
+
} : void 0);
|
|
140
|
+
},
|
|
141
|
+
children: t("Insert Link")
|
|
142
|
+
}),
|
|
143
|
+
/* @__PURE__ */ jsx(DropdownMenuItem, {
|
|
144
|
+
onClick: handleUnlink,
|
|
145
|
+
disabled: !isLinkActive,
|
|
146
|
+
className: !isLinkActive ? "opacity-50" : "",
|
|
147
|
+
children: t("Unlink")
|
|
148
|
+
})
|
|
149
|
+
]
|
|
150
|
+
})] });
|
|
151
|
+
}
|
|
152
|
+
//#endregion
|
|
153
|
+
export { LinkDropdown };
|
|
154
|
+
|
|
155
|
+
//# sourceMappingURL=LinkDropdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LinkDropdown.js","names":[],"sources":["../../../src/components/tiptap/LinkDropdown.tsx"],"sourcesContent":["import { useEditorState } from '@tiptap/react';\nimport type { Editor } from '@tiptap/core';\nimport {\n DropdownMenu,\n DropdownMenuTrigger,\n DropdownMenuContent,\n DropdownMenuItem,\n DropdownMenuSeparator,\n} from '@verbb/plugin-kit-react/components/DropdownMenu';\nimport { Button } from '@verbb/plugin-kit-react/components/Button';\nimport { Tooltip, TooltipContent, TooltipTrigger } from '@verbb/plugin-kit-react/components/Tooltip';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faLink } from '@fortawesome/pro-solid-svg-icons';\nimport { cn, hostOpenElementSelector } from '@verbb/plugin-kit-react/utils';\nimport { useTranslation } from '@verbb/plugin-kit-react/hooks';\n\nexport type LinkElementConfig = {\n elementType: string;\n refHandle: string;\n sources?: string[];\n criteria?: Record<string, unknown>;\n};\n\nexport type LinkOptionSchemaItem = LinkElementConfig & {\n optionTitle: string;\n};\n\nexport type LinkOptions = {\n elementSiteId?: number;\n linkToEntry?: LinkElementConfig;\n linkToAsset?: LinkElementConfig;\n linkToCategory?: LinkElementConfig;\n};\n\n/** linkOptions can be the object format above, or an array from schema: { optionTitle, elementType, refHandle, sources?, criteria? }[] */\nexport type LinkOptionsInput = LinkOptions | LinkOptionSchemaItem[];\n\ntype LinkDropdownProps = {\n editor: Editor | null | undefined;\n linkOptions?: LinkOptionsInput;\n linkSelectorStorageKeyPrefix?: string;\n openInsertLinkDialog: (initial?: { url?: string; text?: string; from?: number; to?: number }) => void;\n title?: string;\n};\n\ndeclare global {\n interface Window {\n Craft?: {\n createElementSelectorModal?: (\n elementType: string,\n options: {\n storageKey: string;\n sources?: string[];\n criteria?: Record<string, unknown>;\n defaultSiteId?: number;\n autoFocusSearchBox?: boolean;\n onSelect: (elements: Array<{ url?: string; label?: string; id?: number; siteId?: number }>) => void;\n closeOtherModals?: boolean;\n },\n ) => void;\n };\n }\n}\n\nfunction openCraftElementModal(\n config: LinkElementConfig,\n elementSiteId: number | undefined,\n linkSelectorStorageKeyPrefix: string | undefined,\n onSelect: (url: string, text: string) => void,\n getSelectedText: () => string,\n) {\n if (!linkSelectorStorageKeyPrefix) {\n throw new Error('LinkDropdown requires \"linkSelectorStorageKeyPrefix\" when using element selector links.');\n }\n\n hostOpenElementSelector(config.elementType, {\n storageKey: `${linkSelectorStorageKeyPrefix}.${config.elementType}`,\n sources: config.sources,\n criteria: config.criteria,\n defaultSiteId: elementSiteId,\n autoFocusSearchBox: false,\n onSelect: (elements) => {\n if (elements?.length) {\n const [element] = elements;\n const url = `${element.url || ''}#${config.refHandle}:${element.id}@${element.siteId}`;\n const text = getSelectedText() || element.label || '';\n onSelect(url, text);\n }\n },\n closeOtherModals: false,\n });\n}\n\nfunction isLinkOptionsArray(value: LinkOptionsInput | undefined): value is LinkOptionSchemaItem[] {\n return Array.isArray(value) && value.length > 0;\n}\n\nfunction getCraftOptionsFromLinkOptions(linkOptions: LinkOptionsInput | undefined): LinkOptionSchemaItem[] {\n if (!linkOptions) {\n return [];\n }\n if (isLinkOptionsArray(linkOptions)) {\n return linkOptions;\n }\n const items: LinkOptionSchemaItem[] = [];\n if (linkOptions.linkToEntry) {\n items.push({ ...linkOptions.linkToEntry, optionTitle: 'Link to an entry' });\n }\n if (linkOptions.linkToAsset) {\n items.push({ ...linkOptions.linkToAsset, optionTitle: 'Link to an asset' });\n }\n if (linkOptions.linkToCategory) {\n items.push({ ...linkOptions.linkToCategory, optionTitle: 'Link to a category' });\n }\n return items;\n}\n\nexport function LinkDropdown({\n editor,\n linkOptions = {},\n linkSelectorStorageKeyPrefix,\n openInsertLinkDialog,\n title,\n}: LinkDropdownProps) {\n const t = useTranslation();\n const craftOptions = getCraftOptionsFromLinkOptions(linkOptions);\n const elementSiteId = !isLinkOptionsArray(linkOptions) ? linkOptions?.elementSiteId : undefined;\n\n const getSelectedText = () => {\n if (!editor) {\n return '';\n }\n const { from, to } = editor.state.selection;\n return editor.state.doc.textBetween(from, to, ' ');\n };\n\n const handleCraftElementSelect = (url: string, text: string) => {\n openInsertLinkDialog({ url, text });\n };\n\n const handleCraftOption = (config: LinkElementConfig) => {\n openCraftElementModal(\n config,\n elementSiteId,\n linkSelectorStorageKeyPrefix,\n handleCraftElementSelect,\n getSelectedText,\n );\n };\n\n const handleLinkToEntry = () => {\n const config = !isLinkOptionsArray(linkOptions) ? linkOptions?.linkToEntry : undefined;\n if (config) {\n handleCraftOption(config);\n } else {\n openInsertLinkDialog();\n }\n };\n\n const handleLinkToAsset = () => {\n const config = !isLinkOptionsArray(linkOptions) ? linkOptions?.linkToAsset : undefined;\n if (config) {\n handleCraftOption(config);\n } else {\n openInsertLinkDialog();\n }\n };\n\n const handleLinkToCategory = () => {\n const config = !isLinkOptionsArray(linkOptions) ? linkOptions?.linkToCategory : undefined;\n if (config) {\n handleCraftOption(config);\n } else {\n openInsertLinkDialog();\n }\n };\n\n const handleUnlink = () => {\n editor?.chain().focus().extendMarkRange('link').unsetLink().run();\n };\n\n const isLinkActive = useEditorState({\n editor,\n selector: ({ editor: ed }) => {\n return (ed?.isFocused && ed?.isActive('link')) ?? false;\n },\n });\n\n const showCraftOptionsFromObject = !isLinkOptionsArray(linkOptions) && (linkOptions?.linkToEntry || linkOptions?.linkToAsset || linkOptions?.linkToCategory);\n const showCraftOptions = showCraftOptionsFromObject || craftOptions.length > 0;\n\n const triggerButton = (\n <Button\n variant=\"transparent\"\n className={cn(\n 'w-[32px] h-[32px]',\n 'text-[#1c2e36]',\n 'hover:bg-slate-100!',\n isLinkActive && 'bg-slate-250! hover:bg-slate-250!',\n )}\n >\n <FontAwesomeIcon icon={faLink} className=\"size-4\" />\n </Button>\n );\n\n return (\n <DropdownMenu>\n {title ? (\n <Tooltip>\n <TooltipTrigger render={<DropdownMenuTrigger render={triggerButton} />} />\n <TooltipContent sideOffset={4}>{title}</TooltipContent>\n </Tooltip>\n ) : (\n <DropdownMenuTrigger render={triggerButton} />\n )}\n <DropdownMenuContent align=\"start\" side=\"bottom\">\n {showCraftOptions && (\n <>\n {craftOptions.length > 0 ? (\n craftOptions.map((option, index) => {\n return (\n <DropdownMenuItem\n key={index}\n onClick={() => { return handleCraftOption(option); }}\n >\n {option.optionTitle}\n </DropdownMenuItem>\n );\n })\n ) : (\n <>\n {!isLinkOptionsArray(linkOptions) && linkOptions?.linkToEntry && (\n <DropdownMenuItem onClick={handleLinkToEntry}>\n {t('Link to an entry')}\n </DropdownMenuItem>\n )}\n {!isLinkOptionsArray(linkOptions) && linkOptions?.linkToAsset && (\n <DropdownMenuItem onClick={handleLinkToAsset}>\n {t('Link to an asset')}\n </DropdownMenuItem>\n )}\n {!isLinkOptionsArray(linkOptions) && linkOptions?.linkToCategory && (\n <DropdownMenuItem onClick={handleLinkToCategory}>\n {t('Link to a category')}\n </DropdownMenuItem>\n )}\n </>\n )}\n <DropdownMenuSeparator />\n </>\n )}\n <DropdownMenuItem onClick={() => {\n const selected = getSelectedText();\n const { from, to } = editor?.state.selection ?? {};\n const hasSelection = typeof from === 'number' && typeof to === 'number' && from !== to;\n openInsertLinkDialog(hasSelection ? { text: selected, from, to } : undefined);\n }}>\n {t('Insert Link')}\n </DropdownMenuItem>\n <DropdownMenuItem\n onClick={handleUnlink}\n disabled={!isLinkActive}\n className={!isLinkActive ? 'opacity-50' : ''}\n >\n {t('Unlink')}\n </DropdownMenuItem>\n </DropdownMenuContent>\n </DropdownMenu>\n );\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { VariableOption } from './VariableDropdown';
|
|
3
|
+
export type VariableGroup = {
|
|
4
|
+
label: string;
|
|
5
|
+
value: string;
|
|
6
|
+
items: VariableOption[];
|
|
7
|
+
};
|
|
8
|
+
export type VariableCommandListProps = {
|
|
9
|
+
/** Search query - controls Command filter. Use empty string to show all. */
|
|
10
|
+
search: string;
|
|
11
|
+
onSearchChange?: (value: string) => void;
|
|
12
|
+
/** Grouped items (top-level categories). When null, shows flat options (child mode). */
|
|
13
|
+
groups: VariableGroup[] | null;
|
|
14
|
+
/** Flat options for child mode when groups is null */
|
|
15
|
+
options: VariableOption[];
|
|
16
|
+
/** Currently selected value for keyboard-nav sync (inline picker). Pass to highlight. */
|
|
17
|
+
selectedValue?: string | null;
|
|
18
|
+
onSelect: (item: VariableOption, baseVariable?: VariableOption) => void;
|
|
19
|
+
/** Placeholder for search input */
|
|
20
|
+
placeholder?: string;
|
|
21
|
+
/** Show search input */
|
|
22
|
+
showSearch?: boolean;
|
|
23
|
+
/** Disable built-in filtering - we provide pre-filtered items */
|
|
24
|
+
shouldFilter?: boolean;
|
|
25
|
+
/** Optional: render back button row when in child mode */
|
|
26
|
+
onBack?: () => void;
|
|
27
|
+
/** True when showing a drilled-in child page; used to restore scroll when navigating back */
|
|
28
|
+
isChildMode?: boolean;
|
|
29
|
+
/** When false, don't auto-select first item (e.g. for toolbar/button trigger) */
|
|
30
|
+
selectFirstItem?: boolean;
|
|
31
|
+
/** Control autofocus of command search input when list opens/navigates */
|
|
32
|
+
autoFocusSearchInput?: boolean;
|
|
33
|
+
/** Optional content rendered directly below search input */
|
|
34
|
+
afterSearchContent?: React.ReactNode;
|
|
35
|
+
};
|
|
36
|
+
export declare function VariableCommandList({ search, onSearchChange, groups, options, selectedValue, onSelect, placeholder, showSearch, shouldFilter, onBack, isChildMode, selectFirstItem, autoFocusSearchInput, afterSearchContent, }: VariableCommandListProps): import("react/jsx-runtime").JSX.Element;
|
|
37
|
+
//# sourceMappingURL=VariableCommandList.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VariableCommandList.d.ts","sourceRoot":"","sources":["../../../src/components/tiptap/VariableCommandList.tsx"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAkC,MAAM,OAAO,CAAC;AAcvD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAGzD,MAAM,MAAM,aAAa,GAAG;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,cAAc,EAAE,CAAC;CAC3B,CAAC;AA0CF,MAAM,MAAM,wBAAwB,GAAG;IACnC,4EAA4E;IAC5E,MAAM,EAAE,MAAM,CAAC;IACf,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACzC,wFAAwF;IACxF,MAAM,EAAE,aAAa,EAAE,GAAG,IAAI,CAAC;IAC/B,sDAAsD;IACtD,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,yFAAyF;IACzF,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,QAAQ,EAAE,CAAC,IAAI,EAAE,cAAc,EAAE,YAAY,CAAC,EAAE,cAAc,KAAK,IAAI,CAAC;IACxE,mCAAmC;IACnC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,wBAAwB;IACxB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,iEAAiE;IACjE,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,0DAA0D;IAC1D,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,6FAA6F;IAC7F,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,iFAAiF;IACjF,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,0EAA0E;IAC1E,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,4DAA4D;IAC5D,kBAAkB,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CACxC,CAAC;AAEF,wBAAgB,mBAAmB,CAAC,EAChC,MAAM,EACN,cAAc,EACd,MAAM,EACN,OAAO,EACP,aAAa,EACb,QAAQ,EACR,WAAW,EACX,UAAiB,EACjB,YAAoB,EACpB,MAAM,EACN,WAAmB,EACnB,eAAsB,EACtB,oBAA2B,EAC3B,kBAAkB,GACrB,EAAE,wBAAwB,2CAoK1B"}
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import { cn } from "../../utils/classes.js";
|
|
2
|
+
import "../../utils/index.js";
|
|
3
|
+
import { Command, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList, CommandSeparator } from "../Command.js";
|
|
4
|
+
import { useTranslation } from "../../hooks/useTranslation.js";
|
|
5
|
+
import "../../hooks/index.js";
|
|
6
|
+
import { Button } from "../Button.js";
|
|
7
|
+
import React, { useLayoutEffect, useRef } from "react";
|
|
8
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
9
|
+
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
|
|
10
|
+
import { faChevronLeft, faChevronRight } from "@fortawesome/pro-solid-svg-icons";
|
|
11
|
+
//#region src/components/tiptap/VariableCommandList.tsx
|
|
12
|
+
/**
|
|
13
|
+
* Command-based variable list. Used by VariableDropdown and InlineVariablePickerPopover.
|
|
14
|
+
* Supports grouped items and nested "pages" (parent → children) via groups/options.
|
|
15
|
+
*/
|
|
16
|
+
/** Renders child item only when search is non-empty and child matches (cmdk sub-item pattern) */
|
|
17
|
+
function VariableSubItem({ child, parent, groupLabel, search, handleSelectItem }) {
|
|
18
|
+
const q = search.trim().toLowerCase();
|
|
19
|
+
if (!q) return null;
|
|
20
|
+
if (!((child.label ?? "").toLowerCase().includes(q) || String(child.value ?? "").toLowerCase().includes(q))) return null;
|
|
21
|
+
const key = child.value ?? child.label ?? `sub-${parent.label}-${child.label}`;
|
|
22
|
+
return /* @__PURE__ */ jsx(CommandItem, {
|
|
23
|
+
value: child.value ?? child.label ?? key,
|
|
24
|
+
onSelect: () => {
|
|
25
|
+
return handleSelectItem(child, parent);
|
|
26
|
+
},
|
|
27
|
+
keywords: [
|
|
28
|
+
child.label,
|
|
29
|
+
child.value ?? "",
|
|
30
|
+
parent.label,
|
|
31
|
+
groupLabel
|
|
32
|
+
],
|
|
33
|
+
children: child.label
|
|
34
|
+
}, key);
|
|
35
|
+
}
|
|
36
|
+
function VariableCommandList({ search, onSearchChange, groups, options, selectedValue, onSelect, placeholder, showSearch = true, shouldFilter = false, onBack, isChildMode = false, selectFirstItem = true, autoFocusSearchInput = true, afterSearchContent }) {
|
|
37
|
+
const t = useTranslation();
|
|
38
|
+
const listRef = useRef(null);
|
|
39
|
+
const commandRef = useRef(null);
|
|
40
|
+
const savedScrollTopRef = useRef(null);
|
|
41
|
+
const flatItems = groups ? groups.flatMap((g) => {
|
|
42
|
+
return g.items;
|
|
43
|
+
}) : options;
|
|
44
|
+
const isControlled = selectedValue !== void 0 && selectedValue !== null;
|
|
45
|
+
const currentValue = selectedValue ?? (selectFirstItem ? flatItems[0]?.value ?? "" : "");
|
|
46
|
+
const commandProps = isControlled ? {
|
|
47
|
+
value: currentValue,
|
|
48
|
+
onValueChange: () => {}
|
|
49
|
+
} : { defaultValue: currentValue || void 0 };
|
|
50
|
+
const handleSelectItem = (item, baseVariable) => {
|
|
51
|
+
if (Array.isArray(item.children) && item.children.length > 0) savedScrollTopRef.current = listRef.current?.scrollTop ?? 0;
|
|
52
|
+
onSelect(item, baseVariable);
|
|
53
|
+
};
|
|
54
|
+
const wasChildModeRef = React.useRef(isChildMode);
|
|
55
|
+
useLayoutEffect(() => {
|
|
56
|
+
const wasChild = wasChildModeRef.current;
|
|
57
|
+
wasChildModeRef.current = isChildMode;
|
|
58
|
+
if (wasChild && !isChildMode && savedScrollTopRef.current != null && listRef.current) {
|
|
59
|
+
listRef.current.scrollTop = savedScrollTopRef.current;
|
|
60
|
+
savedScrollTopRef.current = null;
|
|
61
|
+
}
|
|
62
|
+
if (!wasChild && isChildMode && showSearch && autoFocusSearchInput) (commandRef.current?.querySelector("[data-slot=\"command-input\"]"))?.focus();
|
|
63
|
+
}, [
|
|
64
|
+
autoFocusSearchInput,
|
|
65
|
+
isChildMode,
|
|
66
|
+
showSearch
|
|
67
|
+
]);
|
|
68
|
+
const handleKeyDown = (e) => {
|
|
69
|
+
if (onBack && !search.trim() && e.key === "Backspace") {
|
|
70
|
+
e.preventDefault();
|
|
71
|
+
e.stopPropagation();
|
|
72
|
+
onBack();
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
const content = /* @__PURE__ */ jsx("div", {
|
|
76
|
+
ref: commandRef,
|
|
77
|
+
className: "contents",
|
|
78
|
+
children: /* @__PURE__ */ jsxs(Command, {
|
|
79
|
+
shouldFilter,
|
|
80
|
+
className: "border-0 shadow-none rounded-none",
|
|
81
|
+
...commandProps,
|
|
82
|
+
children: [
|
|
83
|
+
showSearch && /* @__PURE__ */ jsx(CommandInput, {
|
|
84
|
+
value: search,
|
|
85
|
+
onValueChange: onSearchChange,
|
|
86
|
+
placeholder: placeholder ?? t("Search variables"),
|
|
87
|
+
className: "border-0"
|
|
88
|
+
}),
|
|
89
|
+
afterSearchContent,
|
|
90
|
+
onBack && /* @__PURE__ */ jsxs(Button, {
|
|
91
|
+
variant: "none",
|
|
92
|
+
className: cn(["w-full text-left text-[11px] flex flex-1 items-center justify-start", "hover:bg-slate-100 gap-1 border-b border-slate-150 px-2 py-1.5"]),
|
|
93
|
+
onClick: (e) => {
|
|
94
|
+
e.preventDefault();
|
|
95
|
+
onBack();
|
|
96
|
+
},
|
|
97
|
+
children: [/* @__PURE__ */ jsx(FontAwesomeIcon, {
|
|
98
|
+
icon: faChevronLeft,
|
|
99
|
+
className: "size-[8px] shrink-0"
|
|
100
|
+
}), t("Back")]
|
|
101
|
+
}),
|
|
102
|
+
/* @__PURE__ */ jsxs(CommandList, {
|
|
103
|
+
ref: listRef,
|
|
104
|
+
className: "max-h-[280px]",
|
|
105
|
+
children: [/* @__PURE__ */ jsx(CommandEmpty, { children: t("No variables found.") }), groups ? groups.map((group, gi) => {
|
|
106
|
+
return /* @__PURE__ */ jsxs(React.Fragment, { children: [gi > 0 && /* @__PURE__ */ jsx(CommandSeparator, {}), /* @__PURE__ */ jsx(CommandGroup, {
|
|
107
|
+
heading: group.label,
|
|
108
|
+
children: group.items.map((item, ii) => {
|
|
109
|
+
const q = search.trim().toLowerCase();
|
|
110
|
+
const hasChildren = Array.isArray(item.children) && item.children.length > 0;
|
|
111
|
+
const showParent = !hasChildren || !q;
|
|
112
|
+
return /* @__PURE__ */ jsxs(React.Fragment, { children: [showParent && /* @__PURE__ */ jsxs(CommandItem, {
|
|
113
|
+
value: item.value ?? item.label ?? `${gi}-${ii}`,
|
|
114
|
+
onSelect: () => {
|
|
115
|
+
return handleSelectItem(item);
|
|
116
|
+
},
|
|
117
|
+
keywords: [
|
|
118
|
+
item.label,
|
|
119
|
+
item.value ?? "",
|
|
120
|
+
group.label
|
|
121
|
+
],
|
|
122
|
+
children: [/* @__PURE__ */ jsx("span", {
|
|
123
|
+
className: "truncate flex-1",
|
|
124
|
+
children: item.label
|
|
125
|
+
}), hasChildren && /* @__PURE__ */ jsx(FontAwesomeIcon, {
|
|
126
|
+
icon: faChevronRight,
|
|
127
|
+
className: cn("size-3 shrink-0 text-gray-400 ml-2"),
|
|
128
|
+
"aria-hidden": true
|
|
129
|
+
})]
|
|
130
|
+
}), hasChildren && item.children.map((child) => {
|
|
131
|
+
return /* @__PURE__ */ jsx(VariableSubItem, {
|
|
132
|
+
child,
|
|
133
|
+
parent: item,
|
|
134
|
+
groupLabel: group.label,
|
|
135
|
+
search,
|
|
136
|
+
handleSelectItem
|
|
137
|
+
}, child.value ?? child.label ?? `${gi}-${ii}-${child.label}`);
|
|
138
|
+
})] }, item.value ?? item.label ?? `${gi}-${ii}`);
|
|
139
|
+
})
|
|
140
|
+
})] }, group.value ?? group.label ?? gi);
|
|
141
|
+
}) : /* @__PURE__ */ jsx(CommandGroup, {
|
|
142
|
+
heading: t("Selectors"),
|
|
143
|
+
children: options.map((item, i) => {
|
|
144
|
+
return /* @__PURE__ */ jsx(CommandItem, {
|
|
145
|
+
value: item.value ?? item.label ?? `opt-${i}`,
|
|
146
|
+
onSelect: () => {
|
|
147
|
+
return handleSelectItem(item);
|
|
148
|
+
},
|
|
149
|
+
children: item.label
|
|
150
|
+
}, item.value ?? item.label ?? `opt-${i}`);
|
|
151
|
+
})
|
|
152
|
+
})]
|
|
153
|
+
})
|
|
154
|
+
]
|
|
155
|
+
})
|
|
156
|
+
});
|
|
157
|
+
return onBack ? /* @__PURE__ */ jsx("div", {
|
|
158
|
+
onKeyDown: handleKeyDown,
|
|
159
|
+
className: "contents",
|
|
160
|
+
children: content
|
|
161
|
+
}) : content;
|
|
162
|
+
}
|
|
163
|
+
//#endregion
|
|
164
|
+
export { VariableCommandList };
|
|
165
|
+
|
|
166
|
+
//# sourceMappingURL=VariableCommandList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VariableCommandList.js","names":[],"sources":["../../../src/components/tiptap/VariableCommandList.tsx"],"sourcesContent":["/**\n * Command-based variable list. Used by VariableDropdown and InlineVariablePickerPopover.\n * Supports grouped items and nested \"pages\" (parent → children) via groups/options.\n */\n\nimport React, { useRef, useLayoutEffect } from 'react';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faChevronLeft, faChevronRight } from '@fortawesome/pro-solid-svg-icons';\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n CommandSeparator,\n} from '@verbb/plugin-kit-react/components/Command';\nimport { useTranslation } from '@verbb/plugin-kit-react/hooks';\nimport { cn } from '@verbb/plugin-kit-react/utils';\nimport type { VariableOption } from './VariableDropdown';\nimport { Button } from '@verbb/plugin-kit-react/components/Button';\n\nexport type VariableGroup = {\n label: string;\n value: string;\n items: VariableOption[];\n};\n\n/** Renders child item only when search is non-empty and child matches (cmdk sub-item pattern) */\nfunction VariableSubItem({\n child,\n parent,\n groupLabel,\n search,\n handleSelectItem,\n}: {\n child: VariableOption;\n parent: VariableOption;\n groupLabel: string;\n search: string;\n handleSelectItem: (item: VariableOption, baseVariable?: VariableOption) => void;\n}) {\n const q = search.trim().toLowerCase();\n if (!q) {\n return null;\n }\n const matches =\n (child.label ?? '').toLowerCase().includes(q) ||\n String(child.value ?? '').toLowerCase().includes(q);\n if (!matches) {\n return null;\n }\n const key = child.value ?? child.label ?? `sub-${parent.label}-${child.label}`;\n const value = child.value ?? child.label ?? key;\n return (\n <CommandItem\n key={key}\n value={value}\n onSelect={() => {\n return handleSelectItem(child, parent);\n }}\n keywords={[child.label, child.value ?? '', parent.label, groupLabel]}\n >\n {child.label}\n </CommandItem>\n );\n}\n\nexport type VariableCommandListProps = {\n /** Search query - controls Command filter. Use empty string to show all. */\n search: string;\n onSearchChange?: (value: string) => void;\n /** Grouped items (top-level categories). When null, shows flat options (child mode). */\n groups: VariableGroup[] | null;\n /** Flat options for child mode when groups is null */\n options: VariableOption[];\n /** Currently selected value for keyboard-nav sync (inline picker). Pass to highlight. */\n selectedValue?: string | null;\n onSelect: (item: VariableOption, baseVariable?: VariableOption) => void;\n /** Placeholder for search input */\n placeholder?: string;\n /** Show search input */\n showSearch?: boolean;\n /** Disable built-in filtering - we provide pre-filtered items */\n shouldFilter?: boolean;\n /** Optional: render back button row when in child mode */\n onBack?: () => void;\n /** True when showing a drilled-in child page; used to restore scroll when navigating back */\n isChildMode?: boolean;\n /** When false, don't auto-select first item (e.g. for toolbar/button trigger) */\n selectFirstItem?: boolean;\n /** Control autofocus of command search input when list opens/navigates */\n autoFocusSearchInput?: boolean;\n /** Optional content rendered directly below search input */\n afterSearchContent?: React.ReactNode;\n};\n\nexport function VariableCommandList({\n search,\n onSearchChange,\n groups,\n options,\n selectedValue,\n onSelect,\n placeholder,\n showSearch = true,\n shouldFilter = false,\n onBack,\n isChildMode = false,\n selectFirstItem = true,\n autoFocusSearchInput = true,\n afterSearchContent,\n}: VariableCommandListProps) {\n const t = useTranslation();\n const listRef = useRef<HTMLDivElement>(null);\n const commandRef = useRef<HTMLDivElement>(null);\n const savedScrollTopRef = useRef<number | null>(null);\n\n const flatItems = groups ? groups.flatMap(g => {\n return g.items;\n }) : options;\n const isControlled = selectedValue !== undefined && selectedValue !== null;\n const currentValue = selectedValue ?? (selectFirstItem ? flatItems[0]?.value ?? '' : '');\n // Dropdown: uncontrolled (no value/onValueChange) so cmdk handles scroll natively like shadcn static example\n const commandProps = isControlled\n ? { value: currentValue, onValueChange: () => { } }\n : { defaultValue: currentValue || undefined };\n\n const handleSelectItem = (item: VariableOption, baseVariable?: VariableOption) => {\n if (Array.isArray(item.children) && item.children.length > 0) {\n savedScrollTopRef.current = listRef.current?.scrollTop ?? 0;\n }\n onSelect(item, baseVariable);\n };\n\n const wasChildModeRef = React.useRef(isChildMode);\n useLayoutEffect(() => {\n const wasChild = wasChildModeRef.current;\n wasChildModeRef.current = isChildMode;\n if (wasChild && !isChildMode && savedScrollTopRef.current != null && listRef.current) {\n listRef.current.scrollTop = savedScrollTopRef.current;\n savedScrollTopRef.current = null;\n }\n if (!wasChild && isChildMode && showSearch && autoFocusSearchInput) {\n const input = commandRef.current?.querySelector<HTMLInputElement>('[data-slot=\"command-input\"]');\n input?.focus();\n }\n }, [autoFocusSearchInput, isChildMode, showSearch]);\n\n const handleKeyDown = (e: React.KeyboardEvent) => {\n if (onBack && !search.trim() && e.key === 'Backspace') {\n e.preventDefault();\n e.stopPropagation();\n onBack();\n }\n };\n\n const content = (\n <div ref={commandRef} className=\"contents\">\n <Command\n shouldFilter={shouldFilter}\n className=\"border-0 shadow-none rounded-none\"\n {...commandProps}\n >\n {showSearch && (\n <CommandInput\n value={search}\n onValueChange={onSearchChange}\n placeholder={placeholder ?? t('Search variables')}\n className=\"border-0\"\n />\n )}\n\n {afterSearchContent}\n\n {onBack && (\n <Button\n variant=\"none\"\n className={cn([\n 'w-full text-left text-[11px] flex flex-1 items-center justify-start',\n 'hover:bg-slate-100 gap-1 border-b border-slate-150 px-2 py-1.5'\n ])}\n onClick={(e) => {\n e.preventDefault();\n onBack();\n }}\n >\n <FontAwesomeIcon icon={faChevronLeft} className=\"size-[8px] shrink-0\" />\n {t('Back')}\n </Button>\n )}\n\n <CommandList ref={listRef} className=\"max-h-[280px]\">\n <CommandEmpty>{t('No variables found.')}</CommandEmpty>\n\n {groups ? (\n groups.map((group, gi) => {\n return (\n <React.Fragment key={group.value ?? group.label ?? gi}>\n {gi > 0 && <CommandSeparator />}\n <CommandGroup heading={group.label}>\n {group.items.map((item, ii) => {\n const q = search.trim().toLowerCase();\n const hasChildren = Array.isArray(item.children) && item.children.length > 0;\n // In search mode, for nested items show only matching children (visual test behavior).\n // Parents are still shown when not searching.\n const showParent = !hasChildren || !q;\n return (\n <React.Fragment key={item.value ?? item.label ?? `${gi}-${ii}`}>\n {showParent && (\n <CommandItem\n value={item.value ?? item.label ?? `${gi}-${ii}`}\n onSelect={() => {\n return handleSelectItem(item);\n }}\n keywords={[item.label, item.value ?? '', group.label]}\n >\n <span className=\"truncate flex-1\">{item.label}</span>\n {hasChildren && (\n <FontAwesomeIcon\n icon={faChevronRight}\n className={cn('size-3 shrink-0 text-gray-400 ml-2')}\n aria-hidden\n />\n )}\n </CommandItem>\n )}\n {hasChildren &&\n item.children!.map(child => {\n return (\n <VariableSubItem\n key={child.value ?? child.label ?? `${gi}-${ii}-${child.label}`}\n child={child}\n parent={item}\n groupLabel={group.label}\n search={search}\n handleSelectItem={handleSelectItem}\n />\n );\n })}\n </React.Fragment>\n );\n })}\n </CommandGroup>\n </React.Fragment>\n );\n })\n ) : (\n <CommandGroup heading={t('Selectors')}>\n {options.map((item, i) => {\n return (\n <CommandItem\n key={item.value ?? item.label ?? `opt-${i}`}\n value={item.value ?? item.label ?? `opt-${i}`}\n onSelect={() => {\n return handleSelectItem(item);\n }}\n >\n {item.label}\n </CommandItem>\n );\n })}\n </CommandGroup>\n )}\n </CommandList>\n </Command>\n </div>\n );\n\n return onBack ? (\n <div onKeyDown={handleKeyDown} className=\"contents\">\n {content}\n </div>\n ) : (\n content\n );\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Editor } from '@tiptap/core';
|
|
2
|
+
export type VariableOption = {
|
|
3
|
+
label: string;
|
|
4
|
+
value?: string;
|
|
5
|
+
children?: VariableOption[];
|
|
6
|
+
/** Optional display bucket for first-level grouping (e.g. page headings). */
|
|
7
|
+
pageLabel?: string;
|
|
8
|
+
/** For child items: selector | format | value. Used by variableSerialization. */
|
|
9
|
+
group?: string;
|
|
10
|
+
/** Supported transform value types for this variable (e.g. text, number, date, url). */
|
|
11
|
+
transformValueTypes?: string[];
|
|
12
|
+
};
|
|
13
|
+
export type VariableCategories = {
|
|
14
|
+
[key: string]: VariableOption[] | undefined;
|
|
15
|
+
};
|
|
16
|
+
export declare function formatVariableCategoryLabel(key: string, labels?: Record<string, string> | null): string;
|
|
17
|
+
type VariableDropdownProps = {
|
|
18
|
+
editor: Editor | null | undefined;
|
|
19
|
+
variableCategories: VariableCategories;
|
|
20
|
+
variableCategoryLabels?: Record<string, string>;
|
|
21
|
+
variableCategoryOrder?: string[];
|
|
22
|
+
title?: string;
|
|
23
|
+
buttonLabel?: string;
|
|
24
|
+
buttonVariant?: 'default' | 'primary' | 'secondary' | 'dashed' | 'outline' | 'transparent' | 'link' | 'none';
|
|
25
|
+
buttonSize?: 'default' | 'none' | 'xs' | 'sm' | 'lg' | 'xl';
|
|
26
|
+
buttonClassName?: string;
|
|
27
|
+
open?: boolean;
|
|
28
|
+
onOpenChange?: (open: boolean) => void;
|
|
29
|
+
triggerMode?: 'toolbar' | 'input';
|
|
30
|
+
};
|
|
31
|
+
export declare function VariableDropdown({ editor, variableCategories, variableCategoryLabels, variableCategoryOrder, title, buttonLabel, buttonVariant, buttonSize, buttonClassName, open, onOpenChange, triggerMode, }: VariableDropdownProps): import("react/jsx-runtime").JSX.Element | null;
|
|
32
|
+
export {};
|
|
33
|
+
//# sourceMappingURL=VariableDropdown.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VariableDropdown.d.ts","sourceRoot":"","sources":["../../../src/components/tiptap/VariableDropdown.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAa3C,MAAM,MAAM,cAAc,GAAG;IACzB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAC;IAC5B,6EAA6E;IAC7E,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,iFAAiF;IACjF,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wFAAwF;IACxF,mBAAmB,CAAC,EAAE,MAAM,EAAE,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC7B,CAAC,GAAG,EAAE,MAAM,GAAG,cAAc,EAAE,GAAG,SAAS,CAAC;CAC/C,CAAC;AAEF,wBAAgB,2BAA2B,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,IAAI,GAAG,MAAM,CAEvG;AAED,KAAK,qBAAqB,GAAG;IACzB,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,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,aAAa,CAAC,EAAE,SAAS,GAAG,SAAS,GAAG,WAAW,GAAG,QAAQ,GAAG,SAAS,GAAG,aAAa,GAAG,MAAM,GAAG,MAAM,CAAC;IAC7G,UAAU,CAAC,EAAE,SAAS,GAAG,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;IAC5D,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACvC,WAAW,CAAC,EAAE,SAAS,GAAG,OAAO,CAAC;CACrC,CAAC;AAEF,wBAAgB,gBAAgB,CAAC,EAC7B,MAAM,EACN,kBAAkB,EAClB,sBAAsB,EACtB,qBAAqB,EACrB,KAAK,EACL,WAAW,EACX,aAAa,EACb,UAAU,EACV,eAAe,EACf,IAAI,EACJ,YAAY,EACZ,WAAuB,GAC1B,EAAE,qBAAqB,kDA2HvB"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { cn } from "../../utils/classes.js";
|
|
2
|
+
import "../../utils/index.js";
|
|
3
|
+
import { useTranslation } from "../../hooks/useTranslation.js";
|
|
4
|
+
import "../../hooks/index.js";
|
|
5
|
+
import { Tooltip, TooltipContent, TooltipTrigger } from "../Tooltip.js";
|
|
6
|
+
import { buildVariableTagAttrs } from "./variableSerialization.js";
|
|
7
|
+
import { VariableCommandList } from "./VariableCommandList.js";
|
|
8
|
+
import { useVariablePicker } from "./useVariablePicker.js";
|
|
9
|
+
import { Popover, PopoverContent, PopoverTrigger } from "../Popover.js";
|
|
10
|
+
import "../index.js";
|
|
11
|
+
import { Button } from "../Button.js";
|
|
12
|
+
import { useState } from "react";
|
|
13
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
14
|
+
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
|
|
15
|
+
import { useEditorState } from "@tiptap/react";
|
|
16
|
+
import { faPlusCircle } from "@fortawesome/pro-regular-svg-icons";
|
|
17
|
+
//#region src/components/tiptap/VariableDropdown.tsx
|
|
18
|
+
function formatVariableCategoryLabel(key, labels) {
|
|
19
|
+
return labels?.[key] ?? key;
|
|
20
|
+
}
|
|
21
|
+
function VariableDropdown({ editor, variableCategories, variableCategoryLabels, variableCategoryOrder, title, buttonLabel, buttonVariant, buttonSize, buttonClassName, open, onOpenChange, triggerMode = "toolbar" }) {
|
|
22
|
+
const t = useTranslation();
|
|
23
|
+
const [uncontrolledOpen, setUncontrolledOpen] = useState(false);
|
|
24
|
+
const isControlledOpen = typeof open === "boolean";
|
|
25
|
+
const isOpen = isControlledOpen ? open : uncontrolledOpen;
|
|
26
|
+
const picker = useVariablePicker({
|
|
27
|
+
variableCategories,
|
|
28
|
+
variableCategoryLabels,
|
|
29
|
+
variableCategoryOrder,
|
|
30
|
+
isOpen,
|
|
31
|
+
onApply: (baseVariable, variable) => {
|
|
32
|
+
const attrs = buildVariableTagAttrs(baseVariable, variable);
|
|
33
|
+
(editor?.chain())?.focus?.()?.setVariableTag?.(attrs)?.run?.();
|
|
34
|
+
if (!isControlledOpen) setUncontrolledOpen(false);
|
|
35
|
+
onOpenChange?.(false);
|
|
36
|
+
picker.reset();
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
const isVariableActive = useEditorState({
|
|
40
|
+
editor,
|
|
41
|
+
selector: ({ editor: ed }) => {
|
|
42
|
+
return (ed?.isFocused && ed?.isActive("variableTag")) ?? false;
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
const handleOpenChange = (nextOpen) => {
|
|
46
|
+
if (!nextOpen) picker.reset();
|
|
47
|
+
if (!isControlledOpen) setUncontrolledOpen(nextOpen);
|
|
48
|
+
onOpenChange?.(nextOpen);
|
|
49
|
+
};
|
|
50
|
+
if (!Object.values(variableCategories ?? {}).some((items) => {
|
|
51
|
+
return Array.isArray(items) && items.length > 0;
|
|
52
|
+
})) return null;
|
|
53
|
+
const triggerButton = /* @__PURE__ */ jsxs(Button, {
|
|
54
|
+
variant: buttonVariant ?? "none",
|
|
55
|
+
size: buttonSize,
|
|
56
|
+
className: cn(triggerMode === "toolbar" && [
|
|
57
|
+
buttonLabel ? "h-[32px] px-[8px] gap-1.5" : "w-[32px] h-[32px]",
|
|
58
|
+
"text-[#1c2e36]",
|
|
59
|
+
"hover:bg-slate-100!",
|
|
60
|
+
isVariableActive && "bg-slate-250! hover:bg-slate-250!"
|
|
61
|
+
], triggerMode === "input" && [
|
|
62
|
+
"absolute right-[1px] top-1/2 -translate-y-1/2",
|
|
63
|
+
"border-l border-transparent",
|
|
64
|
+
"rounded-[3px] rounded-l-none",
|
|
65
|
+
"h-[calc(100%-2px)]",
|
|
66
|
+
"text-[#8d959b]",
|
|
67
|
+
"bg-white hover:bg-slate-50",
|
|
68
|
+
"border-[#d7dfe7]",
|
|
69
|
+
"text-[#1c2e36]"
|
|
70
|
+
], buttonClassName ?? ""),
|
|
71
|
+
children: [/* @__PURE__ */ jsx(FontAwesomeIcon, {
|
|
72
|
+
icon: faPlusCircle,
|
|
73
|
+
className: "size-4"
|
|
74
|
+
}), buttonLabel && /* @__PURE__ */ jsx("span", { children: buttonLabel })]
|
|
75
|
+
});
|
|
76
|
+
return /* @__PURE__ */ jsxs(Popover, {
|
|
77
|
+
modal: false,
|
|
78
|
+
open: isOpen,
|
|
79
|
+
onOpenChange: handleOpenChange,
|
|
80
|
+
children: [buttonLabel || title ? /* @__PURE__ */ jsxs(Tooltip, { children: [/* @__PURE__ */ jsx(TooltipTrigger, { render: /* @__PURE__ */ jsx(PopoverTrigger, {
|
|
81
|
+
nativeButton: true,
|
|
82
|
+
render: triggerButton
|
|
83
|
+
}) }), /* @__PURE__ */ jsx(TooltipContent, {
|
|
84
|
+
sideOffset: 4,
|
|
85
|
+
children: buttonLabel || title
|
|
86
|
+
})] }) : /* @__PURE__ */ jsx(PopoverTrigger, {
|
|
87
|
+
nativeButton: true,
|
|
88
|
+
render: triggerButton
|
|
89
|
+
}), /* @__PURE__ */ jsx(PopoverContent, {
|
|
90
|
+
align: triggerMode === "input" ? "end" : "start",
|
|
91
|
+
side: "bottom",
|
|
92
|
+
sideOffset: 6,
|
|
93
|
+
positionMethod: "fixed",
|
|
94
|
+
collisionAvoidance: {
|
|
95
|
+
side: "flip",
|
|
96
|
+
align: "shift",
|
|
97
|
+
fallbackAxisSide: "none"
|
|
98
|
+
},
|
|
99
|
+
className: "min-w-[260px] max-w-[360px] p-0 overflow-hidden flex flex-col",
|
|
100
|
+
portalClassName: "z-250",
|
|
101
|
+
children: /* @__PURE__ */ jsx(VariableCommandList, {
|
|
102
|
+
search: picker.search,
|
|
103
|
+
onSearchChange: picker.setSearch,
|
|
104
|
+
groups: picker.groups,
|
|
105
|
+
options: picker.options,
|
|
106
|
+
onSelect: picker.handleSelect,
|
|
107
|
+
placeholder: t("Search variables"),
|
|
108
|
+
showSearch: true,
|
|
109
|
+
shouldFilter: false,
|
|
110
|
+
onBack: picker.page ? picker.handleBack : void 0,
|
|
111
|
+
isChildMode: !!picker.page,
|
|
112
|
+
selectFirstItem: triggerMode === "input",
|
|
113
|
+
autoFocusSearchInput: triggerMode !== "input"
|
|
114
|
+
})
|
|
115
|
+
})]
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
//#endregion
|
|
119
|
+
export { VariableDropdown, formatVariableCategoryLabel };
|
|
120
|
+
|
|
121
|
+
//# sourceMappingURL=VariableDropdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VariableDropdown.js","names":[],"sources":["../../../src/components/tiptap/VariableDropdown.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport { useEditorState } from '@tiptap/react';\nimport type { Editor } from '@tiptap/core';\nimport { Button } from '@verbb/plugin-kit-react/components/Button';\nimport { Popover, PopoverContent, PopoverTrigger } from '@verbb/plugin-kit-react/components';\nimport { Tooltip, TooltipContent, TooltipTrigger } from '@verbb/plugin-kit-react/components/Tooltip';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faPlusCircle } from '@fortawesome/pro-regular-svg-icons';\nimport { cn } from '@verbb/plugin-kit-react/utils';\nimport { useTranslation } from '@verbb/plugin-kit-react/hooks';\n\nimport { buildVariableTagAttrs } from './variableSerialization';\nimport { VariableCommandList } from './VariableCommandList';\nimport { useVariablePicker } from './useVariablePicker';\n\nexport type VariableOption = {\n label: string;\n value?: string;\n children?: VariableOption[];\n /** Optional display bucket for first-level grouping (e.g. page headings). */\n pageLabel?: string;\n /** For child items: selector | format | value. Used by variableSerialization. */\n group?: string;\n /** Supported transform value types for this variable (e.g. text, number, date, url). */\n transformValueTypes?: string[];\n};\n\nexport type VariableCategories = {\n [key: string]: VariableOption[] | undefined;\n};\n\nexport function formatVariableCategoryLabel(key: string, labels?: Record<string, string> | null): string {\n return labels?.[key] ?? key;\n}\n\ntype VariableDropdownProps = {\n editor: Editor | null | undefined;\n variableCategories: VariableCategories;\n variableCategoryLabels?: Record<string, string>;\n variableCategoryOrder?: string[];\n title?: string;\n buttonLabel?: string;\n buttonVariant?: 'default' | 'primary' | 'secondary' | 'dashed' | 'outline' | 'transparent' | 'link' | 'none';\n buttonSize?: 'default' | 'none' | 'xs' | 'sm' | 'lg' | 'xl';\n buttonClassName?: string;\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n triggerMode?: 'toolbar' | 'input';\n};\n\nexport function VariableDropdown({\n editor,\n variableCategories,\n variableCategoryLabels,\n variableCategoryOrder,\n title,\n buttonLabel,\n buttonVariant,\n buttonSize,\n buttonClassName,\n open,\n onOpenChange,\n triggerMode = 'toolbar',\n}: VariableDropdownProps) {\n const t = useTranslation();\n const [uncontrolledOpen, setUncontrolledOpen] = useState(false);\n\n const isControlledOpen = typeof open === 'boolean';\n const isOpen = isControlledOpen ? open : uncontrolledOpen;\n\n const picker = useVariablePicker({\n variableCategories,\n variableCategoryLabels,\n variableCategoryOrder,\n isOpen,\n onApply: (baseVariable, variable) => {\n const attrs = buildVariableTagAttrs(baseVariable, variable);\n const chain = editor?.chain();\n chain?.focus?.()?.setVariableTag?.(attrs)?.run?.();\n if (!isControlledOpen) {\n setUncontrolledOpen(false);\n }\n onOpenChange?.(false);\n picker.reset();\n },\n });\n\n const isVariableActive = useEditorState({\n editor: editor as import('@tiptap/core').Editor | null,\n selector: ({ editor: ed }) => {\n return (ed?.isFocused && ed?.isActive('variableTag')) ?? false;\n },\n });\n\n const handleOpenChange = (nextOpen: boolean) => {\n if (!nextOpen) {\n picker.reset();\n }\n if (!isControlledOpen) {\n setUncontrolledOpen(nextOpen);\n }\n onOpenChange?.(nextOpen);\n };\n\n const hasAnyVariables = Object.values(variableCategories ?? {}).some(\n items => {\n return Array.isArray(items) && items.length > 0;\n },\n );\n\n if (!hasAnyVariables) {\n return null;\n }\n\n const triggerButton = (\n <Button\n variant={buttonVariant ?? 'none'}\n size={buttonSize}\n className={cn(\n triggerMode === 'toolbar' && [\n buttonLabel ? 'h-[32px] px-[8px] gap-1.5' : 'w-[32px] h-[32px]',\n 'text-[#1c2e36]',\n 'hover:bg-slate-100!',\n isVariableActive && 'bg-slate-250! hover:bg-slate-250!',\n ],\n triggerMode === 'input' && [\n 'absolute right-[1px] top-1/2 -translate-y-1/2',\n 'border-l border-transparent',\n 'rounded-[3px] rounded-l-none',\n 'h-[calc(100%-2px)]',\n 'text-[#8d959b]',\n 'bg-white hover:bg-slate-50',\n 'border-[#d7dfe7]',\n 'text-[#1c2e36]',\n ],\n\n buttonClassName ?? '',\n )}\n >\n <FontAwesomeIcon icon={faPlusCircle} className=\"size-4\" />\n {buttonLabel && <span>{buttonLabel}</span>}\n </Button>\n );\n\n const content = (\n <Popover modal={false} open={isOpen} onOpenChange={handleOpenChange}>\n {(buttonLabel || title) ? (\n <Tooltip>\n <TooltipTrigger render={<PopoverTrigger nativeButton={true} render={triggerButton} />} />\n <TooltipContent sideOffset={4}>{buttonLabel || title}</TooltipContent>\n </Tooltip>\n ) : (\n <PopoverTrigger nativeButton={true} render={triggerButton} />\n )}\n <PopoverContent\n align={triggerMode === 'input' ? 'end' : 'start'}\n side=\"bottom\"\n sideOffset={6}\n positionMethod=\"fixed\"\n collisionAvoidance={{\n side: 'flip',\n align: 'shift',\n fallbackAxisSide: 'none',\n }}\n className=\"min-w-[260px] max-w-[360px] p-0 overflow-hidden flex flex-col\"\n portalClassName=\"z-250\"\n >\n <VariableCommandList\n search={picker.search}\n onSearchChange={picker.setSearch}\n groups={picker.groups}\n options={picker.options}\n onSelect={picker.handleSelect}\n placeholder={t('Search variables')}\n showSearch\n shouldFilter={false}\n onBack={picker.page ? picker.handleBack : undefined}\n isChildMode={!!picker.page}\n selectFirstItem={triggerMode === 'input'}\n autoFocusSearchInput={triggerMode !== 'input'}\n />\n </PopoverContent>\n </Popover>\n );\n\n return content;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AA+BA,SAAgB,4BAA4B,KAAa,QAAgD;AACrG,QAAO,SAAS,QAAQ;;AAkB5B,SAAgB,iBAAiB,EAC7B,QACA,oBACA,wBACA,uBACA,OACA,aACA,eACA,YACA,iBACA,MACA,cACA,cAAc,aACQ;CACtB,MAAM,IAAI,gBAAgB;CAC1B,MAAM,CAAC,kBAAkB,uBAAuB,SAAS,MAAM;CAE/D,MAAM,mBAAmB,OAAO,SAAS;CACzC,MAAM,SAAS,mBAAmB,OAAO;CAEzC,MAAM,SAAS,kBAAkB;EAC7B;EACA;EACA;EACA;EACA,UAAU,cAAc,aAAa;GACjC,MAAM,QAAQ,sBAAsB,cAAc,SAAS;AAE3D,IADc,QAAQ,OAAO,GACtB,SAAS,EAAE,iBAAiB,MAAM,EAAE,OAAO;AAClD,OAAI,CAAC,iBACD,qBAAoB,MAAM;AAE9B,kBAAe,MAAM;AACrB,UAAO,OAAO;;EAErB,CAAC;CAEF,MAAM,mBAAmB,eAAe;EAC5B;EACR,WAAW,EAAE,QAAQ,SAAS;AAC1B,WAAQ,IAAI,aAAa,IAAI,SAAS,cAAc,KAAK;;EAEhE,CAAC;CAEF,MAAM,oBAAoB,aAAsB;AAC5C,MAAI,CAAC,SACD,QAAO,OAAO;AAElB,MAAI,CAAC,iBACD,qBAAoB,SAAS;AAEjC,iBAAe,SAAS;;AAS5B,KAAI,CANoB,OAAO,OAAO,sBAAsB,EAAE,CAAC,CAAC,MAC5D,UAAS;AACL,SAAO,MAAM,QAAQ,MAAM,IAAI,MAAM,SAAS;GAIjD,CACD,QAAO;CAGX,MAAM,gBACF,qBAAC,QAAD;EACI,SAAS,iBAAiB;EAC1B,MAAM;EACN,WAAW,GACP,gBAAgB,aAAa;GACzB,cAAc,8BAA8B;GAC5C;GACA;GACA,oBAAoB;GACvB,EACD,gBAAgB,WAAW;GACvB;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACH,EAED,mBAAmB,GACtB;YAtBL,CAwBI,oBAAC,iBAAD;GAAiB,MAAM;GAAc,WAAU;GAAW,CAAA,EACzD,eAAe,oBAAC,QAAD,EAAA,UAAO,aAAmB,CAAA,CACrC;;AA4Cb,QAxCI,qBAAC,SAAD;EAAS,OAAO;EAAO,MAAM;EAAQ,cAAc;YAAnD,CACM,eAAe,QACb,qBAAC,SAAD,EAAA,UAAA,CACI,oBAAC,gBAAD,EAAgB,QAAQ,oBAAC,gBAAD;GAAgB,cAAc;GAAM,QAAQ;GAAiB,CAAA,EAAI,CAAA,EACzF,oBAAC,gBAAD;GAAgB,YAAY;aAAI,eAAe;GAAuB,CAAA,CAChE,EAAA,CAAA,GAEV,oBAAC,gBAAD;GAAgB,cAAc;GAAM,QAAQ;GAAiB,CAAA,EAEjE,oBAAC,gBAAD;GACI,OAAO,gBAAgB,UAAU,QAAQ;GACzC,MAAK;GACL,YAAY;GACZ,gBAAe;GACf,oBAAoB;IAChB,MAAM;IACN,OAAO;IACP,kBAAkB;IACrB;GACD,WAAU;GACV,iBAAgB;aAEhB,oBAAC,qBAAD;IACI,QAAQ,OAAO;IACf,gBAAgB,OAAO;IACvB,QAAQ,OAAO;IACf,SAAS,OAAO;IAChB,UAAU,OAAO;IACjB,aAAa,EAAE,mBAAmB;IAClC,YAAA;IACA,cAAc;IACd,QAAQ,OAAO,OAAO,OAAO,aAAa,KAAA;IAC1C,aAAa,CAAC,CAAC,OAAO;IACtB,iBAAiB,gBAAgB;IACjC,sBAAsB,gBAAgB;IACxC,CAAA;GACW,CAAA,CACX;GAGP"}
|