@parhelia/core 0.1.12882 → 0.1.12884
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/dist/agents-view/AgentsSidebar.js +1 -1
- package/dist/agents-view/AgentsSidebar.js.map +1 -1
- package/dist/agents-view/AgentsTitlebar.d.ts +1 -1
- package/dist/agents-view/AgentsTitlebar.js +3 -6
- package/dist/agents-view/AgentsTitlebar.js.map +1 -1
- package/dist/agents-view/AgentsView.d.ts +2 -2
- package/dist/agents-view/AgentsView.js +2 -2
- package/dist/agents-view/AgentsView.js.map +1 -1
- package/dist/agents-view/AgentsWorkspaceView.js +1 -12
- package/dist/agents-view/AgentsWorkspaceView.js.map +1 -1
- package/dist/agents-view/CreateAgentView.d.ts +1 -1
- package/dist/agents-view/CreateAgentView.js +1 -1
- package/dist/agents-view/DateAgentsGroup.js +12 -1
- package/dist/agents-view/DateAgentsGroup.js.map +1 -1
- package/dist/agents-view/ProfileAgentsGroup.js +16 -4
- package/dist/agents-view/ProfileAgentsGroup.js.map +1 -1
- package/dist/components/ui/card.d.ts +3 -1
- package/dist/components/ui/card.js +2 -2
- package/dist/components/ui/card.js.map +1 -1
- package/dist/components/ui/checkbox.js +1 -1
- package/dist/components/ui/checkbox.js.map +1 -1
- package/dist/components/ui/context-menu.d.ts +2 -1
- package/dist/components/ui/context-menu.js +6 -3
- package/dist/components/ui/context-menu.js.map +1 -1
- package/dist/components/ui/input.js +2 -2
- package/dist/components/ui/input.js.map +1 -1
- package/dist/components/ui/select.js +1 -1
- package/dist/components/ui/select.js.map +1 -1
- package/dist/components/ui/textarea.js +2 -2
- package/dist/components/ui/textarea.js.map +1 -1
- package/dist/config/config.js +107 -12
- package/dist/config/config.js.map +1 -1
- package/dist/editor/ContextMenu.d.ts +1 -0
- package/dist/editor/ContextMenu.js +4 -4
- package/dist/editor/ContextMenu.js.map +1 -1
- package/dist/editor/FieldActionsOverlay.d.ts +0 -1
- package/dist/editor/FieldActionsOverlay.js +1 -45
- package/dist/editor/FieldActionsOverlay.js.map +1 -1
- package/dist/editor/FieldHistory.d.ts +2 -1
- package/dist/editor/FieldHistory.js +13 -12
- package/dist/editor/FieldHistory.js.map +1 -1
- package/dist/editor/FieldListField.d.ts +1 -1
- package/dist/editor/FieldListField.js +24 -36
- package/dist/editor/FieldListField.js.map +1 -1
- package/dist/editor/ImageEditor.d.ts +6 -1
- package/dist/editor/ImageEditor.js +19 -3
- package/dist/editor/ImageEditor.js.map +1 -1
- package/dist/editor/LinkEditorDialog.d.ts +9 -2
- package/dist/editor/LinkEditorDialog.js +174 -70
- package/dist/editor/LinkEditorDialog.js.map +1 -1
- package/dist/editor/MainLayout.js +49 -6
- package/dist/editor/MainLayout.js.map +1 -1
- package/dist/editor/MobileLayout.js +33 -1
- package/dist/editor/MobileLayout.js.map +1 -1
- package/dist/editor/PictureCropper.js +45 -28
- package/dist/editor/PictureCropper.js.map +1 -1
- package/dist/editor/PictureEditor.d.ts +2 -1
- package/dist/editor/PictureEditor.js +5 -14
- package/dist/editor/PictureEditor.js.map +1 -1
- package/dist/editor/ai/AgentProfileSelector.js +7 -7
- package/dist/editor/ai/AgentProfileSelector.js.map +1 -1
- package/dist/editor/ai/Agents.js +20 -6
- package/dist/editor/ai/Agents.js.map +1 -1
- package/dist/editor/ai/GuidanceOverlay.js +1 -11
- package/dist/editor/ai/GuidanceOverlay.js.map +1 -1
- package/dist/editor/ai/InlineAiDialog.d.ts +1 -0
- package/dist/editor/ai/InlineAiDialog.js +254 -202
- package/dist/editor/ai/InlineAiDialog.js.map +1 -1
- package/dist/editor/ai/InlineAiTextEditTooltip.d.ts +8 -0
- package/dist/editor/ai/InlineAiTextEditTooltip.js +10 -0
- package/dist/editor/ai/InlineAiTextEditTooltip.js.map +1 -0
- package/dist/editor/ai/InlineAiTrigger.js +158 -31
- package/dist/editor/ai/InlineAiTrigger.js.map +1 -1
- package/dist/editor/ai/dialogs/capturePageDom.js +66 -36
- package/dist/editor/ai/dialogs/capturePageDom.js.map +1 -1
- package/dist/editor/ai/dialogs/capturePageScreenshot.js +281 -162
- package/dist/editor/ai/dialogs/capturePageScreenshot.js.map +1 -1
- package/dist/editor/ai/inlineAiTextEditLabels.d.ts +2 -0
- package/dist/editor/ai/inlineAiTextEditLabels.js +8 -0
- package/dist/editor/ai/inlineAiTextEditLabels.js.map +1 -0
- package/dist/editor/ai/prepareInlineAiTextSelection.d.ts +5 -0
- package/dist/editor/ai/prepareInlineAiTextSelection.js +86 -0
- package/dist/editor/ai/prepareInlineAiTextSelection.js.map +1 -0
- package/dist/editor/ai/terminal/agentSessionState.d.ts +3 -0
- package/dist/editor/ai/terminal/agentSessionState.js +3 -1
- package/dist/editor/ai/terminal/agentSessionState.js.map +1 -1
- package/dist/editor/ai/terminal/agentStartRequest.d.ts +2 -1
- package/dist/editor/ai/terminal/agentStartRequest.js +2 -1
- package/dist/editor/ai/terminal/agentStartRequest.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentCostDisplay.js +1 -1
- package/dist/editor/ai/terminal/components/AgentCostDisplay.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentDocumentList.d.ts +7 -0
- package/dist/editor/ai/terminal/components/AgentDocumentList.js +55 -13
- package/dist/editor/ai/terminal/components/AgentDocumentList.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentEditHistoryButton.d.ts +5 -0
- package/dist/editor/ai/terminal/components/AgentEditHistoryButton.js +12 -0
- package/dist/editor/ai/terminal/components/AgentEditHistoryButton.js.map +1 -0
- package/dist/editor/ai/terminal/components/AgentFullPromptControls.d.ts +3 -1
- package/dist/editor/ai/terminal/components/AgentFullPromptControls.js +22 -14
- package/dist/editor/ai/terminal/components/AgentFullPromptControls.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentModeSelector.js +4 -4
- package/dist/editor/ai/terminal/components/AgentModeSelector.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentPromptActionButtons.js +4 -4
- package/dist/editor/ai/terminal/components/AgentPromptActionButtons.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentPromptComposer.js +1 -1
- package/dist/editor/ai/terminal/components/AgentPromptComposer.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentPromptInputArea.d.ts +2 -1
- package/dist/editor/ai/terminal/components/AgentPromptInputArea.js +8 -11
- package/dist/editor/ai/terminal/components/AgentPromptInputArea.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentPromptTrayPopovers.d.ts +1 -4
- package/dist/editor/ai/terminal/components/AgentPromptTrayPopovers.js +31 -14
- package/dist/editor/ai/terminal/components/AgentPromptTrayPopovers.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentSettingsPopover.js +1 -1
- package/dist/editor/ai/terminal/components/AgentSettingsPopover.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalFullLayout.d.ts +2 -1
- package/dist/editor/ai/terminal/components/AgentTerminalFullLayout.js +2 -4
- package/dist/editor/ai/terminal/components/AgentTerminalFullLayout.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalMessageGroups.js +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalMessageGroups.js.map +1 -1
- package/dist/editor/ai/terminal/components/AgentTerminalView.js +13 -2
- package/dist/editor/ai/terminal/components/AgentTerminalView.js.map +1 -1
- package/dist/editor/ai/terminal/components/AiResponseMessage.js +11 -9
- package/dist/editor/ai/terminal/components/AiResponseMessage.js.map +1 -1
- package/dist/editor/ai/terminal/components/ContextInfoBar.js +22 -2
- package/dist/editor/ai/terminal/components/ContextInfoBar.js.map +1 -1
- package/dist/editor/ai/terminal/components/QueuedPromptsPanel.js +37 -26
- package/dist/editor/ai/terminal/components/QueuedPromptsPanel.js.map +1 -1
- package/dist/editor/ai/terminal/components/ToolCallDisplay.js +3 -1
- package/dist/editor/ai/terminal/components/ToolCallDisplay.js.map +1 -1
- package/dist/editor/ai/terminal/components/UserMessage.d.ts +2 -1
- package/dist/editor/ai/terminal/components/UserMessage.js +144 -8
- package/dist/editor/ai/terminal/components/UserMessage.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentPromptComposerHandlers.js +1 -1
- package/dist/editor/ai/terminal/useAgentPromptComposerHandlers.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentSessionSync.d.ts +1 -0
- package/dist/editor/ai/terminal/useAgentSubmitHandlers.d.ts +3 -1
- package/dist/editor/ai/terminal/useAgentSubmitHandlers.js +9 -3
- package/dist/editor/ai/terminal/useAgentSubmitHandlers.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentTerminalController.js +7 -0
- package/dist/editor/ai/terminal/useAgentTerminalController.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentTerminalUiState.js +1 -1
- package/dist/editor/ai/terminal/useAgentTerminalUiState.js.map +1 -1
- package/dist/editor/ai/terminal/useAgentUserMessageSocketHandler.js +3 -1
- package/dist/editor/ai/terminal/useAgentUserMessageSocketHandler.js.map +1 -1
- package/dist/editor/ai/useActiveAgentConversation.d.ts +3 -0
- package/dist/editor/ai/useActiveAgentConversation.js +32 -0
- package/dist/editor/ai/useActiveAgentConversation.js.map +1 -0
- package/dist/editor/ai/useInlineAiPosition.d.ts +10 -2
- package/dist/editor/ai/useInlineAiPosition.js +32 -71
- package/dist/editor/ai/useInlineAiPosition.js.map +1 -1
- package/dist/editor/ai-image-editor/AiImageResultOverlay.js +30 -62
- package/dist/editor/ai-image-editor/AiImageResultOverlay.js.map +1 -1
- package/dist/editor/bridge/BridgeClient.d.ts +80 -0
- package/dist/editor/bridge/BridgeClient.js +417 -0
- package/dist/editor/bridge/BridgeClient.js.map +1 -0
- package/dist/editor/client/EditorShell.d.ts +5 -1
- package/dist/editor/client/EditorShell.js +295 -127
- package/dist/editor/client/EditorShell.js.map +1 -1
- package/dist/editor/client/editContext.d.ts +58 -5
- package/dist/editor/client/editContext.js.map +1 -1
- package/dist/editor/client/fieldModificationStore.d.ts +1 -0
- package/dist/editor/client/fieldModificationStore.js +7 -2
- package/dist/editor/client/fieldModificationStore.js.map +1 -1
- package/dist/editor/client/hooks/useSocketMessageHandler.js +14 -17
- package/dist/editor/client/hooks/useSocketMessageHandler.js.map +1 -1
- package/dist/editor/client/itemsRepository.d.ts +2 -0
- package/dist/editor/client/itemsRepository.js +18 -9
- package/dist/editor/client/itemsRepository.js.map +1 -1
- package/dist/editor/client/operations.d.ts +1 -1
- package/dist/editor/client/operations.js +67 -21
- package/dist/editor/client/operations.js.map +1 -1
- package/dist/editor/client/pageModelBuilder.js +24 -7
- package/dist/editor/client/pageModelBuilder.js.map +1 -1
- package/dist/editor/client/ui/EditorChrome.js +1 -1
- package/dist/editor/client/ui/EditorChrome.js.map +1 -1
- package/dist/editor/commands/componentCommands.d.ts +3 -1
- package/dist/editor/commands/componentCommands.js +8 -3
- package/dist/editor/commands/componentCommands.js.map +1 -1
- package/dist/editor/field-types/DateFieldEditor.js +1 -1
- package/dist/editor/field-types/DateFieldEditor.js.map +1 -1
- package/dist/editor/field-types/DateTimeFieldEditor.js +1 -1
- package/dist/editor/field-types/DateTimeFieldEditor.js.map +1 -1
- package/dist/editor/field-types/DropLinkEditor.js +1 -1
- package/dist/editor/field-types/DropLinkEditor.js.map +1 -1
- package/dist/editor/field-types/DropListEditor.js +1 -1
- package/dist/editor/field-types/DropListEditor.js.map +1 -1
- package/dist/editor/field-types/ImageFieldEditor.js +1 -1
- package/dist/editor/field-types/ImageFieldEditor.js.map +1 -1
- package/dist/editor/field-types/InternalLinkFieldEditor.js +1 -1
- package/dist/editor/field-types/InternalLinkFieldEditor.js.map +1 -1
- package/dist/editor/field-types/LinkFieldEditor.js +15 -3
- package/dist/editor/field-types/LinkFieldEditor.js.map +1 -1
- package/dist/editor/field-types/MultiLineText.js +11 -4
- package/dist/editor/field-types/MultiLineText.js.map +1 -1
- package/dist/editor/field-types/NameValueListEditor.js +1 -1
- package/dist/editor/field-types/NameValueListEditor.js.map +1 -1
- package/dist/editor/field-types/PictureFieldEditor.js +2 -2
- package/dist/editor/field-types/PictureFieldEditor.js.map +1 -1
- package/dist/editor/field-types/RawEditor.js +9 -2
- package/dist/editor/field-types/RawEditor.js.map +1 -1
- package/dist/editor/field-types/RichTextEditorComponent.js +170 -77
- package/dist/editor/field-types/RichTextEditorComponent.js.map +1 -1
- package/dist/editor/field-types/SingleLineText.js +10 -3
- package/dist/editor/field-types/SingleLineText.js.map +1 -1
- package/dist/editor/field-types/TreeListEditor.js +1 -1
- package/dist/editor/field-types/TreeListEditor.js.map +1 -1
- package/dist/editor/field-types/richtext/bridgeRichTextProfile.d.ts +21 -0
- package/dist/editor/field-types/richtext/bridgeRichTextProfile.js +96 -0
- package/dist/editor/field-types/richtext/bridgeRichTextProfile.js.map +1 -0
- package/dist/editor/field-types/richtext/components/ReactSlate.css +44 -6
- package/dist/editor/field-types/richtext/components/ReactSlate.js +191 -36
- package/dist/editor/field-types/richtext/components/ReactSlate.js.map +1 -1
- package/dist/editor/field-types/richtext/components/SimpleRichTextEditor.css +5 -2
- package/dist/editor/field-types/richtext/components/SimpleToolbar.js +5 -4
- package/dist/editor/field-types/richtext/components/SimpleToolbar.js.map +1 -1
- package/dist/editor/field-types/richtext/contextMenuFactory.d.ts +2 -15
- package/dist/editor/field-types/richtext/contextMenuFactory.js +4 -435
- package/dist/editor/field-types/richtext/contextMenuFactory.js.map +1 -1
- package/dist/editor/field-types/richtext/richTextToolbarIcons.d.ts +7 -0
- package/dist/editor/field-types/richtext/richTextToolbarIcons.js +49 -0
- package/dist/editor/field-types/richtext/richTextToolbarIcons.js.map +1 -0
- package/dist/editor/field-types/richtext/types.d.ts +2 -0
- package/dist/editor/field-types/richtext/types.js.map +1 -1
- package/dist/editor/field-types/richtext/utils/conversion.js +23 -2
- package/dist/editor/field-types/richtext/utils/conversion.js.map +1 -1
- package/dist/editor/field-types/useFormFieldCaretPresence.d.ts +13 -0
- package/dist/editor/field-types/useFormFieldCaretPresence.js +92 -0
- package/dist/editor/field-types/useFormFieldCaretPresence.js.map +1 -0
- package/dist/editor/fieldTypes.d.ts +2 -0
- package/dist/editor/media-selector/TreeSelector.js +15 -15
- package/dist/editor/media-selector/TreeSelector.js.map +1 -1
- package/dist/editor/menubar/PageSelector.js +8 -2
- package/dist/editor/menubar/PageSelector.js.map +1 -1
- package/dist/editor/menubar/VersionPreviewCard.js +4 -249
- package/dist/editor/menubar/VersionPreviewCard.js.map +1 -1
- package/dist/editor/menubar/toolbar-sections/EditControls.js +2 -2
- package/dist/editor/menubar/toolbar-sections/EditControls.js.map +1 -1
- package/dist/editor/menubar/toolbar-sections/ManualBrowser.js +338 -187
- package/dist/editor/menubar/toolbar-sections/ManualBrowser.js.map +1 -1
- package/dist/editor/menubar/toolbar-sections/UtilityControls.js +3 -1
- package/dist/editor/menubar/toolbar-sections/UtilityControls.js.map +1 -1
- package/dist/editor/menubar/toolbar-sections/ViewportControls.js +1 -1
- package/dist/editor/page-editor-chrome/BridgeInlineFormatOverlay.d.ts +8 -0
- package/dist/editor/page-editor-chrome/BridgeInlineFormatOverlay.js +407 -0
- package/dist/editor/page-editor-chrome/BridgeInlineFormatOverlay.js.map +1 -0
- package/dist/editor/page-editor-chrome/CommentHighlightings.d.ts +5 -2
- package/dist/editor/page-editor-chrome/CommentHighlightings.js +340 -215
- package/dist/editor/page-editor-chrome/CommentHighlightings.js.map +1 -1
- package/dist/editor/page-editor-chrome/FeedbackHighlightBadge.d.ts +5 -1
- package/dist/editor/page-editor-chrome/FeedbackHighlightBadge.js +11 -4
- package/dist/editor/page-editor-chrome/FeedbackHighlightBadge.js.map +1 -1
- package/dist/editor/page-editor-chrome/FieldActionIndicator.js +21 -13
- package/dist/editor/page-editor-chrome/FieldActionIndicator.js.map +1 -1
- package/dist/editor/page-editor-chrome/FieldEditedIndicator.js +23 -29
- package/dist/editor/page-editor-chrome/FieldEditedIndicator.js.map +1 -1
- package/dist/editor/page-editor-chrome/FrameMenu.js +110 -19
- package/dist/editor/page-editor-chrome/FrameMenu.js.map +1 -1
- package/dist/editor/page-editor-chrome/LockedFieldIndicator.d.ts +3 -2
- package/dist/editor/page-editor-chrome/LockedFieldIndicator.js +148 -45
- package/dist/editor/page-editor-chrome/LockedFieldIndicator.js.map +1 -1
- package/dist/editor/page-editor-chrome/PageEditorChrome.d.ts +2 -0
- package/dist/editor/page-editor-chrome/PageEditorChrome.js +25 -21
- package/dist/editor/page-editor-chrome/PageEditorChrome.js.map +1 -1
- package/dist/editor/page-editor-chrome/PictureEditorOverlay.js +163 -128
- package/dist/editor/page-editor-chrome/PictureEditorOverlay.js.map +1 -1
- package/dist/editor/page-editor-chrome/PlaceholderDropZone.d.ts +1 -1
- package/dist/editor/page-editor-chrome/PlaceholderDropZone.js +6 -3
- package/dist/editor/page-editor-chrome/PlaceholderDropZone.js.map +1 -1
- package/dist/editor/page-editor-chrome/PlaceholderDropZones.d.ts +1 -2
- package/dist/editor/page-editor-chrome/PlaceholderDropZones.js +83 -146
- package/dist/editor/page-editor-chrome/PlaceholderDropZones.js.map +1 -1
- package/dist/editor/page-editor-chrome/SuggestionHighlightings.d.ts +5 -2
- package/dist/editor/page-editor-chrome/SuggestionHighlightings.js +144 -63
- package/dist/editor/page-editor-chrome/SuggestionHighlightings.js.map +1 -1
- package/dist/editor/page-editor-chrome/VersionDiffHighlightings.d.ts +1 -2
- package/dist/editor/page-editor-chrome/VersionDiffHighlightings.js +101 -30
- package/dist/editor/page-editor-chrome/VersionDiffHighlightings.js.map +1 -1
- package/dist/editor/page-editor-chrome/bridgeInlineFormatToolbarLayout.d.ts +24 -0
- package/dist/editor/page-editor-chrome/bridgeInlineFormatToolbarLayout.js +89 -0
- package/dist/editor/page-editor-chrome/bridgeInlineFormatToolbarLayout.js.map +1 -0
- package/dist/editor/page-editor-chrome/overlay/IframeOverlayProvider.d.ts +10 -1
- package/dist/editor/page-editor-chrome/overlay/IframeOverlayProvider.js +105 -122
- package/dist/editor/page-editor-chrome/overlay/IframeOverlayProvider.js.map +1 -1
- package/dist/editor/page-editor-chrome/overlay/geometry.d.ts +11 -4
- package/dist/editor/page-editor-chrome/overlay/geometry.js +139 -36
- package/dist/editor/page-editor-chrome/overlay/geometry.js.map +1 -1
- package/dist/editor/page-editor-chrome/useBridgeInlineEditing.d.ts +26 -0
- package/dist/editor/page-editor-chrome/useBridgeInlineEditing.js +228 -0
- package/dist/editor/page-editor-chrome/useBridgeInlineEditing.js.map +1 -0
- package/dist/editor/page-viewer/EditorForm.js +17 -1
- package/dist/editor/page-viewer/EditorForm.js.map +1 -1
- package/dist/editor/page-viewer/MiniMap.d.ts +2 -2
- package/dist/editor/page-viewer/MiniMap.js +176 -364
- package/dist/editor/page-viewer/MiniMap.js.map +1 -1
- package/dist/editor/page-viewer/PageViewer.js +63 -17
- package/dist/editor/page-viewer/PageViewer.js.map +1 -1
- package/dist/editor/page-viewer/PageViewerFrame.d.ts +0 -5
- package/dist/editor/page-viewer/PageViewerFrame.js +1685 -1512
- package/dist/editor/page-viewer/PageViewerFrame.js.map +1 -1
- package/dist/editor/page-viewer/bridgeFieldPatch.d.ts +20 -0
- package/dist/editor/page-viewer/bridgeFieldPatch.js +33 -0
- package/dist/editor/page-viewer/bridgeFieldPatch.js.map +1 -0
- package/dist/editor/page-viewer/pageViewContext.d.ts +32 -0
- package/dist/editor/page-viewer/pageViewContext.js +37 -6
- package/dist/editor/page-viewer/pageViewContext.js.map +1 -1
- package/dist/editor/reviews/Comment.d.ts +2 -1
- package/dist/editor/reviews/Comment.js +10 -5
- package/dist/editor/reviews/Comment.js.map +1 -1
- package/dist/editor/reviews/CommentDisplayPopover.js +2 -1
- package/dist/editor/reviews/CommentDisplayPopover.js.map +1 -1
- package/dist/editor/reviews/CommentEditor.d.ts +1 -0
- package/dist/editor/reviews/CommentEditor.js +3 -2
- package/dist/editor/reviews/CommentEditor.js.map +1 -1
- package/dist/editor/reviews/CommentPopover.js +69 -10
- package/dist/editor/reviews/CommentPopover.js.map +1 -1
- package/dist/editor/reviews/CommentView.js +24 -4
- package/dist/editor/reviews/CommentView.js.map +1 -1
- package/dist/editor/reviews/Comments.d.ts +0 -2
- package/dist/editor/reviews/Comments.js +31 -31
- package/dist/editor/reviews/Comments.js.map +1 -1
- package/dist/editor/reviews/FeedbackCard.d.ts +4 -2
- package/dist/editor/reviews/FeedbackCard.js +8 -10
- package/dist/editor/reviews/FeedbackCard.js.map +1 -1
- package/dist/editor/reviews/SuggestedEdit.js +4 -6
- package/dist/editor/reviews/SuggestedEdit.js.map +1 -1
- package/dist/editor/reviews/SuggestionCommentThread.js +3 -3
- package/dist/editor/reviews/SuggestionCommentThread.js.map +1 -1
- package/dist/editor/reviews/SuggestionDisplayPopover.js +3 -2
- package/dist/editor/reviews/SuggestionDisplayPopover.js.map +1 -1
- package/dist/editor/reviews/commentAi.js +96 -27
- package/dist/editor/reviews/commentAi.js.map +1 -1
- package/dist/editor/reviews/commentTransientSelection.d.ts +23 -0
- package/dist/editor/reviews/commentTransientSelection.js +7 -0
- package/dist/editor/reviews/commentTransientSelection.js.map +1 -0
- package/dist/editor/reviews/feedbackOrdering.d.ts +5 -0
- package/dist/editor/reviews/feedbackOrdering.js +27 -0
- package/dist/editor/reviews/feedbackOrdering.js.map +1 -0
- package/dist/editor/reviews/feedbackSelection.js +32 -4
- package/dist/editor/reviews/feedbackSelection.js.map +1 -1
- package/dist/editor/reviews/suggestedEditState.d.ts +12 -0
- package/dist/editor/reviews/suggestedEditState.js +90 -0
- package/dist/editor/reviews/suggestedEditState.js.map +1 -0
- package/dist/editor/reviews/suggestionDisplayValue.d.ts +43 -0
- package/dist/editor/reviews/suggestionDisplayValue.js +93 -0
- package/dist/editor/reviews/suggestionDisplayValue.js.map +1 -0
- package/dist/editor/services/agentService.d.ts +15 -0
- package/dist/editor/services/agentService.js +11 -1
- package/dist/editor/services/agentService.js.map +1 -1
- package/dist/editor/services/reviewsService.d.ts +2 -2
- package/dist/editor/services/reviewsService.js.map +1 -1
- package/dist/editor/settings/SettingsView.js +2 -2
- package/dist/editor/settings/SettingsView.js.map +1 -1
- package/dist/editor/settings/panels/ProjectTemplatesPanel.js +1 -1
- package/dist/editor/settings/panels/ProjectTemplatesPanel.js.map +1 -1
- package/dist/editor/settings/panels/ProvidersPanel.js +2 -3
- package/dist/editor/settings/panels/ProvidersPanel.js.map +1 -1
- package/dist/editor/sidebar/MorePanelsButton.js +1 -1
- package/dist/editor/sidebar/MorePanelsButton.js.map +1 -1
- package/dist/editor/sidebar/Validation.js +4 -1
- package/dist/editor/sidebar/Validation.js.map +1 -1
- package/dist/editor/sidebar/Workbox.js +1 -1
- package/dist/editor/sidebar/Workbox.js.map +1 -1
- package/dist/editor/template-wizard/TemplateStructureInlineEditor.js +1 -1
- package/dist/editor/template-wizard/TemplateStructureInlineEditor.js.map +1 -1
- package/dist/editor/ui/IconSelectorDialog.js +1 -1
- package/dist/editor/ui/IconSelectorDialog.js.map +1 -1
- package/dist/editor/ui/SimpleIconButton.d.ts +2 -2
- package/dist/editor/ui/SimpleIconButton.js +7 -1
- package/dist/editor/ui/SimpleIconButton.js.map +1 -1
- package/dist/editor/ui/Splitter.d.ts +1 -0
- package/dist/editor/ui/Splitter.js +12 -2
- package/dist/editor/ui/Splitter.js.map +1 -1
- package/dist/editor/ui/animationSettle.d.ts +32 -0
- package/dist/editor/ui/animationSettle.js +85 -0
- package/dist/editor/ui/animationSettle.js.map +1 -0
- package/dist/editor/utils/expandSelectionAtCaret.d.ts +15 -0
- package/dist/editor/utils/expandSelectionAtCaret.js +183 -0
- package/dist/editor/utils/expandSelectionAtCaret.js.map +1 -0
- package/dist/editor/utils.d.ts +1 -17
- package/dist/editor/utils.js +0 -143
- package/dist/editor/utils.js.map +1 -1
- package/dist/editor/version-diff/versionDiffTargets.d.ts +3 -8
- package/dist/editor/version-diff/versionDiffTargets.js +37 -94
- package/dist/editor/version-diff/versionDiffTargets.js.map +1 -1
- package/dist/revision.d.ts +2 -2
- package/dist/revision.js +2 -2
- package/dist/splash-screen/ModernSplashScreen.js +11 -3
- package/dist/splash-screen/ModernSplashScreen.js.map +1 -1
- package/dist/splash-screen/NewPage.js +7 -5
- package/dist/splash-screen/NewPage.js.map +1 -1
- package/dist/splash-screen/OpenPage.js +5 -3
- package/dist/splash-screen/OpenPage.js.map +1 -1
- package/dist/splash-screen/RecentPages.js +3 -3
- package/dist/splash-screen/RecentPages.js.map +1 -1
- package/dist/task-board/components/TaskDetailPanel.js +2 -1
- package/dist/task-board/components/TaskDetailPanel.js.map +1 -1
- package/dist/task-board/views/DependencyGraphView.d.ts +42 -1
- package/dist/task-board/views/DependencyGraphView.js +94 -0
- package/dist/task-board/views/DependencyGraphView.js.map +1 -1
- package/dist/types.d.ts +1 -0
- package/package.json +2 -1
- package/styles.css +96 -0
- package/dist/editor/page-editor-chrome/InlineEditor.d.ts +0 -7
- package/dist/editor/page-editor-chrome/InlineEditor.js +0 -1719
- package/dist/editor/page-editor-chrome/InlineEditor.js.map +0 -1
- package/dist/editor/page-editor-chrome/overlay/iframeAccess.d.ts +0 -2
- package/dist/editor/page-editor-chrome/overlay/iframeAccess.js +0 -21
- package/dist/editor/page-editor-chrome/overlay/iframeAccess.js.map +0 -1
- package/dist/editor/page-editor-chrome/useInlineAICompletion.d.ts +0 -7
- package/dist/editor/page-editor-chrome/useInlineAICompletion.js +0 -758
- package/dist/editor/page-editor-chrome/useInlineAICompletion.js.map +0 -1
- package/dist/editor/page-viewer/pageModelSkeletonBuilder.d.ts +0 -3
- package/dist/editor/page-viewer/pageModelSkeletonBuilder.js +0 -796
- package/dist/editor/page-viewer/pageModelSkeletonBuilder.js.map +0 -1
|
@@ -1,3 +1,30 @@
|
|
|
1
|
+
import { getComponentById } from "../componentTreeHelper";
|
|
2
|
+
function idsMatch(left, right) {
|
|
3
|
+
const normalize = (value) => (value ?? "").replace(/[{}-]/g, "").toLowerCase();
|
|
4
|
+
const a = normalize(left);
|
|
5
|
+
const b = normalize(right);
|
|
6
|
+
return !!a && !!b && a === b;
|
|
7
|
+
}
|
|
8
|
+
function getRelatedItem(comment, itemId) {
|
|
9
|
+
if (!itemId)
|
|
10
|
+
return undefined;
|
|
11
|
+
return comment.relatedItems?.find((item) => idsMatch(item.itemId, itemId));
|
|
12
|
+
}
|
|
13
|
+
function buildCommentTargetPromptParts(comment) {
|
|
14
|
+
const parts = [];
|
|
15
|
+
const mainItemId = comment.mainItemId;
|
|
16
|
+
const targetItemId = comment.itemId;
|
|
17
|
+
if (comment.mainItemName || mainItemId) {
|
|
18
|
+
parts.push(`Page: ${comment.mainItemName || "unknown"}${mainItemId ? ` (${mainItemId})` : ""}`);
|
|
19
|
+
}
|
|
20
|
+
if (targetItemId && !idsMatch(targetItemId, mainItemId)) {
|
|
21
|
+
parts.push(`Anchored item/component: ${comment.itemName || "unknown"} (${targetItemId})`);
|
|
22
|
+
}
|
|
23
|
+
if (comment.fieldId || comment.fieldName) {
|
|
24
|
+
parts.push(`Field: ${comment.fieldName || "unknown"}${comment.fieldId ? ` (${comment.fieldId})` : ""}`);
|
|
25
|
+
}
|
|
26
|
+
return parts;
|
|
27
|
+
}
|
|
1
28
|
/**
|
|
2
29
|
* Opens the Agents panel and seeds it with context from a review comment.
|
|
3
30
|
* Safe to call with an undefined editContext; it will no-op.
|
|
@@ -33,6 +60,7 @@ export function openAiAgentForComment(comment, editContext) {
|
|
|
33
60
|
promptParts.push(`Comment: "${text}"`);
|
|
34
61
|
if (selectedText)
|
|
35
62
|
promptParts.push(`Selected text: "${selectedText}"`);
|
|
63
|
+
promptParts.push(...buildCommentTargetPromptParts(comment));
|
|
36
64
|
const initialPrompt = promptParts.length > 0
|
|
37
65
|
? `Please help resolve this review comment. ${promptParts.join(" | ")}`
|
|
38
66
|
: "Please help resolve this review comment.";
|
|
@@ -43,40 +71,81 @@ export function openAiAgentForComment(comment, editContext) {
|
|
|
43
71
|
else {
|
|
44
72
|
editContext.setShowAgentsPanel(true);
|
|
45
73
|
}
|
|
74
|
+
const mainItemId = comment.mainItemId || editContext.currentItemDescriptor?.id;
|
|
75
|
+
const mainRelatedItem = getRelatedItem(comment, mainItemId);
|
|
76
|
+
const targetRelatedItem = getRelatedItem(comment, comment.itemId);
|
|
77
|
+
const pageItem = mainItemId && comment.language && comment.version
|
|
78
|
+
? {
|
|
79
|
+
id: mainItemId,
|
|
80
|
+
language: comment.language,
|
|
81
|
+
version: comment.version,
|
|
82
|
+
name: comment.mainItemName ||
|
|
83
|
+
mainRelatedItem?.itemName ||
|
|
84
|
+
editContext.item?.name,
|
|
85
|
+
path: mainRelatedItem?.itemPath || editContext.item?.path,
|
|
86
|
+
}
|
|
87
|
+
: undefined;
|
|
88
|
+
const componentIds = Array.from(new Set([
|
|
89
|
+
...(editContext.selection || []),
|
|
90
|
+
comment.itemId && !idsMatch(comment.itemId, mainItemId)
|
|
91
|
+
? comment.itemId
|
|
92
|
+
: undefined,
|
|
93
|
+
].filter((id) => !!id)));
|
|
94
|
+
const components = componentIds
|
|
95
|
+
.map((componentId) => {
|
|
96
|
+
let component;
|
|
97
|
+
try {
|
|
98
|
+
component = editContext.page
|
|
99
|
+
? getComponentById(componentId, editContext.page)
|
|
100
|
+
: undefined;
|
|
101
|
+
}
|
|
102
|
+
catch {
|
|
103
|
+
component = undefined;
|
|
104
|
+
}
|
|
105
|
+
if (!component && !idsMatch(componentId, comment.itemId)) {
|
|
106
|
+
return undefined;
|
|
107
|
+
}
|
|
108
|
+
return {
|
|
109
|
+
componentId,
|
|
110
|
+
componentName: component?.datasourceItem?.name ||
|
|
111
|
+
component?.name ||
|
|
112
|
+
(idsMatch(componentId, comment.itemId)
|
|
113
|
+
? comment.itemName || targetRelatedItem?.itemName
|
|
114
|
+
: undefined),
|
|
115
|
+
componentType: component?.type || undefined,
|
|
116
|
+
renderingItemId: component?.rendering?.id || undefined,
|
|
117
|
+
pageItem: pageItem,
|
|
118
|
+
};
|
|
119
|
+
})
|
|
120
|
+
.filter((component) => !!component && !!component.pageItem);
|
|
121
|
+
const field = comment.fieldId && comment.itemId
|
|
122
|
+
? {
|
|
123
|
+
fieldId: comment.fieldId,
|
|
124
|
+
fieldName: comment.fieldName,
|
|
125
|
+
item: {
|
|
126
|
+
id: comment.itemId,
|
|
127
|
+
language: comment.language,
|
|
128
|
+
version: comment.version,
|
|
129
|
+
name: comment.itemName || targetRelatedItem?.itemName,
|
|
130
|
+
path: targetRelatedItem?.itemPath,
|
|
131
|
+
},
|
|
132
|
+
}
|
|
133
|
+
: undefined;
|
|
46
134
|
const initialMetadata = {
|
|
47
135
|
items: [
|
|
48
136
|
{
|
|
49
|
-
id:
|
|
50
|
-
editContext.currentItemDescriptor?.id,
|
|
137
|
+
id: mainItemId,
|
|
51
138
|
language: comment.language,
|
|
52
139
|
version: comment.version,
|
|
53
|
-
name:
|
|
140
|
+
name: comment.mainItemName ||
|
|
141
|
+
mainRelatedItem?.itemName ||
|
|
142
|
+
editContext.item?.name,
|
|
143
|
+
path: mainRelatedItem?.itemPath || editContext.item?.path,
|
|
54
144
|
},
|
|
55
145
|
],
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
pageItem: {
|
|
60
|
-
id: comment.mainItemId ||
|
|
61
|
-
editContext.currentItemDescriptor?.id,
|
|
62
|
-
language: comment.language,
|
|
63
|
-
version: comment.version,
|
|
64
|
-
name: editContext.item?.name,
|
|
65
|
-
},
|
|
66
|
-
}))
|
|
67
|
-
: undefined,
|
|
68
|
-
field: comment.fieldId && comment.itemId
|
|
69
|
-
? {
|
|
70
|
-
fieldId: comment.fieldId,
|
|
71
|
-
fieldName: comment.fieldName,
|
|
72
|
-
item: {
|
|
73
|
-
id: comment.itemId,
|
|
74
|
-
language: comment.language,
|
|
75
|
-
version: comment.version,
|
|
76
|
-
name: comment.itemName,
|
|
77
|
-
},
|
|
78
|
-
}
|
|
79
|
-
: undefined,
|
|
146
|
+
currentItemId: mainItemId,
|
|
147
|
+
components: components.length > 0 ? components : undefined,
|
|
148
|
+
field,
|
|
80
149
|
comment: {
|
|
81
150
|
id: comment.id,
|
|
82
151
|
text: comment.text,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commentAi.js","sourceRoot":"","sources":["../../../src/editor/reviews/commentAi.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"commentAi.js","sourceRoot":"","sources":["../../../src/editor/reviews/commentAi.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { Comment } from "../../types";
|
|
2
|
+
import type { SelectionRange } from "../client/editContext";
|
|
3
|
+
export type ViewportSelectionRect = {
|
|
4
|
+
x: number;
|
|
5
|
+
y: number;
|
|
6
|
+
width: number;
|
|
7
|
+
height: number;
|
|
8
|
+
top: number;
|
|
9
|
+
right: number;
|
|
10
|
+
bottom: number;
|
|
11
|
+
left: number;
|
|
12
|
+
};
|
|
13
|
+
export declare const COMMENT_TRANSIENT_SELECTION_RECT: unique symbol;
|
|
14
|
+
export declare const COMMENT_TRANSIENT_ELEMENT_KEY: unique symbol;
|
|
15
|
+
export type CommentWithTransientSelection = Comment & {
|
|
16
|
+
[COMMENT_TRANSIENT_ELEMENT_KEY]?: string;
|
|
17
|
+
[COMMENT_TRANSIENT_SELECTION_RECT]?: ViewportSelectionRect;
|
|
18
|
+
};
|
|
19
|
+
export declare const COMMENT_DRAFT_SELECTION_EVENT = "parhelia:comment-draft-selection";
|
|
20
|
+
export type CommentDraftSelectionEventDetail = {
|
|
21
|
+
range?: SelectionRange;
|
|
22
|
+
};
|
|
23
|
+
export declare function publishCommentDraftSelection(range?: SelectionRange): void;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export const COMMENT_TRANSIENT_SELECTION_RECT = Symbol("parhelia.commentTransientSelectionRect");
|
|
2
|
+
export const COMMENT_TRANSIENT_ELEMENT_KEY = Symbol("parhelia.commentTransientElementKey");
|
|
3
|
+
export const COMMENT_DRAFT_SELECTION_EVENT = "parhelia:comment-draft-selection";
|
|
4
|
+
export function publishCommentDraftSelection(range) {
|
|
5
|
+
window.dispatchEvent(new CustomEvent(COMMENT_DRAFT_SELECTION_EVENT, { detail: { range } }));
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=commentTransientSelection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commentTransientSelection.js","sourceRoot":"","sources":["../../../src/editor/reviews/commentTransientSelection.ts"],"names":[],"mappings":"AAcA,MAAM,CAAC,MAAM,gCAAgC,GAAG,MAAM,CACpD,wCAAwC,CACzC,CAAC;AAEF,MAAM,CAAC,MAAM,6BAA6B,GAAG,MAAM,CACjD,qCAAqC,CACtC,CAAC;AAOF,MAAM,CAAC,MAAM,6BAA6B,GAAG,kCAAkC,CAAC;AAMhF,MAAM,UAAU,4BAA4B,CAAC,KAAsB;IACjE,MAAM,CAAC,aAAa,CAClB,IAAI,WAAW,CACb,6BAA6B,EAC7B,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,CACtB,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { Comment, SuggestedEdit } from "../../types";
|
|
2
|
+
export type FeedbackItem = Comment | SuggestedEdit;
|
|
3
|
+
export declare function isSuggestedEdit(item: FeedbackItem): item is SuggestedEdit;
|
|
4
|
+
export declare function getFeedbackActivityTime(item: FeedbackItem, suggestionCommentsBySuggestionId?: ReadonlyMap<string, Comment[]>): number;
|
|
5
|
+
export declare function sortFeedbackItemsMostRecentFirst(items: FeedbackItem[], suggestionCommentsBySuggestionId?: ReadonlyMap<string, Comment[]>): FeedbackItem[];
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export function isSuggestedEdit(item) {
|
|
2
|
+
return "oldValue" in item && "newValue" in item;
|
|
3
|
+
}
|
|
4
|
+
function parseCreatedTime(value) {
|
|
5
|
+
if (!value)
|
|
6
|
+
return 0;
|
|
7
|
+
const time = new Date(value).getTime();
|
|
8
|
+
return Number.isFinite(time) ? time : 0;
|
|
9
|
+
}
|
|
10
|
+
export function getFeedbackActivityTime(item, suggestionCommentsBySuggestionId) {
|
|
11
|
+
const itemTime = parseCreatedTime(item.created);
|
|
12
|
+
if (!isSuggestedEdit(item))
|
|
13
|
+
return itemTime;
|
|
14
|
+
const latestCommentTime = Math.max(0, ...(suggestionCommentsBySuggestionId?.get(item.id) || []).map((comment) => parseCreatedTime(comment.created)));
|
|
15
|
+
return Math.max(itemTime, latestCommentTime);
|
|
16
|
+
}
|
|
17
|
+
export function sortFeedbackItemsMostRecentFirst(items, suggestionCommentsBySuggestionId) {
|
|
18
|
+
return items
|
|
19
|
+
.map((item, index) => ({ item, index }))
|
|
20
|
+
.sort((a, b) => {
|
|
21
|
+
const timeDifference = getFeedbackActivityTime(b.item, suggestionCommentsBySuggestionId) -
|
|
22
|
+
getFeedbackActivityTime(a.item, suggestionCommentsBySuggestionId);
|
|
23
|
+
return timeDifference || a.index - b.index;
|
|
24
|
+
})
|
|
25
|
+
.map(({ item }) => item);
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=feedbackOrdering.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"feedbackOrdering.js","sourceRoot":"","sources":["../../../src/editor/reviews/feedbackOrdering.ts"],"names":[],"mappings":"AAIA,MAAM,UAAU,eAAe,CAAC,IAAkB;IAChD,OAAO,UAAU,IAAI,IAAI,IAAI,UAAU,IAAI,IAAI,CAAC;AAClD,CAAC;AAED,SAAS,gBAAgB,CAAC,KAAc;IACtC,IAAI,CAAC,KAAK;QAAE,OAAO,CAAC,CAAC;IAErB,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC;IACvC,OAAO,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,uBAAuB,CACrC,IAAkB,EAClB,gCAAiE;IAEjE,MAAM,QAAQ,GAAG,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAEhD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;QAAE,OAAO,QAAQ,CAAC;IAE5C,MAAM,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAChC,CAAC,EACD,GAAG,CAAC,gCAAgC,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACxE,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,CAClC,CACF,CAAC;IAEF,OAAO,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;AAC/C,CAAC;AAED,MAAM,UAAU,gCAAgC,CAC9C,KAAqB,EACrB,gCAAiE;IAEjE,OAAO,KAAK;SACT,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;SACvC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACb,MAAM,cAAc,GAClB,uBAAuB,CAAC,CAAC,CAAC,IAAI,EAAE,gCAAgC,CAAC;YACjE,uBAAuB,CAAC,CAAC,CAAC,IAAI,EAAE,gCAAgC,CAAC,CAAC;QAEpE,OAAO,cAAc,IAAI,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;IAC7C,CAAC,CAAC;SACD,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;AAC7B,CAAC"}
|
|
@@ -1,3 +1,13 @@
|
|
|
1
|
+
function normalizeBridgeId(value) {
|
|
2
|
+
return (value ?? "").replace(/[{}-]/g, "").toLowerCase();
|
|
3
|
+
}
|
|
4
|
+
function bridgeIdsMatch(left, right) {
|
|
5
|
+
const normalizedLeft = normalizeBridgeId(left);
|
|
6
|
+
const normalizedRight = normalizeBridgeId(right);
|
|
7
|
+
return (!!normalizedLeft &&
|
|
8
|
+
!!normalizedRight &&
|
|
9
|
+
normalizedLeft === normalizedRight);
|
|
10
|
+
}
|
|
1
11
|
export async function selectFeedbackComment(comment, editContext, fieldsContext) {
|
|
2
12
|
const currentPageId = editContext?.currentItemDescriptor?.id;
|
|
3
13
|
if (currentPageId &&
|
|
@@ -22,10 +32,28 @@ export async function selectFeedbackComment(comment, editContext, fieldsContext)
|
|
|
22
32
|
version: comment.version,
|
|
23
33
|
},
|
|
24
34
|
}, false);
|
|
25
|
-
const
|
|
26
|
-
?.
|
|
27
|
-
const
|
|
28
|
-
|
|
35
|
+
const geometry = editContext?.getActiveSlotContext?.()?.primaryPageViewContext
|
|
36
|
+
?.bridgeGeometry;
|
|
37
|
+
const fieldIsRendered = geometry?.targets.some((target) => {
|
|
38
|
+
if (target.kind !== "field")
|
|
39
|
+
return false;
|
|
40
|
+
if (!bridgeIdsMatch(target.fieldId, comment.fieldId))
|
|
41
|
+
return false;
|
|
42
|
+
if (!bridgeIdsMatch(target.item?.id, comment.itemId))
|
|
43
|
+
return false;
|
|
44
|
+
if (target.item?.language &&
|
|
45
|
+
comment.language &&
|
|
46
|
+
target.item.language !== comment.language) {
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
if (typeof target.item?.version === "number" &&
|
|
50
|
+
typeof comment.version === "number" &&
|
|
51
|
+
target.item.version !== comment.version) {
|
|
52
|
+
return false;
|
|
53
|
+
}
|
|
54
|
+
return true;
|
|
55
|
+
});
|
|
56
|
+
if (!fieldIsRendered) {
|
|
29
57
|
const slotId = editContext?.activeSlotId ?? null;
|
|
30
58
|
if (editContext?.isEditorFormHiddenForSlot(slotId)) {
|
|
31
59
|
editContext.setEditorFormHiddenForSlot(slotId, false);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"feedbackSelection.js","sourceRoot":"","sources":["../../../src/editor/reviews/feedbackSelection.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,OAAgB,EAChB,WAAwC,EACxC,aAAgD;IAEhD,MAAM,aAAa,GAAG,WAAW,EAAE,qBAAqB,EAAE,EAAE,CAAC;IAC7D,IACE,aAAa;QACb,OAAO,CAAC,UAAU;QAClB,OAAO,CAAC,UAAU,KAAK,aAAa,EACpC,CAAC;QACD,MAAM,WAAW,EAAE,QAAQ,CAAC;YAC1B,EAAE,EAAE,OAAO,CAAC,UAAU;YACtB,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,OAAO,CAAC,OAAO;SACzB,CAAC,CAAC;IACL,CAAC;IAED,WAAW,EAAE,kBAAkB,CAAC,OAAO,CAAC,CAAC;IACzC,WAAW,EAAE,iBAAiB,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAE/C,IAAI,CAAC,WAAW,EAAE,QAAQ,EAAE,CAAC;QAC3B,WAAW,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC;QACtC,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YACpB,aAAa,EAAE,eAAe,CAC5B;gBACE,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,IAAI,EAAE;oBACJ,EAAE,EAAE,OAAO,CAAC,MAAM;oBAClB,QAAQ,EAAE,OAAO,CAAC,QAAQ;oBAC1B,OAAO,EAAE,OAAO,CAAC,OAAO;iBACzB;aACF,EACD,KAAK,CACN,CAAC;YAEF,MAAM,
|
|
1
|
+
{"version":3,"file":"feedbackSelection.js","sourceRoot":"","sources":["../../../src/editor/reviews/feedbackSelection.ts"],"names":[],"mappings":"AAMA,SAAS,iBAAiB,CAAC,KAAgC;IACzD,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;AAC3D,CAAC;AAED,SAAS,cAAc,CACrB,IAA+B,EAC/B,KAAgC;IAEhC,MAAM,cAAc,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAC/C,MAAM,eAAe,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACjD,OAAO,CACL,CAAC,CAAC,cAAc;QAChB,CAAC,CAAC,eAAe;QACjB,cAAc,KAAK,eAAe,CACnC,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,OAAgB,EAChB,WAAwC,EACxC,aAAgD;IAEhD,MAAM,aAAa,GAAG,WAAW,EAAE,qBAAqB,EAAE,EAAE,CAAC;IAC7D,IACE,aAAa;QACb,OAAO,CAAC,UAAU;QAClB,OAAO,CAAC,UAAU,KAAK,aAAa,EACpC,CAAC;QACD,MAAM,WAAW,EAAE,QAAQ,CAAC;YAC1B,EAAE,EAAE,OAAO,CAAC,UAAU;YACtB,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,OAAO,EAAE,OAAO,CAAC,OAAO;SACzB,CAAC,CAAC;IACL,CAAC;IAED,WAAW,EAAE,kBAAkB,CAAC,OAAO,CAAC,CAAC;IACzC,WAAW,EAAE,iBAAiB,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAE/C,IAAI,CAAC,WAAW,EAAE,QAAQ,EAAE,CAAC;QAC3B,WAAW,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC;QACtC,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YACpB,aAAa,EAAE,eAAe,CAC5B;gBACE,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,IAAI,EAAE;oBACJ,EAAE,EAAE,OAAO,CAAC,MAAM;oBAClB,QAAQ,EAAE,OAAO,CAAC,QAAQ;oBAC1B,OAAO,EAAE,OAAO,CAAC,OAAO;iBACzB;aACF,EACD,KAAK,CACN,CAAC;YAEF,MAAM,QAAQ,GACZ,WAAW,EAAE,oBAAoB,EAAE,EAAE,EAAE,sBAAsB;gBAC3D,EAAE,cAAc,CAAC;YACrB,MAAM,eAAe,GAAG,QAAQ,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;gBACxD,IAAI,MAAM,CAAC,IAAI,KAAK,OAAO;oBAAE,OAAO,KAAK,CAAC;gBAC1C,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC;oBAAE,OAAO,KAAK,CAAC;gBACnE,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC;oBAAE,OAAO,KAAK,CAAC;gBACnE,IACE,MAAM,CAAC,IAAI,EAAE,QAAQ;oBACrB,OAAO,CAAC,QAAQ;oBAChB,MAAM,CAAC,IAAI,CAAC,QAAQ,KAAK,OAAO,CAAC,QAAQ,EACzC,CAAC;oBACD,OAAO,KAAK,CAAC;gBACf,CAAC;gBACD,IACE,OAAO,MAAM,CAAC,IAAI,EAAE,OAAO,KAAK,QAAQ;oBACxC,OAAO,OAAO,CAAC,OAAO,KAAK,QAAQ;oBACnC,MAAM,CAAC,IAAI,CAAC,OAAO,KAAK,OAAO,CAAC,OAAO,EACvC,CAAC;oBACD,OAAO,KAAK,CAAC;gBACf,CAAC;gBACD,OAAO,IAAI,CAAC;YACd,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,eAAe,EAAE,CAAC;gBACrB,MAAM,MAAM,GAAG,WAAW,EAAE,YAAY,IAAI,IAAI,CAAC;gBACjD,IAAI,WAAW,EAAE,yBAAyB,CAAC,MAAM,CAAC,EAAE,CAAC;oBACnD,WAAW,CAAC,0BAA0B,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;gBACxD,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { SuggestedEdit } from "../../types";
|
|
2
|
+
type UpsertSuggestedEditOptions = {
|
|
3
|
+
/**
|
|
4
|
+
* Save acknowledgements should only replace local state if the user has not
|
|
5
|
+
* typed a newer value while the request was in flight.
|
|
6
|
+
*/
|
|
7
|
+
expectedNewValue?: string;
|
|
8
|
+
source?: "local" | "save-ack" | "socket";
|
|
9
|
+
};
|
|
10
|
+
export declare function upsertSuggestedEdit(suggestedEdits: SuggestedEdit[], incoming: SuggestedEdit, options?: UpsertSuggestedEditOptions): SuggestedEdit[];
|
|
11
|
+
export declare function replacePendingSuggestionForSameField(suggestedEdits: SuggestedEdit[], incoming: SuggestedEdit): SuggestedEdit[];
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
const locallyEditedSuggestedEdits = new Map();
|
|
2
|
+
function toTime(value) {
|
|
3
|
+
if (!value)
|
|
4
|
+
return 0;
|
|
5
|
+
const timestamp = new Date(value).getTime();
|
|
6
|
+
return Number.isFinite(timestamp) ? timestamp : 0;
|
|
7
|
+
}
|
|
8
|
+
function isIncomingOlder(current, incoming) {
|
|
9
|
+
const currentTime = toTime(current.updated);
|
|
10
|
+
const incomingTime = toTime(incoming.updated);
|
|
11
|
+
return currentTime > 0 && incomingTime > 0 && currentTime > incomingTime;
|
|
12
|
+
}
|
|
13
|
+
function rememberLocalSuggestedEdit(edit) {
|
|
14
|
+
locallyEditedSuggestedEdits.set(edit.id, {
|
|
15
|
+
author: edit.author,
|
|
16
|
+
fieldId: edit.fieldId,
|
|
17
|
+
itemId: edit.itemId,
|
|
18
|
+
mainItemLanguage: edit.mainItemLanguage,
|
|
19
|
+
mainItemVersion: edit.mainItemVersion,
|
|
20
|
+
newValue: edit.newValue,
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
function forgetLocalSuggestedEdit(edit) {
|
|
24
|
+
if (edit.status !== "pending") {
|
|
25
|
+
locallyEditedSuggestedEdits.delete(edit.id);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
function hasNewerLocalSuggestionValue(current, incoming, options) {
|
|
29
|
+
if (options.source !== "socket")
|
|
30
|
+
return false;
|
|
31
|
+
const local = locallyEditedSuggestedEdits.get(incoming.id);
|
|
32
|
+
if (!local)
|
|
33
|
+
return false;
|
|
34
|
+
if (local.newValue === incoming.newValue)
|
|
35
|
+
return false;
|
|
36
|
+
return (current.newValue === local.newValue &&
|
|
37
|
+
incoming.status === "pending" &&
|
|
38
|
+
incoming.author === local.author &&
|
|
39
|
+
incoming.fieldId === local.fieldId &&
|
|
40
|
+
incoming.itemId === local.itemId &&
|
|
41
|
+
incoming.mainItemLanguage === local.mainItemLanguage &&
|
|
42
|
+
incoming.mainItemVersion === local.mainItemVersion);
|
|
43
|
+
}
|
|
44
|
+
function shouldAcceptSuggestedEditUpdate(current, incoming, options) {
|
|
45
|
+
if (!current)
|
|
46
|
+
return true;
|
|
47
|
+
if (hasNewerLocalSuggestionValue(current, incoming, options)) {
|
|
48
|
+
return false;
|
|
49
|
+
}
|
|
50
|
+
if (options.expectedNewValue !== undefined &&
|
|
51
|
+
current.newValue !== options.expectedNewValue) {
|
|
52
|
+
return false;
|
|
53
|
+
}
|
|
54
|
+
return !isIncomingOlder(current, incoming);
|
|
55
|
+
}
|
|
56
|
+
export function upsertSuggestedEdit(suggestedEdits, incoming, options = {}) {
|
|
57
|
+
const index = suggestedEdits.findIndex((edit) => edit.id === incoming.id);
|
|
58
|
+
if (index !== -1) {
|
|
59
|
+
const acceptUpdate = shouldAcceptSuggestedEditUpdate(suggestedEdits[index], incoming, options);
|
|
60
|
+
if (!acceptUpdate) {
|
|
61
|
+
return suggestedEdits;
|
|
62
|
+
}
|
|
63
|
+
const updated = [...suggestedEdits];
|
|
64
|
+
updated[index] = incoming;
|
|
65
|
+
if (options.source === "local") {
|
|
66
|
+
rememberLocalSuggestedEdit(incoming);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
forgetLocalSuggestedEdit(incoming);
|
|
70
|
+
}
|
|
71
|
+
return updated;
|
|
72
|
+
}
|
|
73
|
+
if (options.source === "local") {
|
|
74
|
+
rememberLocalSuggestedEdit(incoming);
|
|
75
|
+
}
|
|
76
|
+
return [...suggestedEdits, incoming];
|
|
77
|
+
}
|
|
78
|
+
export function replacePendingSuggestionForSameField(suggestedEdits, incoming) {
|
|
79
|
+
return [
|
|
80
|
+
...suggestedEdits.filter((edit) => !(edit.status === "pending" &&
|
|
81
|
+
edit.mainItemId === incoming.mainItemId &&
|
|
82
|
+
edit.mainItemLanguage === incoming.mainItemLanguage &&
|
|
83
|
+
edit.mainItemVersion === incoming.mainItemVersion &&
|
|
84
|
+
edit.itemId === incoming.itemId &&
|
|
85
|
+
edit.fieldId === incoming.fieldId &&
|
|
86
|
+
edit.author === incoming.author)),
|
|
87
|
+
incoming,
|
|
88
|
+
];
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=suggestedEditState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suggestedEditState.js","sourceRoot":"","sources":["../../../src/editor/reviews/suggestedEditState.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import type { SuggestedEdit } from "../../types";
|
|
2
|
+
export type SuggestionDisplayMode = "baseline" | "suggestions";
|
|
3
|
+
export type SuggestionDisplayFormat = "plain" | "diff";
|
|
4
|
+
export type SuggestionDisplayField = {
|
|
5
|
+
fieldId: string;
|
|
6
|
+
itemId: string;
|
|
7
|
+
language: string;
|
|
8
|
+
version: number;
|
|
9
|
+
pageItemId?: string;
|
|
10
|
+
pageItemVersion?: number | null;
|
|
11
|
+
};
|
|
12
|
+
export type SuggestionDisplayModifiedField = {
|
|
13
|
+
fieldId: string;
|
|
14
|
+
item: {
|
|
15
|
+
id: string;
|
|
16
|
+
language: string;
|
|
17
|
+
version: number;
|
|
18
|
+
};
|
|
19
|
+
value: string | null;
|
|
20
|
+
};
|
|
21
|
+
export type SuggestionDisplayResult = {
|
|
22
|
+
baselineValue: string;
|
|
23
|
+
mergedValue: string;
|
|
24
|
+
displayValue: string;
|
|
25
|
+
suggestions: SuggestedEdit[];
|
|
26
|
+
hasSuggestions: boolean;
|
|
27
|
+
};
|
|
28
|
+
export declare function getPendingFieldSuggestions(suggestedEdits: SuggestedEdit[], field: SuggestionDisplayField): SuggestedEdit[];
|
|
29
|
+
export declare function getBaselineFieldValue({ repositoryValue, modifiedFields, field, }: {
|
|
30
|
+
repositoryValue: string | null | undefined;
|
|
31
|
+
modifiedFields?: SuggestionDisplayModifiedField[];
|
|
32
|
+
field: SuggestionDisplayField;
|
|
33
|
+
}): string;
|
|
34
|
+
export declare function mergePendingSuggestionValues(baselineValue: string, suggestions: SuggestedEdit[]): string;
|
|
35
|
+
export declare function getSuggestionDiffHtml(baselineValue: string, mergedValue: string): string;
|
|
36
|
+
export declare function getSuggestionDisplayValue({ repositoryValue, modifiedFields, suggestedEdits, field, mode, format, }: {
|
|
37
|
+
repositoryValue: string | null | undefined;
|
|
38
|
+
modifiedFields?: SuggestionDisplayModifiedField[];
|
|
39
|
+
suggestedEdits: SuggestedEdit[];
|
|
40
|
+
field: SuggestionDisplayField;
|
|
41
|
+
mode: SuggestionDisplayMode;
|
|
42
|
+
format?: SuggestionDisplayFormat;
|
|
43
|
+
}): SuggestionDisplayResult;
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { applyPatch, createPatch, diffWords } from "diff";
|
|
2
|
+
function toTimestamp(value) {
|
|
3
|
+
if (!value)
|
|
4
|
+
return 0;
|
|
5
|
+
const timestamp = new Date(value).getTime();
|
|
6
|
+
return Number.isFinite(timestamp) ? timestamp : 0;
|
|
7
|
+
}
|
|
8
|
+
function matchesFieldSuggestion(suggestion, field) {
|
|
9
|
+
const pageVersion = field.pageItemVersion;
|
|
10
|
+
const versionMatches = pageVersion != null
|
|
11
|
+
? suggestion.mainItemVersion === pageVersion ||
|
|
12
|
+
suggestion.mainItemVersion === 0
|
|
13
|
+
: suggestion.mainItemVersion === field.version;
|
|
14
|
+
return (suggestion.status === "pending" &&
|
|
15
|
+
suggestion.fieldId === field.fieldId &&
|
|
16
|
+
suggestion.itemId === field.itemId &&
|
|
17
|
+
suggestion.mainItemLanguage === field.language &&
|
|
18
|
+
(!field.pageItemId || suggestion.mainItemId === field.pageItemId) &&
|
|
19
|
+
versionMatches);
|
|
20
|
+
}
|
|
21
|
+
export function getPendingFieldSuggestions(suggestedEdits, field) {
|
|
22
|
+
return suggestedEdits
|
|
23
|
+
.filter((suggestion) => matchesFieldSuggestion(suggestion, field))
|
|
24
|
+
.sort((left, right) => {
|
|
25
|
+
const timeDelta = toTimestamp(left.created) - toTimestamp(right.created);
|
|
26
|
+
return timeDelta || left.id.localeCompare(right.id);
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
export function getBaselineFieldValue({ repositoryValue, modifiedFields, field, }) {
|
|
30
|
+
const modifiedField = modifiedFields?.find((candidate) => candidate.fieldId === field.fieldId &&
|
|
31
|
+
candidate.item.id === field.itemId &&
|
|
32
|
+
candidate.item.language === field.language &&
|
|
33
|
+
candidate.item.version === field.version);
|
|
34
|
+
return modifiedField ? (modifiedField.value ?? "") : (repositoryValue ?? "");
|
|
35
|
+
}
|
|
36
|
+
export function mergePendingSuggestionValues(baselineValue, suggestions) {
|
|
37
|
+
let mergedValue = baselineValue;
|
|
38
|
+
for (const suggestion of suggestions) {
|
|
39
|
+
const patch = createPatch("field", suggestion.oldValue, suggestion.newValue);
|
|
40
|
+
const patchedCandidate = applyPatch(mergedValue, patch);
|
|
41
|
+
mergedValue =
|
|
42
|
+
patchedCandidate !== false && typeof patchedCandidate === "string"
|
|
43
|
+
? patchedCandidate
|
|
44
|
+
: suggestion.newValue;
|
|
45
|
+
}
|
|
46
|
+
return mergedValue;
|
|
47
|
+
}
|
|
48
|
+
function escapeHtml(value) {
|
|
49
|
+
return value
|
|
50
|
+
.replaceAll("&", "&")
|
|
51
|
+
.replaceAll("<", "<")
|
|
52
|
+
.replaceAll(">", ">")
|
|
53
|
+
.replaceAll('"', """)
|
|
54
|
+
.replaceAll("'", "'");
|
|
55
|
+
}
|
|
56
|
+
export function getSuggestionDiffHtml(baselineValue, mergedValue) {
|
|
57
|
+
return diffWords(baselineValue, mergedValue)
|
|
58
|
+
.map((part) => {
|
|
59
|
+
let style = "color: gray;";
|
|
60
|
+
if (part.added) {
|
|
61
|
+
style = "color: green;";
|
|
62
|
+
}
|
|
63
|
+
else if (part.removed) {
|
|
64
|
+
style = "color: red; text-decoration: line-through;";
|
|
65
|
+
}
|
|
66
|
+
return `<span style="${style}">${escapeHtml(part.value)}</span>`;
|
|
67
|
+
})
|
|
68
|
+
.join("");
|
|
69
|
+
}
|
|
70
|
+
export function getSuggestionDisplayValue({ repositoryValue, modifiedFields, suggestedEdits, field, mode, format = "plain", }) {
|
|
71
|
+
const baselineValue = getBaselineFieldValue({
|
|
72
|
+
repositoryValue,
|
|
73
|
+
modifiedFields,
|
|
74
|
+
field,
|
|
75
|
+
});
|
|
76
|
+
const suggestions = mode === "suggestions"
|
|
77
|
+
? getPendingFieldSuggestions(suggestedEdits, field)
|
|
78
|
+
: [];
|
|
79
|
+
const mergedValue = suggestions.length
|
|
80
|
+
? mergePendingSuggestionValues(baselineValue, suggestions)
|
|
81
|
+
: baselineValue;
|
|
82
|
+
const displayValue = mode === "suggestions" && suggestions.length && format === "diff"
|
|
83
|
+
? getSuggestionDiffHtml(baselineValue, mergedValue)
|
|
84
|
+
: mergedValue;
|
|
85
|
+
return {
|
|
86
|
+
baselineValue,
|
|
87
|
+
mergedValue,
|
|
88
|
+
displayValue,
|
|
89
|
+
suggestions,
|
|
90
|
+
hasSuggestions: suggestions.length > 0,
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
//# sourceMappingURL=suggestionDisplayValue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suggestionDisplayValue.js","sourceRoot":"","sources":["../../../src/editor/reviews/suggestionDisplayValue.ts"],"names":[],"mappings":"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"}
|
|
@@ -13,6 +13,7 @@ export interface StartAgentRequest {
|
|
|
13
13
|
seed?: number;
|
|
14
14
|
context?: any;
|
|
15
15
|
clientMessageId?: string;
|
|
16
|
+
attachments?: AgentMessageAttachment[];
|
|
16
17
|
}
|
|
17
18
|
export interface StartAgentResponse {
|
|
18
19
|
agentId: string;
|
|
@@ -294,8 +295,21 @@ export interface AgentChatMessage {
|
|
|
294
295
|
editOperations?: string;
|
|
295
296
|
longRunningTaskIds?: string;
|
|
296
297
|
metadata?: string;
|
|
298
|
+
attachments?: AgentMessageAttachment[];
|
|
297
299
|
toolCalls?: AgentChatToolCall[];
|
|
298
300
|
}
|
|
301
|
+
export interface AgentMessageAttachment {
|
|
302
|
+
id?: string;
|
|
303
|
+
agentId?: string;
|
|
304
|
+
attachmentId?: string;
|
|
305
|
+
fileName: string;
|
|
306
|
+
fileSize?: number;
|
|
307
|
+
contentType?: string;
|
|
308
|
+
fileType?: string;
|
|
309
|
+
uploadedBy?: string;
|
|
310
|
+
uploadedDate?: string;
|
|
311
|
+
url?: string;
|
|
312
|
+
}
|
|
299
313
|
export interface AgentChatToolCall {
|
|
300
314
|
id: string;
|
|
301
315
|
messageId: string;
|
|
@@ -332,6 +346,7 @@ export declare function deleteQueuedPrompt(params: {
|
|
|
332
346
|
}): Promise<{
|
|
333
347
|
success: boolean;
|
|
334
348
|
message?: string;
|
|
349
|
+
alreadyGone?: boolean;
|
|
335
350
|
}>;
|
|
336
351
|
export interface StartSuggestionAgentRequest {
|
|
337
352
|
agentId: string;
|
|
@@ -119,6 +119,13 @@ export async function pushQueuedPrompt(request) {
|
|
|
119
119
|
export async function deleteQueuedPrompt(params) {
|
|
120
120
|
const result = await post(AGENT_BASE_URL + "/deleteQueuedPrompt", params);
|
|
121
121
|
if (result.type !== "success") {
|
|
122
|
+
// A 404 means the prompt is no longer in the backend queue (already
|
|
123
|
+
// processed or removed) — e.g. a missed "agent:prompt:processed" event
|
|
124
|
+
// left a stale row. Deleting it is then an idempotent no-op success, so
|
|
125
|
+
// the UI can drop the ghost row instead of erroring and re-showing it.
|
|
126
|
+
if (result.response?.status === 404) {
|
|
127
|
+
return { success: true, alreadyGone: true };
|
|
128
|
+
}
|
|
122
129
|
throw new Error(`Failed to delete queued prompt: ${result.summary || "Unknown error"} ${result.details || ""}`);
|
|
123
130
|
}
|
|
124
131
|
return result.data ?? { success: true };
|
|
@@ -328,7 +335,10 @@ function cloneGetAgentsGroupedResponse(response) {
|
|
|
328
335
|
activeAgents: response.activeAgents.map(cloneAgent),
|
|
329
336
|
closedAgentsByProfile: response.closedAgentsByProfile.map((group) => ({
|
|
330
337
|
...group,
|
|
331
|
-
agents: group.agents.map(
|
|
338
|
+
agents: group.agents.map((agent) => ({
|
|
339
|
+
...cloneAgent(agent),
|
|
340
|
+
profileSvgIcon: agent.profileSvgIcon ?? group.profileSvgIcon,
|
|
341
|
+
})),
|
|
332
342
|
})),
|
|
333
343
|
};
|
|
334
344
|
}
|