@alpaca-editor/core 1.0.0 → 1.0.3
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/build.css +3 -0
- package/components.json +21 -0
- package/dev.css +3 -0
- package/dist/client-components/api.d.ts +1 -0
- package/dist/client-components/api.js +4 -0
- package/dist/client-components/api.js.map +1 -0
- package/dist/client-components/index.d.ts +16 -0
- package/dist/client-components/index.js +17 -0
- package/dist/client-components/index.js.map +1 -0
- package/dist/components/ActionButton.d.ts +12 -0
- package/dist/components/ActionButton.js +6 -0
- package/dist/components/ActionButton.js.map +1 -0
- package/dist/components/Error.d.ts +9 -0
- package/dist/components/Error.js +24 -0
- package/dist/components/Error.js.map +1 -0
- package/dist/components/ui/button.d.ts +10 -0
- package/dist/components/ui/button.js +32 -0
- package/dist/components/ui/button.js.map +1 -0
- package/dist/config/config.d.ts +6 -0
- package/dist/config/config.js +647 -0
- package/dist/config/config.js.map +1 -0
- package/dist/config/types.d.ts +223 -0
- package/dist/config/types.js +2 -0
- package/dist/config/types.js.map +1 -0
- package/dist/editor/ComponentInfo.d.ts +4 -0
- package/dist/editor/ComponentInfo.js +29 -0
- package/dist/editor/ComponentInfo.js.map +1 -0
- package/dist/editor/ConfirmationDialog.d.ts +19 -0
- package/dist/editor/ConfirmationDialog.js +31 -0
- package/dist/editor/ConfirmationDialog.js.map +1 -0
- package/dist/editor/ContentTree.d.ts +35 -0
- package/dist/editor/ContentTree.js +404 -0
- package/dist/editor/ContentTree.js.map +1 -0
- package/dist/editor/ContextMenu.d.ts +13 -0
- package/dist/editor/ContextMenu.js +114 -0
- package/dist/editor/ContextMenu.js.map +1 -0
- package/dist/editor/Editor.d.ts +11 -0
- package/dist/editor/Editor.js +50 -0
- package/dist/editor/Editor.js.map +1 -0
- package/dist/editor/EditorWarning.d.ts +5 -0
- package/dist/editor/EditorWarning.js +11 -0
- package/dist/editor/EditorWarning.js.map +1 -0
- package/dist/editor/EditorWarnings.d.ts +9 -0
- package/dist/editor/EditorWarnings.js +19 -0
- package/dist/editor/EditorWarnings.js.map +1 -0
- package/dist/editor/FieldEditorPopup.d.ts +10 -0
- package/dist/editor/FieldEditorPopup.js +22 -0
- package/dist/editor/FieldEditorPopup.js.map +1 -0
- package/dist/editor/FieldHistory.d.ts +6 -0
- package/dist/editor/FieldHistory.js +38 -0
- package/dist/editor/FieldHistory.js.map +1 -0
- package/dist/editor/FieldList.d.ts +16 -0
- package/dist/editor/FieldList.js +58 -0
- package/dist/editor/FieldList.js.map +1 -0
- package/dist/editor/FieldListField.d.ts +14 -0
- package/dist/editor/FieldListField.js +161 -0
- package/dist/editor/FieldListField.js.map +1 -0
- package/dist/editor/FieldListFieldWithFallbacks.d.ts +10 -0
- package/dist/editor/FieldListFieldWithFallbacks.js +109 -0
- package/dist/editor/FieldListFieldWithFallbacks.js.map +1 -0
- package/dist/editor/FloatingToolbar.d.ts +7 -0
- package/dist/editor/FloatingToolbar.js +90 -0
- package/dist/editor/FloatingToolbar.js.map +1 -0
- package/dist/editor/ImageEditor.d.ts +5 -0
- package/dist/editor/ImageEditor.js +53 -0
- package/dist/editor/ImageEditor.js.map +1 -0
- package/dist/editor/InsertMenu.d.ts +8 -0
- package/dist/editor/InsertMenu.js +158 -0
- package/dist/editor/InsertMenu.js.map +1 -0
- package/dist/editor/ItemInfo.d.ts +4 -0
- package/dist/editor/ItemInfo.js +28 -0
- package/dist/editor/ItemInfo.js.map +1 -0
- package/dist/editor/LinkEditorDialog.d.ts +15 -0
- package/dist/editor/LinkEditorDialog.js +84 -0
- package/dist/editor/LinkEditorDialog.js.map +1 -0
- package/dist/editor/MainLayout.d.ts +9 -0
- package/dist/editor/MainLayout.js +41 -0
- package/dist/editor/MainLayout.js.map +1 -0
- package/dist/editor/NewEditorClient.d.ts +5 -0
- package/dist/editor/NewEditorClient.js +7 -0
- package/dist/editor/NewEditorClient.js.map +1 -0
- package/dist/editor/PictureCropper.d.ts +6 -0
- package/dist/editor/PictureCropper.js +327 -0
- package/dist/editor/PictureCropper.js.map +1 -0
- package/dist/editor/PictureEditor.d.ts +8 -0
- package/dist/editor/PictureEditor.js +102 -0
- package/dist/editor/PictureEditor.js.map +1 -0
- package/dist/editor/PictureEditorDialog.d.ts +8 -0
- package/dist/editor/PictureEditorDialog.js +189 -0
- package/dist/editor/PictureEditorDialog.js.map +1 -0
- package/dist/editor/ScrollingContentTree.d.ts +6 -0
- package/dist/editor/ScrollingContentTree.js +25 -0
- package/dist/editor/ScrollingContentTree.js.map +1 -0
- package/dist/editor/Terminal.d.ts +14 -0
- package/dist/editor/Terminal.js +107 -0
- package/dist/editor/Terminal.js.map +1 -0
- package/dist/editor/Titlebar.d.ts +1 -0
- package/dist/editor/Titlebar.js +9 -0
- package/dist/editor/Titlebar.js.map +1 -0
- package/dist/editor/ai/AiPopup.d.ts +10 -0
- package/dist/editor/ai/AiPopup.js +23 -0
- package/dist/editor/ai/AiPopup.js.map +1 -0
- package/dist/editor/ai/AiResponseMessage.d.ts +8 -0
- package/dist/editor/ai/AiResponseMessage.js +22 -0
- package/dist/editor/ai/AiResponseMessage.js.map +1 -0
- package/dist/editor/ai/AiTerminal.d.ts +34 -0
- package/dist/editor/ai/AiTerminal.js +236 -0
- package/dist/editor/ai/AiTerminal.js.map +1 -0
- package/dist/editor/ai/AiToolCall.d.ts +9 -0
- package/dist/editor/ai/AiToolCall.js +16 -0
- package/dist/editor/ai/AiToolCall.js.map +1 -0
- package/dist/editor/ai/EditorAiTerminal.d.ts +5 -0
- package/dist/editor/ai/EditorAiTerminal.js +7 -0
- package/dist/editor/ai/EditorAiTerminal.js.map +1 -0
- package/dist/editor/ai/editorAiContext.d.ts +11 -0
- package/dist/editor/ai/editorAiContext.js +12 -0
- package/dist/editor/ai/editorAiContext.js.map +1 -0
- package/dist/editor/client/DialogContext.d.ts +12 -0
- package/dist/editor/client/DialogContext.js +25 -0
- package/dist/editor/client/DialogContext.js.map +1 -0
- package/dist/editor/client/EditorClient.d.ts +26 -0
- package/dist/editor/client/EditorClient.js +1298 -0
- package/dist/editor/client/EditorClient.js.map +1 -0
- package/dist/editor/client/GenericDialog.d.ts +10 -0
- package/dist/editor/client/GenericDialog.js +25 -0
- package/dist/editor/client/GenericDialog.js.map +1 -0
- package/dist/editor/client/editContext.d.ts +199 -0
- package/dist/editor/client/editContext.js +20 -0
- package/dist/editor/client/editContext.js.map +1 -0
- package/dist/editor/client/helpers.d.ts +12 -0
- package/dist/editor/client/helpers.js +29 -0
- package/dist/editor/client/helpers.js.map +1 -0
- package/dist/editor/client/itemsRepository.d.ts +24 -0
- package/dist/editor/client/itemsRepository.js +253 -0
- package/dist/editor/client/itemsRepository.js.map +1 -0
- package/dist/editor/client/operations.d.ts +57 -0
- package/dist/editor/client/operations.js +393 -0
- package/dist/editor/client/operations.js.map +1 -0
- package/dist/editor/client/pageModelBuilder.d.ts +6 -0
- package/dist/editor/client/pageModelBuilder.js +127 -0
- package/dist/editor/client/pageModelBuilder.js.map +1 -0
- package/dist/editor/commands/commands.d.ts +19 -0
- package/dist/editor/commands/commands.js +2 -0
- package/dist/editor/commands/commands.js.map +1 -0
- package/dist/editor/commands/componentCommands.d.ts +13 -0
- package/dist/editor/commands/componentCommands.js +271 -0
- package/dist/editor/commands/componentCommands.js.map +1 -0
- package/dist/editor/commands/createVersionCommand.d.ts +4 -0
- package/dist/editor/commands/createVersionCommand.js +24 -0
- package/dist/editor/commands/createVersionCommand.js.map +1 -0
- package/dist/editor/commands/deleteVersionCommand.d.ts +4 -0
- package/dist/editor/commands/deleteVersionCommand.js +53 -0
- package/dist/editor/commands/deleteVersionCommand.js.map +1 -0
- package/dist/editor/commands/itemCommands.d.ts +17 -0
- package/dist/editor/commands/itemCommands.js +132 -0
- package/dist/editor/commands/itemCommands.js.map +1 -0
- package/dist/editor/commands/localizeItem/LocalizeItemDialog.d.ts +8 -0
- package/dist/editor/commands/localizeItem/LocalizeItemDialog.js +89 -0
- package/dist/editor/commands/localizeItem/LocalizeItemDialog.js.map +1 -0
- package/dist/editor/commands/undo.d.ts +15 -0
- package/dist/editor/commands/undo.js +29 -0
- package/dist/editor/commands/undo.js.map +1 -0
- package/dist/editor/component-designer/ComponentDesigner.d.ts +1 -0
- package/dist/editor/component-designer/ComponentDesigner.js +56 -0
- package/dist/editor/component-designer/ComponentDesigner.js.map +1 -0
- package/dist/editor/component-designer/ComponentDesignerAiTerminal.d.ts +1 -0
- package/dist/editor/component-designer/ComponentDesignerAiTerminal.js +7 -0
- package/dist/editor/component-designer/ComponentDesignerAiTerminal.js.map +1 -0
- package/dist/editor/component-designer/ComponentDesignerMenu.d.ts +1 -0
- package/dist/editor/component-designer/ComponentDesignerMenu.js +65 -0
- package/dist/editor/component-designer/ComponentDesignerMenu.js.map +1 -0
- package/dist/editor/component-designer/ComponentEditor.d.ts +4 -0
- package/dist/editor/component-designer/ComponentEditor.js +57 -0
- package/dist/editor/component-designer/ComponentEditor.js.map +1 -0
- package/dist/editor/component-designer/ComponentRenderingCodeEditor.d.ts +5 -0
- package/dist/editor/component-designer/ComponentRenderingCodeEditor.js +11 -0
- package/dist/editor/component-designer/ComponentRenderingCodeEditor.js.map +1 -0
- package/dist/editor/component-designer/ComponentRenderingEditor.d.ts +1 -0
- package/dist/editor/component-designer/ComponentRenderingEditor.js +69 -0
- package/dist/editor/component-designer/ComponentRenderingEditor.js.map +1 -0
- package/dist/editor/component-designer/ComponentsDropdown.d.ts +4 -0
- package/dist/editor/component-designer/ComponentsDropdown.js +20 -0
- package/dist/editor/component-designer/ComponentsDropdown.js.map +1 -0
- package/dist/editor/component-designer/PlaceholdersEditor.d.ts +4 -0
- package/dist/editor/component-designer/PlaceholdersEditor.js +68 -0
- package/dist/editor/component-designer/PlaceholdersEditor.js.map +1 -0
- package/dist/editor/component-designer/RenderingsDropdown.d.ts +1 -0
- package/dist/editor/component-designer/RenderingsDropdown.js +23 -0
- package/dist/editor/component-designer/RenderingsDropdown.js.map +1 -0
- package/dist/editor/component-designer/TemplateEditor.d.ts +1 -0
- package/dist/editor/component-designer/TemplateEditor.js +142 -0
- package/dist/editor/component-designer/TemplateEditor.js.map +1 -0
- package/dist/editor/component-designer/aiContext.d.ts +5 -0
- package/dist/editor/component-designer/aiContext.js +16 -0
- package/dist/editor/component-designer/aiContext.js.map +1 -0
- package/dist/editor/componentTreeHelper.d.ts +16 -0
- package/dist/editor/componentTreeHelper.js +87 -0
- package/dist/editor/componentTreeHelper.js.map +1 -0
- package/dist/editor/control-center/ControlCenterMenu.d.ts +1 -0
- package/dist/editor/control-center/ControlCenterMenu.js +57 -0
- package/dist/editor/control-center/ControlCenterMenu.js.map +1 -0
- package/dist/editor/control-center/IndexOverview.d.ts +1 -0
- package/dist/editor/control-center/IndexOverview.js +25 -0
- package/dist/editor/control-center/IndexOverview.js.map +1 -0
- package/dist/editor/control-center/IndexSettings.d.ts +5 -0
- package/dist/editor/control-center/IndexSettings.js +104 -0
- package/dist/editor/control-center/IndexSettings.js.map +1 -0
- package/dist/editor/control-center/Status.d.ts +1 -0
- package/dist/editor/control-center/Status.js +5 -0
- package/dist/editor/control-center/Status.js.map +1 -0
- package/dist/editor/editor-warnings/ItemLocked.d.ts +2 -0
- package/dist/editor/editor-warnings/ItemLocked.js +38 -0
- package/dist/editor/editor-warnings/ItemLocked.js.map +1 -0
- package/dist/editor/editor-warnings/NoLanguageWriteAccess.d.ts +2 -0
- package/dist/editor/editor-warnings/NoLanguageWriteAccess.js +14 -0
- package/dist/editor/editor-warnings/NoLanguageWriteAccess.js.map +1 -0
- package/dist/editor/editor-warnings/NoWorkflowWriteAccess.d.ts +2 -0
- package/dist/editor/editor-warnings/NoWorkflowWriteAccess.js +14 -0
- package/dist/editor/editor-warnings/NoWorkflowWriteAccess.js.map +1 -0
- package/dist/editor/editor-warnings/NoWriteAccess.d.ts +2 -0
- package/dist/editor/editor-warnings/NoWriteAccess.js +12 -0
- package/dist/editor/editor-warnings/NoWriteAccess.js.map +1 -0
- package/dist/editor/editor-warnings/ValidationErrors.d.ts +2 -0
- package/dist/editor/editor-warnings/ValidationErrors.js +25 -0
- package/dist/editor/editor-warnings/ValidationErrors.js.map +1 -0
- package/dist/editor/field-types/AttachmentEditor.d.ts +4 -0
- package/dist/editor/field-types/AttachmentEditor.js +5 -0
- package/dist/editor/field-types/AttachmentEditor.js.map +1 -0
- package/dist/editor/field-types/CheckboxEditor.d.ts +5 -0
- package/dist/editor/field-types/CheckboxEditor.js +30 -0
- package/dist/editor/field-types/CheckboxEditor.js.map +1 -0
- package/dist/editor/field-types/DropLinkEditor.d.ts +5 -0
- package/dist/editor/field-types/DropLinkEditor.js +49 -0
- package/dist/editor/field-types/DropLinkEditor.js.map +1 -0
- package/dist/editor/field-types/DropListEditor.d.ts +5 -0
- package/dist/editor/field-types/DropListEditor.js +56 -0
- package/dist/editor/field-types/DropListEditor.js.map +1 -0
- package/dist/editor/field-types/ImageFieldEditor.d.ts +5 -0
- package/dist/editor/field-types/ImageFieldEditor.js +34 -0
- package/dist/editor/field-types/ImageFieldEditor.js.map +1 -0
- package/dist/editor/field-types/InternalLinkFieldEditor.d.ts +5 -0
- package/dist/editor/field-types/InternalLinkFieldEditor.js +59 -0
- package/dist/editor/field-types/InternalLinkFieldEditor.js.map +1 -0
- package/dist/editor/field-types/LinkFieldEditor.d.ts +5 -0
- package/dist/editor/field-types/LinkFieldEditor.js +56 -0
- package/dist/editor/field-types/LinkFieldEditor.js.map +1 -0
- package/dist/editor/field-types/MultiLineText.d.ts +6 -0
- package/dist/editor/field-types/MultiLineText.js +33 -0
- package/dist/editor/field-types/MultiLineText.js.map +1 -0
- package/dist/editor/field-types/PictureFieldEditor.d.ts +5 -0
- package/dist/editor/field-types/PictureFieldEditor.js +57 -0
- package/dist/editor/field-types/PictureFieldEditor.js.map +1 -0
- package/dist/editor/field-types/RawEditor.d.ts +5 -0
- package/dist/editor/field-types/RawEditor.js +31 -0
- package/dist/editor/field-types/RawEditor.js.map +1 -0
- package/dist/editor/field-types/ReactQuill.d.ts +125 -0
- package/dist/editor/field-types/ReactQuill.js +385 -0
- package/dist/editor/field-types/ReactQuill.js.map +1 -0
- package/dist/editor/field-types/RichTextEditor.d.ts +5 -0
- package/dist/editor/field-types/RichTextEditor.js +8 -0
- package/dist/editor/field-types/RichTextEditor.js.map +1 -0
- package/dist/editor/field-types/RichTextEditorComponent.d.ts +6 -0
- package/dist/editor/field-types/RichTextEditorComponent.js +70 -0
- package/dist/editor/field-types/RichTextEditorComponent.js.map +1 -0
- package/dist/editor/field-types/SingleLineText.d.ts +6 -0
- package/dist/editor/field-types/SingleLineText.js +90 -0
- package/dist/editor/field-types/SingleLineText.js.map +1 -0
- package/dist/editor/field-types/TreeListEditor.d.ts +5 -0
- package/dist/editor/field-types/TreeListEditor.js +132 -0
- package/dist/editor/field-types/TreeListEditor.js.map +1 -0
- package/dist/editor/fieldTypes.d.ts +117 -0
- package/dist/editor/fieldTypes.js +2 -0
- package/dist/editor/fieldTypes.js.map +1 -0
- package/dist/editor/media-selector/AiImageSearch.d.ts +4 -0
- package/dist/editor/media-selector/AiImageSearch.js +105 -0
- package/dist/editor/media-selector/AiImageSearch.js.map +1 -0
- package/dist/editor/media-selector/AiImageSearchPrompt.d.ts +3 -0
- package/dist/editor/media-selector/AiImageSearchPrompt.js +56 -0
- package/dist/editor/media-selector/AiImageSearchPrompt.js.map +1 -0
- package/dist/editor/media-selector/MediaSelector.d.ts +9 -0
- package/dist/editor/media-selector/MediaSelector.js +8 -0
- package/dist/editor/media-selector/MediaSelector.js.map +1 -0
- package/dist/editor/media-selector/Preview.d.ts +4 -0
- package/dist/editor/media-selector/Preview.js +7 -0
- package/dist/editor/media-selector/Preview.js.map +1 -0
- package/dist/editor/media-selector/Thumbnails.d.ts +13 -0
- package/dist/editor/media-selector/Thumbnails.js +9 -0
- package/dist/editor/media-selector/Thumbnails.js.map +1 -0
- package/dist/editor/media-selector/TreeSelector.d.ts +7 -0
- package/dist/editor/media-selector/TreeSelector.js +165 -0
- package/dist/editor/media-selector/TreeSelector.js.map +1 -0
- package/dist/editor/media-selector/UploadZone.d.ts +4 -0
- package/dist/editor/media-selector/UploadZone.js +78 -0
- package/dist/editor/media-selector/UploadZone.js.map +1 -0
- package/dist/editor/menubar/ActionsMenu.d.ts +1 -0
- package/dist/editor/menubar/ActionsMenu.js +31 -0
- package/dist/editor/menubar/ActionsMenu.js.map +1 -0
- package/dist/editor/menubar/ActiveUsers.d.ts +1 -0
- package/dist/editor/menubar/ActiveUsers.js +11 -0
- package/dist/editor/menubar/ActiveUsers.js.map +1 -0
- package/dist/editor/menubar/ApproveAndPublish.d.ts +1 -0
- package/dist/editor/menubar/ApproveAndPublish.js +11 -0
- package/dist/editor/menubar/ApproveAndPublish.js.map +1 -0
- package/dist/editor/menubar/BrowseHistory.d.ts +6 -0
- package/dist/editor/menubar/BrowseHistory.js +12 -0
- package/dist/editor/menubar/BrowseHistory.js.map +1 -0
- package/dist/editor/menubar/ItemLanguageVersion.d.ts +1 -0
- package/dist/editor/menubar/ItemLanguageVersion.js +34 -0
- package/dist/editor/menubar/ItemLanguageVersion.js.map +1 -0
- package/dist/editor/menubar/LanguageSelector.d.ts +9 -0
- package/dist/editor/menubar/LanguageSelector.js +31 -0
- package/dist/editor/menubar/LanguageSelector.js.map +1 -0
- package/dist/editor/menubar/Menu.d.ts +1 -0
- package/dist/editor/menubar/Menu.js +63 -0
- package/dist/editor/menubar/Menu.js.map +1 -0
- package/dist/editor/menubar/NavButtons.d.ts +1 -0
- package/dist/editor/menubar/NavButtons.js +41 -0
- package/dist/editor/menubar/NavButtons.js.map +1 -0
- package/dist/editor/menubar/PageSelector.d.ts +4 -0
- package/dist/editor/menubar/PageSelector.js +48 -0
- package/dist/editor/menubar/PageSelector.js.map +1 -0
- package/dist/editor/menubar/PageViewerControls.d.ts +1 -0
- package/dist/editor/menubar/PageViewerControls.js +35 -0
- package/dist/editor/menubar/PageViewerControls.js.map +1 -0
- package/dist/editor/menubar/Separator.d.ts +3 -0
- package/dist/editor/menubar/Separator.js +6 -0
- package/dist/editor/menubar/Separator.js.map +1 -0
- package/dist/editor/menubar/SiteInfo.d.ts +1 -0
- package/dist/editor/menubar/SiteInfo.js +24 -0
- package/dist/editor/menubar/SiteInfo.js.map +1 -0
- package/dist/editor/menubar/User.d.ts +4 -0
- package/dist/editor/menubar/User.js +16 -0
- package/dist/editor/menubar/User.js.map +1 -0
- package/dist/editor/menubar/VersionSelector.d.ts +9 -0
- package/dist/editor/menubar/VersionSelector.js +47 -0
- package/dist/editor/menubar/VersionSelector.js.map +1 -0
- package/dist/editor/page-editor-chrome/CommentHighlighting.d.ts +6 -0
- package/dist/editor/page-editor-chrome/CommentHighlighting.js +212 -0
- package/dist/editor/page-editor-chrome/CommentHighlighting.js.map +1 -0
- package/dist/editor/page-editor-chrome/CommentHighlightings.d.ts +4 -0
- package/dist/editor/page-editor-chrome/CommentHighlightings.js +15 -0
- package/dist/editor/page-editor-chrome/CommentHighlightings.js.map +1 -0
- package/dist/editor/page-editor-chrome/FieldActionIndicator.d.ts +4 -0
- package/dist/editor/page-editor-chrome/FieldActionIndicator.js +25 -0
- package/dist/editor/page-editor-chrome/FieldActionIndicator.js.map +1 -0
- package/dist/editor/page-editor-chrome/FieldActionIndicators.d.ts +1 -0
- package/dist/editor/page-editor-chrome/FieldActionIndicators.js +13 -0
- package/dist/editor/page-editor-chrome/FieldActionIndicators.js.map +1 -0
- package/dist/editor/page-editor-chrome/FieldEditedIndicator.d.ts +8 -0
- package/dist/editor/page-editor-chrome/FieldEditedIndicator.js +25 -0
- package/dist/editor/page-editor-chrome/FieldEditedIndicator.js.map +1 -0
- package/dist/editor/page-editor-chrome/FieldEditedIndicators.d.ts +6 -0
- package/dist/editor/page-editor-chrome/FieldEditedIndicators.js +13 -0
- package/dist/editor/page-editor-chrome/FieldEditedIndicators.js.map +1 -0
- package/dist/editor/page-editor-chrome/FrameMenu.d.ts +7 -0
- package/dist/editor/page-editor-chrome/FrameMenu.js +176 -0
- package/dist/editor/page-editor-chrome/FrameMenu.js.map +1 -0
- package/dist/editor/page-editor-chrome/FrameMenus.d.ts +5 -0
- package/dist/editor/page-editor-chrome/FrameMenus.js +22 -0
- package/dist/editor/page-editor-chrome/FrameMenus.js.map +1 -0
- package/dist/editor/page-editor-chrome/InlineEditor.d.ts +5 -0
- package/dist/editor/page-editor-chrome/InlineEditor.js +99 -0
- package/dist/editor/page-editor-chrome/InlineEditor.js.map +1 -0
- package/dist/editor/page-editor-chrome/LockedFieldIndicator.d.ts +1 -0
- package/dist/editor/page-editor-chrome/LockedFieldIndicator.js +33 -0
- package/dist/editor/page-editor-chrome/LockedFieldIndicator.js.map +1 -0
- package/dist/editor/page-editor-chrome/NoLayout.d.ts +1 -0
- package/dist/editor/page-editor-chrome/NoLayout.js +19 -0
- package/dist/editor/page-editor-chrome/NoLayout.js.map +1 -0
- package/dist/editor/page-editor-chrome/PageEditorChrome.d.ts +6 -0
- package/dist/editor/page-editor-chrome/PageEditorChrome.js +63 -0
- package/dist/editor/page-editor-chrome/PageEditorChrome.js.map +1 -0
- package/dist/editor/page-editor-chrome/PictureEditorOverlay.d.ts +1 -0
- package/dist/editor/page-editor-chrome/PictureEditorOverlay.js +107 -0
- package/dist/editor/page-editor-chrome/PictureEditorOverlay.js.map +1 -0
- package/dist/editor/page-editor-chrome/PlaceholderDropZone.d.ts +14 -0
- package/dist/editor/page-editor-chrome/PlaceholderDropZone.js +80 -0
- package/dist/editor/page-editor-chrome/PlaceholderDropZone.js.map +1 -0
- package/dist/editor/page-editor-chrome/PlaceholderDropZones.d.ts +5 -0
- package/dist/editor/page-editor-chrome/PlaceholderDropZones.js +145 -0
- package/dist/editor/page-editor-chrome/PlaceholderDropZones.js.map +1 -0
- package/dist/editor/page-viewer/DeviceToolbar.d.ts +6 -0
- package/dist/editor/page-viewer/DeviceToolbar.js +19 -0
- package/dist/editor/page-viewer/DeviceToolbar.js.map +1 -0
- package/dist/editor/page-viewer/EditorForm.d.ts +5 -0
- package/dist/editor/page-viewer/EditorForm.js +128 -0
- package/dist/editor/page-viewer/EditorForm.js.map +1 -0
- package/dist/editor/page-viewer/MiniMap.d.ts +9 -0
- package/dist/editor/page-viewer/MiniMap.js +222 -0
- package/dist/editor/page-viewer/MiniMap.js.map +1 -0
- package/dist/editor/page-viewer/PageViewer.d.ts +8 -0
- package/dist/editor/page-viewer/PageViewer.js +62 -0
- package/dist/editor/page-viewer/PageViewer.js.map +1 -0
- package/dist/editor/page-viewer/PageViewerFrame.d.ts +11 -0
- package/dist/editor/page-viewer/PageViewerFrame.js +690 -0
- package/dist/editor/page-viewer/PageViewerFrame.js.map +1 -0
- package/dist/editor/page-viewer/pageViewContext.d.ts +38 -0
- package/dist/editor/page-viewer/pageViewContext.js +115 -0
- package/dist/editor/page-viewer/pageViewContext.js.map +1 -0
- package/dist/editor/pageModel.d.ts +171 -0
- package/dist/editor/pageModel.js +2 -0
- package/dist/editor/pageModel.js.map +1 -0
- package/dist/editor/picture-shared.d.ts +16 -0
- package/dist/editor/picture-shared.js +25 -0
- package/dist/editor/picture-shared.js.map +1 -0
- package/dist/editor/reviews/Comment.d.ts +4 -0
- package/dist/editor/reviews/Comment.js +114 -0
- package/dist/editor/reviews/Comment.js.map +1 -0
- package/dist/editor/reviews/Comments.d.ts +1 -0
- package/dist/editor/reviews/Comments.js +22 -0
- package/dist/editor/reviews/Comments.js.map +1 -0
- package/dist/editor/reviews/PreviewInfo.d.ts +1 -0
- package/dist/editor/reviews/PreviewInfo.js +11 -0
- package/dist/editor/reviews/PreviewInfo.js.map +1 -0
- package/dist/editor/reviews/Reviews.d.ts +1 -0
- package/dist/editor/reviews/Reviews.js +160 -0
- package/dist/editor/reviews/Reviews.js.map +1 -0
- package/dist/editor/reviews/reviewCommands.d.ts +3 -0
- package/dist/editor/reviews/reviewCommands.js +42 -0
- package/dist/editor/reviews/reviewCommands.js.map +1 -0
- package/dist/editor/reviews/useReviews.d.ts +12 -0
- package/dist/editor/reviews/useReviews.js +43 -0
- package/dist/editor/reviews/useReviews.js.map +1 -0
- package/dist/editor/services/aiService.d.ts +34 -0
- package/dist/editor/services/aiService.js +95 -0
- package/dist/editor/services/aiService.js.map +1 -0
- package/dist/editor/services/componentDesignerService.d.ts +46 -0
- package/dist/editor/services/componentDesignerService.js +72 -0
- package/dist/editor/services/componentDesignerService.js.map +1 -0
- package/dist/editor/services/contentService.d.ts +34 -0
- package/dist/editor/services/contentService.js +92 -0
- package/dist/editor/services/contentService.js.map +1 -0
- package/dist/editor/services/editService.d.ts +34 -0
- package/dist/editor/services/editService.js +294 -0
- package/dist/editor/services/editService.js.map +1 -0
- package/dist/editor/services/indexService.d.ts +6 -0
- package/dist/editor/services/indexService.js +19 -0
- package/dist/editor/services/indexService.js.map +1 -0
- package/dist/editor/services/reviewsService.d.ts +12 -0
- package/dist/editor/services/reviewsService.js +32 -0
- package/dist/editor/services/reviewsService.js.map +1 -0
- package/dist/editor/services/serviceHelper.d.ts +9 -0
- package/dist/editor/services/serviceHelper.js +64 -0
- package/dist/editor/services/serviceHelper.js.map +1 -0
- package/dist/editor/services/systemService.d.ts +2 -0
- package/dist/editor/services/systemService.js +5 -0
- package/dist/editor/services/systemService.js.map +1 -0
- package/dist/editor/services/translationService.d.ts +11 -0
- package/dist/editor/services/translationService.js +11 -0
- package/dist/editor/services/translationService.js.map +1 -0
- package/dist/editor/services-server/api.d.ts +19 -0
- package/dist/editor/services-server/api.js +111 -0
- package/dist/editor/services-server/api.js.map +1 -0
- package/dist/editor/services-server/graphQL.d.ts +29 -0
- package/dist/editor/services-server/graphQL.js +53 -0
- package/dist/editor/services-server/graphQL.js.map +1 -0
- package/dist/editor/sidebar/ComponentPalette.d.ts +1 -0
- package/dist/editor/sidebar/ComponentPalette.js +53 -0
- package/dist/editor/sidebar/ComponentPalette.js.map +1 -0
- package/dist/editor/sidebar/ComponentTree.d.ts +1 -0
- package/dist/editor/sidebar/ComponentTree.js +360 -0
- package/dist/editor/sidebar/ComponentTree.js.map +1 -0
- package/dist/editor/sidebar/Debug.d.ts +1 -0
- package/dist/editor/sidebar/Debug.js +58 -0
- package/dist/editor/sidebar/Debug.js.map +1 -0
- package/dist/editor/sidebar/DictionaryEditor.d.ts +1 -0
- package/dist/editor/sidebar/DictionaryEditor.js +158 -0
- package/dist/editor/sidebar/DictionaryEditor.js.map +1 -0
- package/dist/editor/sidebar/EditHistory.d.ts +1 -0
- package/dist/editor/sidebar/EditHistory.js +72 -0
- package/dist/editor/sidebar/EditHistory.js.map +1 -0
- package/dist/editor/sidebar/GraphQL.d.ts +1 -0
- package/dist/editor/sidebar/GraphQL.js +113 -0
- package/dist/editor/sidebar/GraphQL.js.map +1 -0
- package/dist/editor/sidebar/Insert.d.ts +1 -0
- package/dist/editor/sidebar/Insert.js +22 -0
- package/dist/editor/sidebar/Insert.js.map +1 -0
- package/dist/editor/sidebar/MainContentTree.d.ts +4 -0
- package/dist/editor/sidebar/MainContentTree.js +49 -0
- package/dist/editor/sidebar/MainContentTree.js.map +1 -0
- package/dist/editor/sidebar/Performance.d.ts +1 -0
- package/dist/editor/sidebar/Performance.js +32 -0
- package/dist/editor/sidebar/Performance.js.map +1 -0
- package/dist/editor/sidebar/Sessions.d.ts +1 -0
- package/dist/editor/sidebar/Sessions.js +29 -0
- package/dist/editor/sidebar/Sessions.js.map +1 -0
- package/dist/editor/sidebar/Sidebar.d.ts +1 -0
- package/dist/editor/sidebar/Sidebar.js +13 -0
- package/dist/editor/sidebar/Sidebar.js.map +1 -0
- package/dist/editor/sidebar/SidebarView.d.ts +8 -0
- package/dist/editor/sidebar/SidebarView.js +74 -0
- package/dist/editor/sidebar/SidebarView.js.map +1 -0
- package/dist/editor/sidebar/Translations.d.ts +1 -0
- package/dist/editor/sidebar/Translations.js +158 -0
- package/dist/editor/sidebar/Translations.js.map +1 -0
- package/dist/editor/sidebar/Validation.d.ts +1 -0
- package/dist/editor/sidebar/Validation.js +50 -0
- package/dist/editor/sidebar/Validation.js.map +1 -0
- package/dist/editor/sidebar/ViewSelector.d.ts +1 -0
- package/dist/editor/sidebar/ViewSelector.js +13 -0
- package/dist/editor/sidebar/ViewSelector.js.map +1 -0
- package/dist/editor/sidebar/Workbox.d.ts +1 -0
- package/dist/editor/sidebar/Workbox.js +78 -0
- package/dist/editor/sidebar/Workbox.js.map +1 -0
- package/dist/editor/ui/CenteredMessage.d.ts +3 -0
- package/dist/editor/ui/CenteredMessage.js +5 -0
- package/dist/editor/ui/CenteredMessage.js.map +1 -0
- package/dist/editor/ui/CopyToClipboardButton.d.ts +3 -0
- package/dist/editor/ui/CopyToClipboardButton.js +15 -0
- package/dist/editor/ui/CopyToClipboardButton.js.map +1 -0
- package/dist/editor/ui/DialogButtons.d.ts +3 -0
- package/dist/editor/ui/DialogButtons.js +5 -0
- package/dist/editor/ui/DialogButtons.js.map +1 -0
- package/dist/editor/ui/Icons.d.ts +38 -0
- package/dist/editor/ui/Icons.js +56 -0
- package/dist/editor/ui/Icons.js.map +1 -0
- package/dist/editor/ui/ItemNameDialog.d.ts +11 -0
- package/dist/editor/ui/ItemNameDialog.js +40 -0
- package/dist/editor/ui/ItemNameDialog.js.map +1 -0
- package/dist/editor/ui/ItemNameDialogNew.d.ts +10 -0
- package/dist/editor/ui/ItemNameDialogNew.js +56 -0
- package/dist/editor/ui/ItemNameDialogNew.js.map +1 -0
- package/dist/editor/ui/ItemSearch.d.ts +23 -0
- package/dist/editor/ui/ItemSearch.js +90 -0
- package/dist/editor/ui/ItemSearch.js.map +1 -0
- package/dist/editor/ui/PerfectTree.d.ts +60 -0
- package/dist/editor/ui/PerfectTree.js +187 -0
- package/dist/editor/ui/PerfectTree.js.map +1 -0
- package/dist/editor/ui/Section.d.ts +4 -0
- package/dist/editor/ui/Section.js +10 -0
- package/dist/editor/ui/Section.js.map +1 -0
- package/dist/editor/ui/SimpleIconButton.d.ts +11 -0
- package/dist/editor/ui/SimpleIconButton.js +9 -0
- package/dist/editor/ui/SimpleIconButton.js.map +1 -0
- package/dist/editor/ui/SimpleMenu.d.ts +13 -0
- package/dist/editor/ui/SimpleMenu.js +7 -0
- package/dist/editor/ui/SimpleMenu.js.map +1 -0
- package/dist/editor/ui/SimpleTable.d.ts +14 -0
- package/dist/editor/ui/SimpleTable.js +9 -0
- package/dist/editor/ui/SimpleTable.js.map +1 -0
- package/dist/editor/ui/SimpleTabs.d.ts +12 -0
- package/dist/editor/ui/SimpleTabs.js +19 -0
- package/dist/editor/ui/SimpleTabs.js.map +1 -0
- package/dist/editor/ui/SimpleToolbar.d.ts +3 -0
- package/dist/editor/ui/SimpleToolbar.js +5 -0
- package/dist/editor/ui/SimpleToolbar.js.map +1 -0
- package/dist/editor/ui/Spinner.d.ts +3 -0
- package/dist/editor/ui/Spinner.js +5 -0
- package/dist/editor/ui/Spinner.js.map +1 -0
- package/dist/editor/ui/Splitter.d.ts +15 -0
- package/dist/editor/ui/Splitter.js +151 -0
- package/dist/editor/ui/Splitter.js.map +1 -0
- package/dist/editor/ui/StackedPanels.d.ts +5 -0
- package/dist/editor/ui/StackedPanels.js +67 -0
- package/dist/editor/ui/StackedPanels.js.map +1 -0
- package/dist/editor/ui/Toolbar.d.ts +3 -0
- package/dist/editor/ui/Toolbar.js +5 -0
- package/dist/editor/ui/Toolbar.js.map +1 -0
- package/dist/editor/utils/id-helper.d.ts +1 -0
- package/dist/editor/utils/id-helper.js +5 -0
- package/dist/editor/utils/id-helper.js.map +1 -0
- package/dist/editor/utils/insertOptions.d.ts +3 -0
- package/dist/editor/utils/insertOptions.js +43 -0
- package/dist/editor/utils/insertOptions.js.map +1 -0
- package/dist/editor/utils/itemutils.d.ts +3 -0
- package/dist/editor/utils/itemutils.js +22 -0
- package/dist/editor/utils/itemutils.js.map +1 -0
- package/dist/editor/utils/useMemoDebug.d.ts +1 -0
- package/dist/editor/utils/useMemoDebug.js +18 -0
- package/dist/editor/utils/useMemoDebug.js.map +1 -0
- package/dist/editor/utils.d.ts +44 -0
- package/dist/editor/utils.js +309 -0
- package/dist/editor/utils.js.map +1 -0
- package/dist/editor/views/CompareView.d.ts +1 -0
- package/dist/editor/views/CompareView.js +145 -0
- package/dist/editor/views/CompareView.js.map +1 -0
- package/dist/editor/views/EditView.d.ts +1 -0
- package/dist/editor/views/EditView.js +15 -0
- package/dist/editor/views/EditView.js.map +1 -0
- package/dist/editor/views/ItemEditor.d.ts +7 -0
- package/dist/editor/views/ItemEditor.js +22 -0
- package/dist/editor/views/ItemEditor.js.map +1 -0
- package/dist/editor/views/SingleEditView.d.ts +8 -0
- package/dist/editor/views/SingleEditView.js +23 -0
- package/dist/editor/views/SingleEditView.js.map +1 -0
- package/dist/images/bg-shape-black.webp +0 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/utils.d.ts +2 -0
- package/dist/lib/utils.js +6 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/page-wizard/PageWizard.d.ts +70 -0
- package/dist/page-wizard/PageWizard.js +60 -0
- package/dist/page-wizard/PageWizard.js.map +1 -0
- package/dist/page-wizard/SelectWizard.d.ts +7 -0
- package/dist/page-wizard/SelectWizard.js +41 -0
- package/dist/page-wizard/SelectWizard.js.map +1 -0
- package/dist/page-wizard/WizardSteps.d.ts +8 -0
- package/dist/page-wizard/WizardSteps.js +69 -0
- package/dist/page-wizard/WizardSteps.js.map +1 -0
- package/dist/page-wizard/service.d.ts +15 -0
- package/dist/page-wizard/service.js +22 -0
- package/dist/page-wizard/service.js.map +1 -0
- package/dist/page-wizard/startPageWizardCommand.d.ts +13 -0
- package/dist/page-wizard/startPageWizardCommand.js +21 -0
- package/dist/page-wizard/startPageWizardCommand.js.map +1 -0
- package/dist/page-wizard/steps/BuildPageStep.d.ts +2 -0
- package/dist/page-wizard/steps/BuildPageStep.js +133 -0
- package/dist/page-wizard/steps/BuildPageStep.js.map +1 -0
- package/dist/page-wizard/steps/CollectStep.d.ts +2 -0
- package/dist/page-wizard/steps/CollectStep.js +119 -0
- package/dist/page-wizard/steps/CollectStep.js.map +1 -0
- package/dist/page-wizard/steps/ComponentTypesSelector.d.ts +11 -0
- package/dist/page-wizard/steps/ComponentTypesSelector.js +209 -0
- package/dist/page-wizard/steps/ComponentTypesSelector.js.map +1 -0
- package/dist/page-wizard/steps/Components.d.ts +9 -0
- package/dist/page-wizard/steps/Components.js +89 -0
- package/dist/page-wizard/steps/Components.js.map +1 -0
- package/dist/page-wizard/steps/CreatePage.d.ts +12 -0
- package/dist/page-wizard/steps/CreatePage.js +140 -0
- package/dist/page-wizard/steps/CreatePage.js.map +1 -0
- package/dist/page-wizard/steps/CreatePageAndLayoutStep.d.ts +2 -0
- package/dist/page-wizard/steps/CreatePageAndLayoutStep.js +228 -0
- package/dist/page-wizard/steps/CreatePageAndLayoutStep.js.map +1 -0
- package/dist/page-wizard/steps/EditButton.d.ts +8 -0
- package/dist/page-wizard/steps/EditButton.js +5 -0
- package/dist/page-wizard/steps/EditButton.js.map +1 -0
- package/dist/page-wizard/steps/FieldEditor.d.ts +5 -0
- package/dist/page-wizard/steps/FieldEditor.js +28 -0
- package/dist/page-wizard/steps/FieldEditor.js.map +1 -0
- package/dist/page-wizard/steps/Generate.d.ts +5 -0
- package/dist/page-wizard/steps/Generate.js +10 -0
- package/dist/page-wizard/steps/Generate.js.map +1 -0
- package/dist/page-wizard/steps/ImagesStep.d.ts +2 -0
- package/dist/page-wizard/steps/ImagesStep.js +156 -0
- package/dist/page-wizard/steps/ImagesStep.js.map +1 -0
- package/dist/page-wizard/steps/LayoutStep.d.ts +2 -0
- package/dist/page-wizard/steps/LayoutStep.js +118 -0
- package/dist/page-wizard/steps/LayoutStep.js.map +1 -0
- package/dist/page-wizard/steps/SelectStep.d.ts +2 -0
- package/dist/page-wizard/steps/SelectStep.js +145 -0
- package/dist/page-wizard/steps/SelectStep.js.map +1 -0
- package/dist/page-wizard/steps/schema.d.ts +13 -0
- package/dist/page-wizard/steps/schema.js +137 -0
- package/dist/page-wizard/steps/schema.js.map +1 -0
- package/dist/page-wizard/steps/usePageCreator.d.ts +6 -0
- package/dist/page-wizard/steps/usePageCreator.js +192 -0
- package/dist/page-wizard/steps/usePageCreator.js.map +1 -0
- package/dist/splash-screen/NewPage.d.ts +3 -0
- package/dist/splash-screen/NewPage.js +129 -0
- package/dist/splash-screen/NewPage.js.map +1 -0
- package/dist/splash-screen/SectionHeadline.d.ts +4 -0
- package/dist/splash-screen/SectionHeadline.js +7 -0
- package/dist/splash-screen/SectionHeadline.js.map +1 -0
- package/dist/splash-screen/SplashScreen.d.ts +1 -0
- package/dist/splash-screen/SplashScreen.js +79 -0
- package/dist/splash-screen/SplashScreen.js.map +1 -0
- package/dist/styles.css +2739 -0
- package/dist/tour/Tour.d.ts +3 -0
- package/dist/tour/Tour.js +319 -0
- package/dist/tour/Tour.js.map +1 -0
- package/dist/tour/default-tour.d.ts +9 -0
- package/dist/tour/default-tour.js +229 -0
- package/dist/tour/default-tour.js.map +1 -0
- package/dist/tour/preview-tour.d.ts +2 -0
- package/dist/tour/preview-tour.js +91 -0
- package/dist/tour/preview-tour.js.map +1 -0
- package/dist/types.d.ts +259 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/package.json +12 -5
- package/src/components/ui/button.tsx +62 -0
- package/src/editor/Titlebar.tsx +2 -2
- package/src/editor/client/EditorClient.tsx +8 -9
- package/src/editor/menubar/ActionsMenu.tsx +1 -1
- package/src/editor/menubar/Menu.tsx +3 -3
- package/src/editor/menubar/VersionSelector.tsx +9 -10
- package/src/editor/page-editor-chrome/CommentHighlighting.tsx +8 -9
- package/src/editor/page-viewer/MiniMap.tsx +11 -11
- package/src/editor/reviews/Comment.tsx +38 -33
- package/src/editor/sidebar/ComponentTree.tsx +512 -512
- package/src/editor/sidebar/Insert.tsx +2 -2
- package/src/editor/sidebar/MainContentTree.tsx +1 -0
- package/src/editor/sidebar/Translations.tsx +12 -12
- package/src/editor/sidebar/ViewSelector.tsx +6 -7
- package/src/editor/ui/PerfectTree.tsx +2 -2
- package/src/editor/ui/SimpleTable.tsx +3 -6
- package/src/editor/utils.ts +32 -29
- package/src/index.ts +2 -0
- package/src/lib/utils.ts +6 -0
- package/src/splash-screen/SplashScreen.tsx +2 -2
- package/styles.css +124 -2
- package/tsconfig.build.json +23 -13
- package/tsconfig.json +3 -0
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { InputText } from "primereact/inputtext";
|
|
4
|
+
import { useEditContext, useEditContextRef, useModifiedFieldsContext, } from "../client/editContext";
|
|
5
|
+
import { useEffect, useRef, useState } from "react";
|
|
6
|
+
export function SingleLineText({ field, readOnly, updateFieldValue, }) {
|
|
7
|
+
const editContextRef = useEditContextRef();
|
|
8
|
+
const editContext = useEditContext();
|
|
9
|
+
const modifiedFieldsContext = useModifiedFieldsContext();
|
|
10
|
+
const inputRef = useRef(null);
|
|
11
|
+
// const [selectionStart, setSelectionStart] = useState(0);
|
|
12
|
+
// const [selectionEnd, setSelectionEnd] = useState(0);
|
|
13
|
+
if (!editContextRef.current)
|
|
14
|
+
return;
|
|
15
|
+
const fieldItem = field.descriptor.item;
|
|
16
|
+
const [value, setValue] = useState(undefined);
|
|
17
|
+
const modifiedField = modifiedFieldsContext?.modifiedFields.find((x) => x.fieldId === field.id &&
|
|
18
|
+
x.item.id === fieldItem.id &&
|
|
19
|
+
x.item.language === fieldItem.language &&
|
|
20
|
+
x.item.version === fieldItem.version);
|
|
21
|
+
useEffect(() => {
|
|
22
|
+
if (inputRef.current !== document.activeElement) {
|
|
23
|
+
if (field.isHistoric)
|
|
24
|
+
setValue(field.value);
|
|
25
|
+
else {
|
|
26
|
+
setValue(modifiedField?.value ?? field.value);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}, [field.value, modifiedFieldsContext?.modifiedFields]);
|
|
30
|
+
if (!fieldItem)
|
|
31
|
+
return;
|
|
32
|
+
const handleChange = (e) => {
|
|
33
|
+
if (editContextRef.current?.operations.undoing) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const newValue = e.target.value;
|
|
37
|
+
if (newValue !== value) {
|
|
38
|
+
setValue(newValue);
|
|
39
|
+
updateFieldValue(newValue);
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
const handleSelect = (e) => {
|
|
43
|
+
const target = e.target;
|
|
44
|
+
const range = {
|
|
45
|
+
fieldId: field.id,
|
|
46
|
+
startOffset: target.selectionStart || 0,
|
|
47
|
+
endOffset: target.selectionEnd || 0,
|
|
48
|
+
text: target.value.slice(target.selectionStart || 0, target.selectionEnd || 0),
|
|
49
|
+
};
|
|
50
|
+
editContextRef.current?.setSelectedRange(range);
|
|
51
|
+
};
|
|
52
|
+
useEffect(() => {
|
|
53
|
+
if (editContextRef.current?.focusedField?.fieldId === field.id &&
|
|
54
|
+
editContextRef.current?.focusedField?.item.id === fieldItem.id &&
|
|
55
|
+
editContextRef.current?.focusedField?.item.language ===
|
|
56
|
+
fieldItem.language &&
|
|
57
|
+
editContextRef.current?.focusedField?.item.version === fieldItem.version) {
|
|
58
|
+
const range = editContextRef.current.selectedRange;
|
|
59
|
+
if (range && inputRef.current) {
|
|
60
|
+
inputRef.current.setSelectionRange(range.startOffset, range.endOffset);
|
|
61
|
+
// setSelectionStart(range.startOffset);
|
|
62
|
+
// setSelectionEnd(range.endOffset);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}, [editContext?.selectedRange]);
|
|
66
|
+
// // Calculate the position of the highlight
|
|
67
|
+
// const getHighlightStyle = () => {
|
|
68
|
+
// if (!inputRef.current || selectionStart === selectionEnd) return {};
|
|
69
|
+
// const text = value || "";
|
|
70
|
+
// const beforeSelection = text.slice(0, selectionStart);
|
|
71
|
+
// const selection = text.slice(selectionStart, selectionEnd);
|
|
72
|
+
// // Use a temporary span to measure text width
|
|
73
|
+
// const temp = document.createElement("span");
|
|
74
|
+
// temp.style.font = window.getComputedStyle(inputRef.current).font;
|
|
75
|
+
// temp.style.visibility = "hidden";
|
|
76
|
+
// temp.style.position = "absolute";
|
|
77
|
+
// document.body.appendChild(temp);
|
|
78
|
+
// temp.textContent = beforeSelection;
|
|
79
|
+
// const startPos = temp.getBoundingClientRect().width + 5; // padding
|
|
80
|
+
// temp.textContent = selection;
|
|
81
|
+
// const width = temp.getBoundingClientRect().width;
|
|
82
|
+
// document.body.removeChild(temp);
|
|
83
|
+
// return {
|
|
84
|
+
// left: `${startPos}px`,
|
|
85
|
+
// width: `${width}px`,
|
|
86
|
+
// };
|
|
87
|
+
// };
|
|
88
|
+
return (_jsx("div", { className: "relative", children: _jsx(InputText, { ref: inputRef, value: value || "", disabled: readOnly, className: "p-1.5 focus-shadow text-sm", style: { width: "100%" }, onChange: handleChange, onSelect: handleSelect }, fieldItem.id + field.id + fieldItem.language + fieldItem.version) }));
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=SingleLineText.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SingleLineText.js","sourceRoot":"","sources":["../../../src/editor/field-types/SingleLineText.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Splitter, SplitterPanel } from "primereact/splitter";
|
|
3
|
+
import { useEditContext } from "../client/editContext";
|
|
4
|
+
import { useEffect, useState, useRef } from "react";
|
|
5
|
+
import { OverlayPanel } from "primereact/overlaypanel";
|
|
6
|
+
import { ListBox } from "primereact/listbox";
|
|
7
|
+
import { getLookupSources } from "../services/editService";
|
|
8
|
+
import { SimpleIconButton } from "../ui/SimpleIconButton";
|
|
9
|
+
import { normalizeGuid } from "../utils";
|
|
10
|
+
import ItemSearch from "../ui/ItemSearch";
|
|
11
|
+
import { Button } from "primereact/button";
|
|
12
|
+
import ContentTree from "../ContentTree";
|
|
13
|
+
export default function TreeListEditor({ field, readOnly, }) {
|
|
14
|
+
const editContext = useEditContext();
|
|
15
|
+
const [selectedItemNodesInTree, setSelectedItemNodesInTree] = useState([]);
|
|
16
|
+
const [selectedFromList, setSelectedFromList] = useState([]);
|
|
17
|
+
const overlayPanelRef = useRef(null);
|
|
18
|
+
const [currentItemId, setCurrentItemId] = useState("");
|
|
19
|
+
const [rootItemIds, setRootItemIds] = useState([]);
|
|
20
|
+
const [values, setValues] = useState([]);
|
|
21
|
+
const [hoveredItemId, setHoveredItemId] = useState();
|
|
22
|
+
const [hoveredItem, setHoveredItem] = useState();
|
|
23
|
+
if (!editContext)
|
|
24
|
+
return;
|
|
25
|
+
useEffect(() => {
|
|
26
|
+
const loadItem = async () => {
|
|
27
|
+
if (!hoveredItemId)
|
|
28
|
+
return;
|
|
29
|
+
const item = await editContext.itemsRepository.getItem({
|
|
30
|
+
id: hoveredItemId,
|
|
31
|
+
language: editContext.currentItemDescriptor?.language ?? "en",
|
|
32
|
+
version: 0,
|
|
33
|
+
});
|
|
34
|
+
if (item)
|
|
35
|
+
setHoveredItem(item);
|
|
36
|
+
};
|
|
37
|
+
loadItem();
|
|
38
|
+
}, [hoveredItemId]);
|
|
39
|
+
useEffect(() => {
|
|
40
|
+
if (editContext.lockedField?.fieldId === field.descriptor.fieldId &&
|
|
41
|
+
editContext.lockedField.item.id == field.descriptor.item.id &&
|
|
42
|
+
editContext.lockedField.item.language == field.descriptor.item.language &&
|
|
43
|
+
editContext.lockedField.item.version == field.descriptor.item.version)
|
|
44
|
+
return;
|
|
45
|
+
setValues(field.value || []);
|
|
46
|
+
}, [field.value]);
|
|
47
|
+
useEffect(() => {
|
|
48
|
+
const loadLookupSources = async () => {
|
|
49
|
+
const datasources = await getLookupSources(field, editContext.sessionId);
|
|
50
|
+
if (datasources.length) {
|
|
51
|
+
setRootItemIds(datasources.map((x) => x.id));
|
|
52
|
+
}
|
|
53
|
+
else
|
|
54
|
+
setRootItemIds(["{11111111-1111-1111-1111-111111111111}"]);
|
|
55
|
+
};
|
|
56
|
+
loadLookupSources();
|
|
57
|
+
}, [field.id, field.descriptor.item.id]);
|
|
58
|
+
const trimPath = (path) => {
|
|
59
|
+
const splitPath = path.split("/");
|
|
60
|
+
if (splitPath.length > 2) {
|
|
61
|
+
return (splitPath[splitPath.length - 2] + "/" + splitPath[splitPath.length - 1]);
|
|
62
|
+
}
|
|
63
|
+
return path;
|
|
64
|
+
};
|
|
65
|
+
async function removeFromList(items) {
|
|
66
|
+
const newValues = values.filter((x) => !items.find((i) => x.id == i.id));
|
|
67
|
+
setValues(newValues);
|
|
68
|
+
await editContext?.operations.editField({
|
|
69
|
+
field: field.descriptor,
|
|
70
|
+
value: newValues,
|
|
71
|
+
rawValue: newValues.map((x) => normalizeGuid(x.id)).join("|"),
|
|
72
|
+
refresh: "waitForQuietPeriod",
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
async function addToList(itemNodes) {
|
|
76
|
+
setSelectedItemNodesInTree([]);
|
|
77
|
+
const newValues = [...values];
|
|
78
|
+
itemNodes.forEach((node) => {
|
|
79
|
+
if (!newValues.find((x) => x.id == node.id)) {
|
|
80
|
+
newValues.push({
|
|
81
|
+
id: node.id,
|
|
82
|
+
path: node.path || node.name,
|
|
83
|
+
name: node.name,
|
|
84
|
+
icon: node.icon,
|
|
85
|
+
idPath: node.idPath,
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
setValues(newValues);
|
|
90
|
+
await editContext?.operations.editField({
|
|
91
|
+
field: field.descriptor,
|
|
92
|
+
value: newValues,
|
|
93
|
+
rawValue: newValues.map((x) => normalizeGuid(x.id)).join("|"),
|
|
94
|
+
refresh: "waitForQuietPeriod",
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
return (_jsxs("div", { className: "border focus-shadow border-gray-200", children: [_jsx("div", { className: "bg-white mb-1 p-2 border-b border-gray-200", children: _jsx(ItemSearch, { rootItemIds: rootItemIds.map((x) => normalizeGuid(x)), itemSelected: async (item) => {
|
|
98
|
+
addToList([
|
|
99
|
+
{
|
|
100
|
+
id: item.id,
|
|
101
|
+
path: item.path || item.name,
|
|
102
|
+
idPath: item.idPath,
|
|
103
|
+
name: item.name || "",
|
|
104
|
+
icon: item.icon,
|
|
105
|
+
},
|
|
106
|
+
]);
|
|
107
|
+
} }) }), _jsxs(Splitter, { className: "h-60", children: [_jsx(SplitterPanel, { size: 50, className: "relative", children: _jsx("div", { className: "absolute inset-0 overflow-auto", children: _jsx(ContentTree, { expandIdPath: hoveredItem?.idPath, language: editContext.currentItemDescriptor?.language ?? "en", onDoubleClick: (node) => {
|
|
108
|
+
if (!readOnly)
|
|
109
|
+
addToList([node]);
|
|
110
|
+
}, selectionMode: "multiple", selectedItemIds: selectedItemNodesInTree.length
|
|
111
|
+
? selectedItemNodesInTree.map((x) => x.id)
|
|
112
|
+
: hoveredItemId
|
|
113
|
+
? [hoveredItemId]
|
|
114
|
+
: [], onSelectionChange: (e) => {
|
|
115
|
+
setSelectedItemNodesInTree(e);
|
|
116
|
+
}, rootItemIds: rootItemIds, includeItemPath: true }) }) }), _jsx(SplitterPanel, { children: _jsx("div", { className: "h-full w-full relative", children: _jsxs("div", { className: "absolute inset-0 flex", children: [_jsxs("div", { className: "bg-gray-100 flex flex-col justify-center gap-1 p-1", children: [_jsx(SimpleIconButton, { label: "Add", icon: "pi pi-angle-right", onClick: () => addToList(selectedItemNodesInTree), disabled: readOnly }), _jsx(SimpleIconButton, { label: "Remove", icon: "pi pi-angle-left", onClick: () => removeFromList(selectedFromList), disabled: readOnly })] }), _jsx("div", { className: "flex-1 h-full relative", children: _jsx(ListBox, { className: "absolute inset-0 overflow-auto text-xs", options: values, optionLabel: "path", metaKeySelection: true, emptyMessage: "None selected", multiple: true, value: selectedFromList, onChange: (e) => setSelectedFromList(e.value), itemTemplate: (option) => (_jsxs("div", { className: "select-none hover:bg-gray-50 relative group flex items-center gap-1", onMouseEnter: async () => {
|
|
117
|
+
setHoveredItemId(option.id);
|
|
118
|
+
// setExpandIdPath(option.idPath || "");
|
|
119
|
+
setSelectedItemNodesInTree([option]);
|
|
120
|
+
}, onDoubleClick: () => {
|
|
121
|
+
if (!readOnly)
|
|
122
|
+
removeFromList([option]);
|
|
123
|
+
}, children: [_jsx("img", { src: option.icon, className: "w-4 h-4 mr-2" }), trimPath(option.path), " ", _jsx("button", { className: "opacity-0 group-hover:opacity-100 transition-opacity", onClick: (e) => {
|
|
124
|
+
e.stopPropagation();
|
|
125
|
+
setCurrentItemId(option.id);
|
|
126
|
+
overlayPanelRef.current?.toggle(e);
|
|
127
|
+
}, title: "Open", children: _jsx("i", { className: "pi pi-arrow-up-right text-xs text-gray-500" }) })] })) }) })] }) }) })] }), _jsx(OverlayPanel, { ref: overlayPanelRef, className: "p-0", showCloseIcon: true, children: _jsx("div", { className: "p-3", children: _jsx("div", { className: "flex justify-end gap-2", children: _jsx(Button, { className: "px-3 py-1 bg-blue-500 text-white rounded text-sm", onClick: () => {
|
|
128
|
+
editContext.loadItem(currentItemId);
|
|
129
|
+
overlayPanelRef.current?.hide();
|
|
130
|
+
}, children: "Open" }) }) }) })] }));
|
|
131
|
+
}
|
|
132
|
+
//# sourceMappingURL=TreeListEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TreeListEditor.js","sourceRoot":"","sources":["../../../src/editor/field-types/TreeListEditor.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { Field } from "./pageModel";
|
|
2
|
+
export type TextField = Field & {
|
|
3
|
+
value: string;
|
|
4
|
+
};
|
|
5
|
+
export type PictureField = Field & {
|
|
6
|
+
value: PictureValue | null;
|
|
7
|
+
};
|
|
8
|
+
export type LinkField = Field & {
|
|
9
|
+
value: LinkValue;
|
|
10
|
+
};
|
|
11
|
+
export type InternalLinkField = Field & {
|
|
12
|
+
value: LinkValue;
|
|
13
|
+
};
|
|
14
|
+
export type PictureValue = {
|
|
15
|
+
name: string;
|
|
16
|
+
alt: string;
|
|
17
|
+
variants: PictureVariant[];
|
|
18
|
+
loopVideos: boolean;
|
|
19
|
+
allowVideos?: boolean;
|
|
20
|
+
error?: string;
|
|
21
|
+
};
|
|
22
|
+
export type PictureVariant = {
|
|
23
|
+
mediaItemName: string;
|
|
24
|
+
name: string;
|
|
25
|
+
src: string;
|
|
26
|
+
videoUrl?: string;
|
|
27
|
+
width: number;
|
|
28
|
+
height: number;
|
|
29
|
+
aspectRatio: number;
|
|
30
|
+
aspectRatioLock?: number;
|
|
31
|
+
aspectRatioLockText?: string;
|
|
32
|
+
minWidth?: number;
|
|
33
|
+
minHeight?: number;
|
|
34
|
+
thumbSrc?: string;
|
|
35
|
+
originalSrc?: string;
|
|
36
|
+
mediaId?: string;
|
|
37
|
+
idPath?: string;
|
|
38
|
+
region: PictureRegion;
|
|
39
|
+
};
|
|
40
|
+
export type PictureRegion = {
|
|
41
|
+
x: number;
|
|
42
|
+
y: number;
|
|
43
|
+
width: number;
|
|
44
|
+
height: number;
|
|
45
|
+
};
|
|
46
|
+
export type PictureRawValue = {
|
|
47
|
+
Variants: PictureRawVariant[];
|
|
48
|
+
AltText?: string;
|
|
49
|
+
};
|
|
50
|
+
export type PictureRawVariant = {
|
|
51
|
+
Name: string;
|
|
52
|
+
MediaId?: string;
|
|
53
|
+
VideoId?: string;
|
|
54
|
+
Region?: PictureRawRegion;
|
|
55
|
+
};
|
|
56
|
+
export type PictureRawRegion = {
|
|
57
|
+
X: number;
|
|
58
|
+
Y: number;
|
|
59
|
+
Width: number;
|
|
60
|
+
Height: number;
|
|
61
|
+
};
|
|
62
|
+
export type ImageField = Field & {
|
|
63
|
+
value: ImageValue | null;
|
|
64
|
+
};
|
|
65
|
+
export type ImageValue = {
|
|
66
|
+
alt: string;
|
|
67
|
+
src: string;
|
|
68
|
+
};
|
|
69
|
+
export type LinkValue = {
|
|
70
|
+
url: string;
|
|
71
|
+
type: "internal" | "external";
|
|
72
|
+
target?: string;
|
|
73
|
+
targetItemLongId?: string;
|
|
74
|
+
targetItemName?: string;
|
|
75
|
+
queryString?: string;
|
|
76
|
+
targetItemId?: string;
|
|
77
|
+
};
|
|
78
|
+
export interface KeyValuePair {
|
|
79
|
+
key: string;
|
|
80
|
+
value: string;
|
|
81
|
+
}
|
|
82
|
+
export type EnhancedNameValueListField = {
|
|
83
|
+
value: KeyValuePair[];
|
|
84
|
+
};
|
|
85
|
+
export type ReferencedItem = {
|
|
86
|
+
id: string;
|
|
87
|
+
name: string;
|
|
88
|
+
path: string;
|
|
89
|
+
icon?: string;
|
|
90
|
+
idPath?: string;
|
|
91
|
+
};
|
|
92
|
+
export type TreeListField = Field & {
|
|
93
|
+
value: ReferencedItem[];
|
|
94
|
+
_editor: {
|
|
95
|
+
customEditorProperties: {
|
|
96
|
+
datasources: string[];
|
|
97
|
+
};
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
export type CheckboxField = Field & {
|
|
101
|
+
value: boolean;
|
|
102
|
+
};
|
|
103
|
+
export type DateField = Field & {
|
|
104
|
+
value: DateFieldValue;
|
|
105
|
+
};
|
|
106
|
+
export type DateFieldValue = Field & {
|
|
107
|
+
date: string;
|
|
108
|
+
};
|
|
109
|
+
export type NumberField = Field & {
|
|
110
|
+
value: number;
|
|
111
|
+
};
|
|
112
|
+
export type AttachmentField = Field & {
|
|
113
|
+
value: AttachmentValue;
|
|
114
|
+
};
|
|
115
|
+
export type AttachmentValue = {
|
|
116
|
+
src: string;
|
|
117
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fieldTypes.js","sourceRoot":"","sources":["../../src/editor/fieldTypes.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useState, useRef } from "react";
|
|
3
|
+
import { useDebouncedCallback } from "use-debounce";
|
|
4
|
+
import { createEditorAiContext } from "../ai/editorAiContext";
|
|
5
|
+
import { executePrompt, executeSearch } from "../services/aiService";
|
|
6
|
+
import { useEditContext } from "../client/editContext";
|
|
7
|
+
import { ProgressSpinner } from "primereact/progressspinner";
|
|
8
|
+
import { InputText } from "primereact/inputtext";
|
|
9
|
+
import { Thumbnails } from "./Thumbnails";
|
|
10
|
+
import { Splitter, SplitterPanel } from "primereact/splitter";
|
|
11
|
+
import { Preview } from "./Preview";
|
|
12
|
+
import DialogButtons from "../ui/DialogButtons";
|
|
13
|
+
import { Button } from "primereact/button";
|
|
14
|
+
export function AiImageSearch({ onMediaSelected, onHide, }) {
|
|
15
|
+
const [prompt, setPrompt] = useState("");
|
|
16
|
+
const [loadingPrompt, setLoadingPrompt] = useState(false);
|
|
17
|
+
const [loadingThumbnails, setLoadingThumbnails] = useState(false);
|
|
18
|
+
const [images, setImages] = useState([]);
|
|
19
|
+
const [selectedImage, setSelectedImage] = useState();
|
|
20
|
+
const editContext = useEditContext();
|
|
21
|
+
const currentSuggestionRequest = useRef(null);
|
|
22
|
+
const inputRef = useRef(null);
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
suggestPrompt();
|
|
25
|
+
if (inputRef.current) {
|
|
26
|
+
inputRef.current.focus();
|
|
27
|
+
}
|
|
28
|
+
}, []);
|
|
29
|
+
const suggestPrompt = async () => {
|
|
30
|
+
if (editContext) {
|
|
31
|
+
setPrompt("");
|
|
32
|
+
setLoadingPrompt(true);
|
|
33
|
+
if (currentSuggestionRequest.current) {
|
|
34
|
+
currentSuggestionRequest.current.abort();
|
|
35
|
+
}
|
|
36
|
+
const abortController = new AbortController();
|
|
37
|
+
currentSuggestionRequest.current = abortController;
|
|
38
|
+
try {
|
|
39
|
+
const result = await executePrompt([
|
|
40
|
+
{
|
|
41
|
+
content: "Please extract search terms from the field context that can be used to find a matching image. " +
|
|
42
|
+
"I will use the search terms to find an image and populate the image field. If the component does not provide enough context, " +
|
|
43
|
+
"also get content from the parent component using the get-content function. " +
|
|
44
|
+
"Do not consider current image field contents. " +
|
|
45
|
+
"Reply with search terms only!",
|
|
46
|
+
name: "user",
|
|
47
|
+
role: "user",
|
|
48
|
+
},
|
|
49
|
+
], editContext, createEditorAiContext, ["get-content"], true, { signal: abortController.signal });
|
|
50
|
+
setLoadingPrompt(false);
|
|
51
|
+
const newPrompt = result.responseText.replaceAll("\n", "");
|
|
52
|
+
setPrompt(newPrompt);
|
|
53
|
+
}
|
|
54
|
+
catch (error) {
|
|
55
|
+
if (error instanceof Error && error.name !== "AbortError") {
|
|
56
|
+
console.error("Failed to fetch prompt:", error);
|
|
57
|
+
}
|
|
58
|
+
setLoadingPrompt(false);
|
|
59
|
+
}
|
|
60
|
+
finally {
|
|
61
|
+
currentSuggestionRequest.current = null;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
const handleSearch = useDebouncedCallback(async (searchPrompt) => {
|
|
66
|
+
if (!editContext)
|
|
67
|
+
return;
|
|
68
|
+
setLoadingThumbnails(true);
|
|
69
|
+
const result = await executeSearch({
|
|
70
|
+
query: searchPrompt,
|
|
71
|
+
editContext,
|
|
72
|
+
maxResults: 50,
|
|
73
|
+
index: "media",
|
|
74
|
+
skipValidation: true,
|
|
75
|
+
});
|
|
76
|
+
if (result.type == "success") {
|
|
77
|
+
setImages(result.data);
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
editContext.showToast({
|
|
81
|
+
severity: "error",
|
|
82
|
+
summary: "Error searching",
|
|
83
|
+
detail: result.response.statusText,
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
setLoadingThumbnails(false);
|
|
87
|
+
}, 300);
|
|
88
|
+
const onPromptChange = (e) => {
|
|
89
|
+
const newPrompt = e.target.value;
|
|
90
|
+
setPrompt(newPrompt);
|
|
91
|
+
if (currentSuggestionRequest.current) {
|
|
92
|
+
currentSuggestionRequest.current.abort();
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
useEffect(() => {
|
|
96
|
+
if (prompt) {
|
|
97
|
+
handleSearch(prompt);
|
|
98
|
+
}
|
|
99
|
+
}, [prompt]);
|
|
100
|
+
return (_jsxs(_Fragment, { children: [_jsxs(Splitter, { className: "flex-1 border-0", children: [_jsx(SplitterPanel, { size: 50, className: "flex flex-col pt-4", children: _jsxs("div", { className: "flex flex-col gap-2 text-sm pt-2 px-2 flex-1", children: [_jsxs("div", { children: ["Search prompt", _jsxs("div", { className: "flex gap-2 items-center", children: [_jsx(InputText, { ref: inputRef, value: prompt, onChange: onPromptChange, className: "flex-1" }), loadingPrompt && (_jsx("div", { className: "flex items-center h-10", children: _jsx(ProgressSpinner, { style: { width: "24px", height: "24px" } }) })), !loadingPrompt && (_jsx(Button, { icon: "pi pi-sparkles", onClick: () => suggestPrompt(), label: "Suggest", size: "small" }))] })] }), _jsxs("div", { className: "flex-1 relative", children: [loadingThumbnails && (_jsx("div", { className: "flex items-center h-full", children: _jsx(ProgressSpinner, { style: { width: "24px", height: "24px" } }) })), _jsx(Thumbnails, { images: images, selectedImage: selectedImage, setSelectedImage: setSelectedImage, onMediaSelected: onMediaSelected, onHide: onHide })] })] }) }), _jsx(SplitterPanel, { size: 50, className: " relative", children: _jsx(Preview, { selectedImage: selectedImage }) })] }), _jsxs(DialogButtons, { children: [_jsx(Button, { disabled: !selectedImage, onClick: () => {
|
|
101
|
+
onMediaSelected(selectedImage.id);
|
|
102
|
+
onHide();
|
|
103
|
+
}, children: "Select" }), _jsx(Button, { onClick: () => onHide(), children: "Cancel" })] })] }));
|
|
104
|
+
}
|
|
105
|
+
//# sourceMappingURL=AiImageSearch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AiImageSearch.js","sourceRoot":"","sources":["../../../src/editor/media-selector/AiImageSearch.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Button } from "primereact/button";
|
|
3
|
+
import { InputText } from "primereact/inputtext";
|
|
4
|
+
import { useEffect, useRef, useState } from "react";
|
|
5
|
+
import { useEditContext } from "../client/editContext";
|
|
6
|
+
import { executePrompt } from "../services/aiService";
|
|
7
|
+
import { createEditorAiContext } from "../ai/editorAiContext";
|
|
8
|
+
import { ProgressSpinner } from "primereact/progressspinner";
|
|
9
|
+
export function AiImageSearchPrompt({ onSearchPromptChange, }) {
|
|
10
|
+
const editContext = useEditContext();
|
|
11
|
+
const inputRef = useRef(null);
|
|
12
|
+
const [prompt, setPrompt] = useState("");
|
|
13
|
+
const [loadingPrompt, setLoadingPrompt] = useState(false);
|
|
14
|
+
const currentSuggestionRequest = useRef(null);
|
|
15
|
+
useEffect(() => {
|
|
16
|
+
onSearchPromptChange(prompt);
|
|
17
|
+
}, [prompt]);
|
|
18
|
+
const suggestPrompt = async () => {
|
|
19
|
+
if (editContext) {
|
|
20
|
+
setPrompt("");
|
|
21
|
+
setLoadingPrompt(true);
|
|
22
|
+
if (currentSuggestionRequest.current) {
|
|
23
|
+
currentSuggestionRequest.current.abort();
|
|
24
|
+
}
|
|
25
|
+
const abortController = new AbortController();
|
|
26
|
+
currentSuggestionRequest.current = abortController;
|
|
27
|
+
try {
|
|
28
|
+
const result = await executePrompt([
|
|
29
|
+
{
|
|
30
|
+
content: "Please extract search terms from the field context that can be used to find a matching image. " +
|
|
31
|
+
"I will use the search terms to find an image and populate the image field. If the component does not provide enough context, " +
|
|
32
|
+
"also get content from the parent component using the get-content function. " +
|
|
33
|
+
"Do not consider current image field contents. " +
|
|
34
|
+
"Reply with search terms only!",
|
|
35
|
+
name: "user",
|
|
36
|
+
role: "user",
|
|
37
|
+
},
|
|
38
|
+
], editContext, createEditorAiContext, ["get-content"], true, { signal: abortController.signal });
|
|
39
|
+
setLoadingPrompt(false);
|
|
40
|
+
const newPrompt = result.responseText.replaceAll("\n", "");
|
|
41
|
+
setPrompt(newPrompt);
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
if (error instanceof Error && error.name !== "AbortError") {
|
|
45
|
+
console.error("Failed to fetch prompt:", error);
|
|
46
|
+
}
|
|
47
|
+
setLoadingPrompt(false);
|
|
48
|
+
}
|
|
49
|
+
finally {
|
|
50
|
+
currentSuggestionRequest.current = null;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
return (_jsxs("div", { className: "flex gap-2 items-center m-2", children: [_jsx("i", { className: "pi pi-search text-gray-500" }), _jsx(InputText, { ref: inputRef, value: prompt, onChange: (e) => setPrompt(e.target.value), className: "flex-1" }), loadingPrompt && (_jsx("div", { className: "flex items-center h-10", children: _jsx(ProgressSpinner, { style: { width: "24px", height: "24px" } }) })), !loadingPrompt && (_jsx(Button, { icon: "pi pi-sparkles", onClick: () => suggestPrompt(), label: "Suggest", size: "small" }))] }));
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=AiImageSearchPrompt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AiImageSearchPrompt.js","sourceRoot":"","sources":["../../../src/editor/media-selector/AiImageSearchPrompt.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export type MediaSelectorMode = "images" | "video";
|
|
2
|
+
export declare const MediaSelector: ({ visible, onHide, onMediaSelected, selectedIdPath, mode, language, }: {
|
|
3
|
+
visible: boolean;
|
|
4
|
+
mode: MediaSelectorMode;
|
|
5
|
+
onHide: () => void;
|
|
6
|
+
onMediaSelected: (mediaId: string) => void;
|
|
7
|
+
selectedIdPath?: string;
|
|
8
|
+
language: string;
|
|
9
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { Dialog } from "primereact/dialog";
|
|
4
|
+
import { TreeSelector } from "./TreeSelector";
|
|
5
|
+
export const MediaSelector = ({ visible, onHide, onMediaSelected, selectedIdPath, mode, language, }) => {
|
|
6
|
+
return (_jsx(Dialog, { style: { width: "80%", height: "80%" }, visible: visible, onHide: onHide, header: mode === "video" ? "Select Video" : "Select Image", "data-testid": "media-selector-dialog", children: _jsx("div", { className: "flex flex-col h-full ", children: _jsx(TreeSelector, { language: language, selectedIdPath: selectedIdPath, onHide: onHide, onMediaSelected: onMediaSelected, mode: mode === "video" ? "video" : "image" }) }) }));
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=MediaSelector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MediaSelector.js","sourceRoot":"","sources":["../../../src/editor/media-selector/MediaSelector.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAI9C,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,EAC5B,OAAO,EACP,MAAM,EACN,eAAe,EACf,cAAc,EACd,IAAI,EACJ,QAAQ,GAQT,EAAE,EAAE;IACH,OAAO,CACL,KAAC,MAAM,IACL,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,EACtC,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,cAAc,iBAC9C,uBAAuB,YAEnC,cAAK,SAAS,EAAC,uBAAuB,YACpC,KAAC,YAAY,IACX,QAAQ,EAAE,QAAQ,EAClB,cAAc,EAAE,cAAc,EAC9B,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,eAAe,EAChC,IAAI,EAAE,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,GAC1C,GACE,GACC,CACV,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
export function Preview({ selectedImage }) {
|
|
3
|
+
if (!selectedImage)
|
|
4
|
+
return null;
|
|
5
|
+
return (_jsx("div", { className: "m-4 flex justify-center align-center absolute inset-0", children: _jsx("img", { src: selectedImage?.previewUrl, className: "object-contain", fetchPriority: "high" }) }));
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=Preview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Preview.js","sourceRoot":"","sources":["../../../src/editor/media-selector/Preview.tsx"],"names":[],"mappings":";AAEA,MAAM,UAAU,OAAO,CAAC,EAAE,aAAa,EAAiC;IACtE,IAAI,CAAC,aAAa;QAAE,OAAO,IAAI,CAAC;IAChC,OAAO,CACL,cAAK,SAAS,EAAC,uDAAuD,YACpE,cACE,GAAG,EAAE,aAAa,EAAE,UAAU,EAC9B,SAAS,EAAC,gBAAgB,EAC1B,aAAa,EAAC,MAAM,GACpB,GACE,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export type Thumbnail = {
|
|
2
|
+
id: string;
|
|
3
|
+
name: string;
|
|
4
|
+
thumbUrl: string;
|
|
5
|
+
previewUrl: string;
|
|
6
|
+
};
|
|
7
|
+
export declare function Thumbnails({ images, selectedImage, setSelectedImage, onMediaSelected, onHide, }: {
|
|
8
|
+
images: Thumbnail[];
|
|
9
|
+
selectedImage: Thumbnail | undefined;
|
|
10
|
+
setSelectedImage: (image: Thumbnail) => void;
|
|
11
|
+
onMediaSelected: (imageId: string) => void;
|
|
12
|
+
onHide: () => void;
|
|
13
|
+
}): import("react/jsx-runtime").JSX.Element;
|