windmill-components 1.542.5 → 1.555.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package/aiStore.d.ts +13 -0
- package/package/aiStore.js +70 -0
- package/package/common.d.ts +6 -2
- package/package/components/AIAgentLogViewer.svelte +1 -1
- package/package/components/AIProviderPicker.svelte +25 -8
- package/package/components/ArgEnum.svelte +17 -7
- package/package/components/ArgEnum.svelte.d.ts +1 -0
- package/package/components/ArgInput.svelte +257 -188
- package/package/components/ArgInput.svelte.d.ts +4 -1
- package/package/components/ArrayTypeNarrowing.svelte +38 -32
- package/package/components/AutoscalingEvents.svelte +21 -5
- package/package/components/AutoscalingEvents.svelte.d.ts +4 -18
- package/package/components/ChannelSelector.svelte +92 -18
- package/package/components/ChannelSelector.svelte.d.ts +2 -0
- package/package/components/ConnectionSection.svelte +12 -1
- package/package/components/DateTimeInput.svelte +8 -6
- package/package/components/DeployButton.svelte +1 -1
- package/package/components/Dev.svelte +24 -9
- package/package/components/Dev.svelte.d.ts +23 -1
- package/package/components/DisplayResult.svelte +36 -23
- package/package/components/DropdownV2.svelte +8 -2
- package/package/components/DropdownV2.svelte.d.ts +1 -0
- package/package/components/DynamicInput.svelte +10 -10
- package/package/components/EditableSchemaForm.svelte +28 -13
- package/package/components/Editor.svelte +2 -1
- package/package/components/EditorSettings.svelte +5 -5
- package/package/components/EditorSettings.svelte.d.ts +4 -18
- package/package/components/ErrorOrRecoveryHandler.svelte +14 -20
- package/package/components/FakeMonacoPlaceHolder.svelte +4 -2
- package/package/components/FakeMonacoPlaceHolder.svelte.d.ts +1 -0
- package/package/components/FieldHeader.svelte +5 -7
- package/package/components/FirstStepInputs.svelte +1 -1
- package/package/components/FlowHistoryJobPicker.svelte +3 -0
- package/package/components/FlowHistoryJobPicker.svelte.d.ts +1 -0
- package/package/components/FlowJobResult.svelte +5 -5
- package/package/components/FlowLogRow.svelte +2 -2
- package/package/components/FlowLogViewer.svelte +228 -57
- package/package/components/FlowLogViewer.svelte.d.ts +16 -5
- package/package/components/FlowLogViewerWrapper.svelte +56 -3
- package/package/components/FlowLogViewerWrapper.svelte.d.ts +4 -3
- package/package/components/FlowLoopIterationPreview.svelte +4 -4
- package/package/components/FlowLoopIterationPreview.svelte.d.ts +1 -1
- package/package/components/FlowMetadata.svelte +3 -4
- package/package/components/FlowMetadata.svelte.d.ts +4 -18
- package/package/components/FlowPlugConnect.svelte +8 -2
- package/package/components/FlowPlugConnect.svelte.d.ts +1 -0
- package/package/components/FlowPreviewContent.svelte +121 -94
- package/package/components/FlowPreviewContent.svelte.d.ts +3 -3
- package/package/components/FlowStatusViewer.svelte +63 -59
- package/package/components/FlowStatusViewer.svelte.d.ts +2 -2
- package/package/components/FlowStatusViewerInner.svelte +186 -94
- package/package/components/FlowStatusViewerInner.svelte.d.ts +10 -3
- package/package/components/FlowTimeline.svelte +110 -131
- package/package/components/FlowTimeline.svelte.d.ts +13 -4
- package/package/components/FlowTimelineBar.svelte +227 -0
- package/package/components/FlowTimelineBar.svelte.d.ts +24 -0
- package/package/components/FolderEditor.svelte +6 -7
- package/package/components/GroupEditor.svelte +148 -141
- package/package/components/GroupEditor.svelte.d.ts +5 -4
- package/package/components/InputTransformForm.svelte +193 -71
- package/package/components/InputTransformForm.svelte.d.ts +3 -0
- package/package/components/InputTransformSchemaForm.svelte +10 -5
- package/package/components/InputTransformSchemaForm.svelte.d.ts +2 -0
- package/package/components/InstanceSetting.svelte +34 -51
- package/package/components/InstanceSettings.svelte +12 -21
- package/package/components/JobArgs.svelte +15 -16
- package/package/components/JobArgs.svelte.d.ts +4 -18
- package/package/components/JobLoader.svelte +23 -42
- package/package/components/JobLoader.svelte.d.ts +2 -0
- package/package/components/JobStatus.svelte +1 -1
- package/package/components/JobStatus.svelte.d.ts +4 -18
- package/package/components/JsonEditor.svelte +18 -9
- package/package/components/JsonEditor.svelte.d.ts +1 -1
- package/package/components/JsonInputs.svelte +1 -1
- package/package/components/ModulePreviewForm.svelte +23 -19
- package/package/components/ModulePreviewResultViewer.svelte +1 -7
- package/package/components/NextcloudSetting.svelte +6 -1
- package/package/components/NumberTypeNarrowing.svelte +32 -16
- package/package/components/ObjectStoreConfigSettings.svelte +27 -19
- package/package/components/Password.svelte +7 -11
- package/package/components/Password.svelte.d.ts +5 -20
- package/package/components/PasswordArgInput.svelte +35 -15
- package/package/components/PasswordArgInput.svelte.d.ts +4 -18
- package/package/components/Path.svelte +2 -8
- package/package/components/Path.svelte.d.ts +1 -1
- package/package/components/QueuePosition.svelte +6 -2
- package/package/components/ResourceEditor.svelte +3 -10
- package/package/components/ResourcePicker.svelte +85 -72
- package/package/components/ResourcePicker.svelte.d.ts +2 -0
- package/package/components/RunChart.svelte +1 -1
- package/package/components/RunForm.svelte +16 -21
- package/package/components/S3ArrayHelperButton.svelte +18 -0
- package/package/components/S3ArrayHelperButton.svelte.d.ts +9 -0
- package/package/components/S3FilePicker.svelte +1 -1
- package/package/components/SchemaForm.svelte +18 -10
- package/package/components/SchemaForm.svelte.d.ts +7 -1
- package/package/components/SchemaFormWithArgPicker.svelte +1 -1
- package/package/components/ScriptBuilder.svelte +2 -2
- package/package/components/ScriptEditor.svelte +9 -9
- package/package/components/ScriptEditor.svelte.d.ts +1 -1
- package/package/components/ShareModal.svelte +4 -4
- package/package/components/SimpleEditor.svelte +6 -2
- package/package/components/SimpleEditor.svelte.d.ts +3 -0
- package/package/components/StringTypeNarrowing.svelte +44 -25
- package/package/components/StringTypeNarrowing.svelte.d.ts +1 -1
- package/package/components/SuperadminSettingsInner.svelte +3 -3
- package/package/components/TeamSelector.svelte +83 -37
- package/package/components/TeamSelector.svelte.d.ts +0 -1
- package/package/components/TemplateEditor.svelte +18 -9
- package/package/components/Toast.svelte +2 -7
- package/package/components/Toast.svelte.d.ts +4 -18
- package/package/components/Toggle.svelte +17 -7
- package/package/components/ToggleHubWorkspaceQuick.svelte +3 -3
- package/package/components/WorkerGroup.svelte +2 -14
- package/package/components/apps/components/buttons/AppButton.svelte +66 -38
- package/package/components/apps/components/display/dbtable/InsertRow.svelte +32 -2
- package/package/components/apps/components/display/dbtable/queries/insert.js +2 -1
- package/package/components/apps/components/display/dbtable/utils.d.ts +8 -8
- package/package/components/apps/components/display/table/AppAggridInfiniteTable.svelte +13 -4
- package/package/components/apps/components/display/table/SyncColumnDefs.svelte +2 -2
- package/package/components/apps/components/display/table/utils.js +14 -4
- package/package/components/apps/components/helpers/RefreshButton.svelte +5 -1
- package/package/components/apps/components/helpers/RunnableComponent.svelte +3 -5
- package/package/components/apps/components/helpers/RunnableWrapper.svelte.d.ts +1 -0
- package/package/components/apps/components/inputs/currency/CurrencyInput.svelte +2 -1
- package/package/components/apps/components/layout/AppTabs.svelte +116 -71
- package/package/components/apps/components/layout/AppTabs.svelte.d.ts +1 -0
- package/package/components/apps/editor/AppEditorHeader.svelte +33 -271
- package/package/components/apps/editor/AppEditorHeaderDeploy.svelte +233 -0
- package/package/components/apps/editor/AppEditorHeaderDeploy.svelte.d.ts +18 -0
- package/package/components/apps/editor/AppEditorHeaderDeployInitialDraft.svelte +47 -0
- package/package/components/apps/editor/AppEditorHeaderDeployInitialDraft.svelte.d.ts +8 -0
- package/package/components/apps/editor/GridEditor.svelte +7 -2
- package/package/components/apps/editor/appDeploy.svelte.d.ts +1 -0
- package/package/components/apps/editor/appDeploy.svelte.js +6 -0
- package/package/components/apps/editor/appUtils.d.ts +1 -0
- package/package/components/apps/editor/appUtils.js +30 -1
- package/package/components/apps/editor/component/ComponentInner.svelte +1 -0
- package/package/components/apps/editor/component/ComponentNavigation.svelte +3 -1
- package/package/components/apps/editor/component/components.d.ts +19 -4
- package/package/components/apps/editor/component/components.js +23 -3
- package/package/components/apps/editor/contextPanel/ComponentOutputViewer.svelte +1 -1
- package/package/components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte +6 -4
- package/package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte.d.ts +1 -1
- package/package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorDrawer.svelte.d.ts +1 -1
- package/package/components/apps/editor/inlineScriptsPanel/InlineScriptRunnableByPath.svelte.d.ts +1 -1
- package/package/components/apps/editor/settingsPanel/ComponentPanel.svelte +2 -0
- package/package/components/apps/editor/settingsPanel/GridTab.svelte +19 -1
- package/package/components/apps/editor/settingsPanel/GridTab.svelte.d.ts +3 -1
- package/package/components/apps/editor/settingsPanel/GridTabHidden.svelte +52 -0
- package/package/components/apps/editor/settingsPanel/GridTabHidden.svelte.d.ts +9 -0
- package/package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte +58 -8
- package/package/components/auditLogs/AuditLogsFilters.svelte +7 -1
- package/package/components/auditLogs/AuditLogsTable.svelte +17 -7
- package/package/components/auditLogs/AuditLogsTable.svelte.d.ts +1 -0
- package/package/components/common/CloseButton.svelte +2 -2
- package/package/components/common/CloseButton.svelte.d.ts +1 -0
- package/package/components/common/ResizeTransitionWrapper.svelte +39 -0
- package/package/components/common/ResizeTransitionWrapper.svelte.d.ts +12 -0
- package/package/components/common/badge/CountBadge.svelte +29 -0
- package/package/components/common/badge/CountBadge.svelte.d.ts +8 -0
- package/package/components/common/button/Button.svelte +1 -0
- package/package/components/common/button/ConnectionButton.svelte +6 -1
- package/package/components/common/button/ConnectionButton.svelte.d.ts +2 -0
- package/package/components/common/button/RefreshButton.svelte +8 -4
- package/package/components/common/button/RefreshButton.svelte.d.ts +3 -0
- package/package/components/common/calendarPicker/CalendarPicker.svelte +1 -1
- package/package/components/common/fileInput/FileInput.svelte +7 -6
- package/package/components/common/fileUpload/S3ArgInput.svelte +11 -9
- package/package/components/common/fileUpload/S3ArgInput.svelte.d.ts +1 -0
- package/package/components/common/layout/List.svelte +3 -7
- package/package/components/common/layout/List.svelte.d.ts +7 -29
- package/package/components/common/popup/PopupV2.svelte +14 -25
- package/package/components/common/popup/PopupV2.svelte.d.ts +4 -2
- package/package/components/common/table/ScriptRow.svelte +22 -2
- package/package/components/common/toggleButton-v2/ToggleButton.svelte +17 -26
- package/package/components/common/toggleButton-v2/ToggleButton.svelte.d.ts +16 -30
- package/package/components/common/toggleButton-v2/ToggleButtonGroup.svelte +1 -1
- package/package/components/common/toggleButton-v2/ToggleButtonMore.svelte +3 -3
- package/package/components/common/toggleButton-v2/ToggleButtonMore.svelte.d.ts +1 -0
- package/package/components/copilot/CodeCompletionStatus.svelte +2 -1
- package/package/components/copilot/CronGen.svelte +1 -1
- package/package/components/copilot/FlowCopilotInputsModal.svelte +26 -23
- package/package/components/copilot/FlowInlineScriptAIButton.svelte +2 -2
- package/package/components/copilot/IteratorGen.svelte +30 -25
- package/package/components/copilot/IteratorGen.svelte.d.ts +8 -7
- package/package/components/copilot/MetadataGen.svelte +4 -3
- package/package/components/copilot/PredicateGen.svelte +15 -12
- package/package/components/copilot/PredicateGen.svelte.d.ts +5 -4
- package/package/components/copilot/RegexGen.svelte +1 -1
- package/package/components/copilot/ScriptFix.svelte +1 -1
- package/package/components/copilot/ScriptGen.svelte +2 -1
- package/package/components/copilot/StepGenQuick.svelte +15 -16
- package/package/components/copilot/StepGenQuick.svelte.d.ts +14 -13
- package/package/components/copilot/StepInputGen.svelte +50 -36
- package/package/components/copilot/StepInputGen.svelte.d.ts +13 -10
- package/package/components/copilot/StepInputsGen.svelte +18 -19
- package/package/components/copilot/StepInputsGen.svelte.d.ts +4 -18
- package/package/components/copilot/autocomplete/Autocompletor.js +1 -1
- package/package/components/copilot/autocomplete/request.js +1 -1
- package/package/components/copilot/chat/AIChat.svelte +2 -1
- package/package/components/copilot/chat/AIChatManager.svelte.js +5 -3
- package/package/components/copilot/chat/AiChatLayout.svelte +2 -1
- package/package/components/copilot/chat/ProviderModelSelector.svelte +11 -10
- package/package/components/copilot/chat/ProviderModelSelector.svelte.d.ts +2 -17
- package/package/components/copilot/chat/flow/FlowAIButton.svelte +1 -1
- package/package/components/copilot/chat/flow/FlowAIChat.svelte +4 -2
- package/package/components/copilot/chat/script/core.d.ts +4 -4
- package/package/components/copilot/chat/script/core.js +95 -35
- package/package/components/copilot/chat/shared.js +2 -1
- package/package/components/copilot/lib.d.ts +1 -0
- package/package/components/copilot/lib.js +7 -3
- package/package/components/custom_ui.d.ts +1 -0
- package/package/components/details/DetailPageLayout.svelte +3 -2
- package/package/components/details/DetailPageLayout.svelte.d.ts +1 -0
- package/package/components/flows/CreateActionsFlow.svelte +1 -1
- package/package/components/flows/FlowChatInterface.svelte +404 -0
- package/package/components/flows/FlowChatInterface.svelte.d.ts +19 -0
- package/package/components/flows/FlowChatMessage.svelte +41 -0
- package/package/components/flows/FlowChatMessage.svelte.d.ts +9 -0
- package/package/components/flows/FlowConversationsSidebar.svelte +213 -0
- package/package/components/flows/FlowConversationsSidebar.svelte.d.ts +15 -0
- package/package/components/flows/FlowEditor.svelte.d.ts +1 -1
- package/package/components/flows/FlowModuleIcon.svelte +10 -10
- package/package/components/flows/FlowProgressBar.svelte +16 -16
- package/package/components/flows/FlowProgressBar.svelte.d.ts +7 -22
- package/package/components/flows/common/FlowCard.svelte +10 -2
- package/package/components/flows/common/FlowCard.svelte.d.ts +1 -0
- package/package/components/flows/common/FlowCardHeader.svelte +2 -1
- package/package/components/flows/common/FlowCardHeader.svelte.d.ts +1 -0
- package/package/components/flows/content/DynamicInputHelpBox.svelte +4 -4
- package/package/components/flows/content/FlowEditorPanel.svelte.d.ts +1 -1
- package/package/components/flows/content/FlowInput.svelte +381 -259
- package/package/components/flows/content/FlowInput.svelte.d.ts +1 -1
- package/package/components/flows/content/FlowInputsQuick.svelte +56 -34
- package/package/components/flows/content/FlowInputsQuick.svelte.d.ts +3 -2
- package/package/components/flows/content/FlowModuleComponent.svelte +29 -11
- package/package/components/flows/flowInfers.d.ts +60 -0
- package/package/components/flows/flowInfers.js +72 -40
- package/package/components/flows/{flowStore.d.ts → flowStore.svelte.d.ts} +5 -1
- package/package/components/flows/header/FlowPreviewButtons.svelte +1 -1
- package/package/components/flows/map/FlowErrorHandlerItem.svelte +4 -2
- package/package/components/flows/map/FlowErrorHandlerItem.svelte.d.ts +1 -0
- package/package/components/flows/map/FlowJobsMenu.svelte +3 -3
- package/package/components/flows/map/FlowJobsMenu.svelte.d.ts +1 -1
- package/package/components/flows/map/FlowModuleSchemaItem.svelte +1 -1
- package/package/components/flows/map/FlowModuleSchemaMap.svelte +5 -2
- package/package/components/flows/map/FlowStickyNode.svelte +2 -2
- package/package/components/flows/map/FlowStickyNode.svelte.d.ts +1 -0
- package/package/components/flows/map/InsertModuleButton.svelte +8 -15
- package/package/components/flows/map/InsertModuleButton.svelte.d.ts +4 -4
- package/package/components/flows/map/InsertModuleInner.svelte +19 -20
- package/package/components/flows/map/InsertModuleInner.svelte.d.ts +2 -2
- package/package/components/flows/map/MapItem.svelte +1 -1
- package/package/components/flows/map/VirtualItem.svelte +1 -2
- package/package/components/flows/pickers/PickHubScriptQuick.svelte +43 -52
- package/package/components/flows/pickers/PickHubScriptQuick.svelte.d.ts +2 -1
- package/package/components/flows/pickers/WorkspaceScriptPickerQuick.svelte +41 -26
- package/package/components/flows/pickers/WorkspaceScriptPickerQuick.svelte.d.ts +1 -0
- package/package/components/flows/propPicker/OutputPicker.svelte +2 -0
- package/package/components/flows/propPicker/PropPickerWrapper.svelte +1 -15
- package/package/components/git_sync/DetectionFlow.svelte +33 -44
- package/package/components/git_sync/DetectionFlow.svelte.d.ts +1 -0
- package/package/components/git_sync/GitSyncContext.svelte.d.ts +22 -0
- package/package/components/git_sync/GitSyncContext.svelte.js +145 -5
- package/package/components/git_sync/GitSyncModeDisplay.svelte +14 -0
- package/package/components/git_sync/GitSyncModeDisplay.svelte.d.ts +9 -0
- package/package/components/git_sync/GitSyncRepositoryCard.svelte +365 -253
- package/package/components/git_sync/GitSyncRepositoryCard.svelte.d.ts +10 -1
- package/package/components/git_sync/GitSyncSection.svelte +134 -14
- package/package/components/git_sync/PullWorkspaceModal.svelte +24 -32
- package/package/components/git_sync/PushWorkspaceModal.svelte +24 -32
- package/package/components/graph/FlowGraphV2.svelte +2 -1
- package/package/components/graph/FlowGraphV2.svelte.d.ts +1 -0
- package/package/components/graph/graphBuilder.svelte.d.ts +2 -0
- package/package/components/graph/graphBuilder.svelte.js +1 -0
- package/package/components/graph/model.d.ts +5 -5
- package/package/components/graph/renderers/edges/BaseEdge.svelte +1 -0
- package/package/components/graph/renderers/edges/EmptyEdge.svelte +3 -10
- package/package/components/graph/renderers/edges/EmptyEdge.svelte.d.ts +4 -18
- package/package/components/graph/renderers/nodes/AIToolNode.svelte +2 -2
- package/package/components/graph/renderers/nodes/InputNode.svelte +13 -2
- package/package/components/graph/renderers/nodes/NewAIToolNode.svelte +5 -10
- package/package/components/graph/renderers/triggers/TriggersBadge.svelte +2 -27
- package/package/components/home/ItemsList.svelte +1 -1
- package/package/components/instanceSettings.js +17 -0
- package/package/components/jobs/JobProgressBar.svelte +27 -21
- package/package/components/jobs/JobProgressBar.svelte.d.ts +9 -24
- package/package/components/meltComponents/MenuSingleItem.svelte +3 -8
- package/package/components/meltComponents/MenuSingleItem.svelte.d.ts +0 -3
- package/package/components/meltComponents/Popover.svelte +3 -2
- package/package/components/meltComponents/Popover.svelte.d.ts +1 -0
- package/package/components/meltComponents/Tooltip.svelte +1 -1
- package/package/components/progressBar/ProgressBar.svelte +39 -53
- package/package/components/progressBar/ProgressBar.svelte.d.ts +11 -26
- package/package/components/raw_apps/FileEditorIcon.svelte +1 -1
- package/package/components/raw_apps/FileEditorIcon.svelte.d.ts +4 -18
- package/package/components/raw_apps/RawAppBackgroundRunner.svelte +2 -8
- package/package/components/raw_apps/RawAppBackgroundRunner.svelte.d.ts +4 -18
- package/package/components/raw_apps/RawAppEditor.svelte +6 -7
- package/package/components/raw_apps/RawAppEditorHeader.svelte +48 -301
- package/package/components/raw_apps/RawAppEditorHeader.svelte.d.ts +18 -19
- package/package/components/raw_apps/RawAppInlineScriptEditor.svelte +10 -16
- package/package/components/raw_apps/RawAppInlineScriptEditor.svelte.d.ts +13 -13
- package/package/components/raw_apps/RawAppInlineScriptPanelList.svelte +8 -11
- package/package/components/raw_apps/RawAppInlineScriptPanelList.svelte.d.ts +1 -2
- package/package/components/raw_apps/RawAppInlineScriptRunnable.svelte +0 -1
- package/package/components/raw_apps/RawAppInlineScriptsPanel.svelte +7 -13
- package/package/components/raw_apps/RawAppInlineScriptsPanel.svelte.d.ts +8 -8
- package/package/components/raw_apps/RawAppPreview.svelte +3 -7
- package/package/components/raw_apps/RawAppPreview.svelte.d.ts +5 -19
- package/package/components/raw_apps/utils.d.ts +1 -1
- package/package/components/raw_apps/utils.js +3 -3
- package/package/components/runs/JobsLoader.svelte +1 -1
- package/package/components/runs/NoWorkerWithTagWarning.svelte +3 -3
- package/package/components/runs/NoWorkerWithTagWarning.svelte.d.ts +1 -1
- package/package/components/runs/RunOption.svelte +2 -2
- package/package/components/runs/RunsFilter.svelte +15 -12
- package/package/components/runs/RunsFilter.svelte.d.ts +1 -1
- package/package/components/schema/AddPropertyV2.svelte +7 -4
- package/package/components/schema/EditableSchemaDrawer.svelte +19 -18
- package/package/components/schema/FlowPropertyEditor.svelte +9 -2
- package/package/components/schema/FlowPropertyEditor.svelte.d.ts +1 -1
- package/package/components/schema/PropertyEditor.svelte +22 -26
- package/package/components/schema/PropertyEditor.svelte.d.ts +1 -1
- package/package/components/schema/SchemaFormDND.svelte +3 -2
- package/package/components/schema/SchemaFormDND.svelte.d.ts +1 -0
- package/package/components/select/DraggableTags.svelte +2 -2
- package/package/components/select/MultiSelect.svelte +15 -9
- package/package/components/select/MultiSelect.svelte.d.ts +1 -0
- package/package/components/select/Select.svelte +12 -5
- package/package/components/select/Select.svelte.d.ts +11 -0
- package/package/components/select/SelectDropdown.svelte +98 -46
- package/package/components/select/SelectDropdown.svelte.d.ts +10 -0
- package/package/components/select/utils.svelte.js +2 -0
- package/package/components/settings/CreateToken.svelte +76 -49
- package/package/components/settings/WorkspaceUserSettings.svelte +111 -17
- package/package/components/sidebar/CriticalAlertTable.svelte +2 -1
- package/package/components/sidebar/Linkify.svelte +14 -0
- package/package/components/sidebar/Linkify.svelte.d.ts +5 -0
- package/package/components/sidebar/MenuLink.svelte +2 -1
- package/package/components/sidebar/MenuLink.svelte.d.ts +1 -0
- package/package/components/sidebar/SidebarContent.svelte +27 -27
- package/package/components/sidebar/WorkspaceMenu.svelte +8 -3
- package/package/components/table/Cell.svelte +7 -14
- package/package/components/table/Cell.svelte.d.ts +13 -35
- package/package/components/table/tableUtils.js +1 -1
- package/package/components/text_input/TextInput.svelte +30 -0
- package/package/components/text_input/TextInput.svelte.d.ts +17 -0
- package/package/components/triggers/AddTriggersButton.svelte +1 -0
- package/package/components/triggers/TriggersEditor.svelte +11 -1
- package/package/components/triggers/gcp/GcpTriggerEditorConfigSection.svelte +1 -1
- package/package/components/triggers/gcp/GcpTriggerEditorConfigSection.svelte.d.ts +2 -1
- package/package/components/triggers/gcp/GcpTriggerEditorInner.svelte +28 -5
- package/package/components/triggers/gcp/utils.js +1 -0
- package/package/components/triggers/schedules/ScheduleEditorInner.svelte +1 -0
- package/package/components/triggers/triggers.svelte.d.ts +1 -1
- package/package/components/triggers/triggers.svelte.js +8 -4
- package/package/components/triggers/webhook/WebhooksConfigSection.svelte +143 -63
- package/package/components/triggers/websocket/WebsocketTriggerEditorInner.svelte +22 -0
- package/package/components/triggers/websocket/utils.js +1 -0
- package/package/components/tutorials/FlowBuilderTutorialErrorHandler.svelte +2 -2
- package/package/components/tutorials/FlowBuilderTutorialForLoop.svelte +3 -0
- package/package/components/tutorials/FlowBuilderTutorialSimpleFlow.svelte +49 -17
- package/package/components/tutorials/Tutorial.svelte +9 -0
- package/package/components/tutorials/Tutorial.svelte.d.ts +1 -0
- package/package/components/tutorials/app/AppTutorial.svelte +41 -57
- package/package/components/tutorials/app/BackgroundRunnablesTutorial.svelte +3 -5
- package/package/components/tutorials/app/ConnectionTutorial.svelte +2 -2
- package/package/components/tutorials/utils.js +2 -154
- package/package/components/vscode.js +16 -8
- package/package/components/workspaceSettings/AISettings.svelte +12 -5
- package/package/components/workspaceSettings/AISettings.svelte.d.ts +2 -1
- package/package/components/workspaceSettings/CreateWorkspace.svelte +2 -2
- package/package/components/workspaceSettings/DucklakeSettings.svelte +64 -7
- package/package/components/workspaceSettings/ModelTokenLimits.svelte +165 -0
- package/package/components/workspaceSettings/ModelTokenLimits.svelte.d.ts +8 -0
- package/package/components/workspaceSettings/StorageSettings.svelte +147 -77
- package/package/editorUtils.d.ts +1 -1
- package/package/gen/core/OpenAPI.js +1 -1
- package/package/gen/schemas.gen.d.ts +223 -17
- package/package/gen/schemas.gen.js +226 -17
- package/package/gen/services.gen.d.ts +221 -27
- package/package/gen/services.gen.js +440 -48
- package/package/gen/types.gen.d.ts +1067 -218
- package/package/hubPaths.json +2 -1
- package/package/script_helpers.js +5 -5
- package/package/services/JobManager.js +14 -9
- package/package/stores.d.ts +4 -12
- package/package/stores.js +5 -65
- package/package/timelineCompute.svelte.d.ts +21 -0
- package/package/timelineCompute.svelte.js +113 -0
- package/package/toast.js +2 -1
- package/package/utils.d.ts +16 -8
- package/package/utils.js +65 -12
- package/package/workspace_settings.d.ts +13 -8
- package/package/workspace_settings.js +46 -11
- package/package.json +4 -4
- /package/package/components/flows/{flowStore.js → flowStore.svelte.js} +0 -0
|
@@ -8,9 +8,8 @@ import { workspaceStore } from '../stores';
|
|
|
8
8
|
import Tooltip from './Tooltip.svelte';
|
|
9
9
|
import { Clock, MemoryStick, Calendar, Bot, User, Code2 } from 'lucide-svelte';
|
|
10
10
|
import BarsStaggered from './icons/BarsStaggered.svelte';
|
|
11
|
-
export let job;
|
|
12
11
|
const SMALL_ICON_SIZE = 14;
|
|
13
|
-
|
|
12
|
+
let { job, scheduleEditor } = $props();
|
|
14
13
|
</script>
|
|
15
14
|
|
|
16
15
|
<div
|
|
@@ -72,11 +71,11 @@ export let scheduleEditor;
|
|
|
72
71
|
<Calendar size={SMALL_ICON_SIZE} class="text-secondary min-w-3.5" />
|
|
73
72
|
<span class="whitespace-nowrap">
|
|
74
73
|
Schedule:
|
|
75
|
-
<!-- svelte-ignore
|
|
74
|
+
<!-- svelte-ignore a11y_invalid_attribute -->
|
|
76
75
|
<a
|
|
77
76
|
href="#"
|
|
78
77
|
class="break-words text-blue-600 font-normal"
|
|
79
|
-
|
|
78
|
+
onclick={() =>
|
|
80
79
|
scheduleEditor?.openEdit(job.schedule_path ?? '', job.job_kind == 'flow')}
|
|
81
80
|
>
|
|
82
81
|
{truncateRev(job.schedule_path, 40)}
|
|
@@ -1,23 +1,9 @@
|
|
|
1
1
|
import { type Job } from '../gen';
|
|
2
2
|
import ScheduleEditor from './triggers/schedules/ScheduleEditor.svelte';
|
|
3
|
-
interface
|
|
4
|
-
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
5
|
-
$$bindings?: Bindings;
|
|
6
|
-
} & Exports;
|
|
7
|
-
(internal: unknown, props: Props & {
|
|
8
|
-
$$events?: Events;
|
|
9
|
-
$$slots?: Slots;
|
|
10
|
-
}): Exports & {
|
|
11
|
-
$set?: any;
|
|
12
|
-
$on?: any;
|
|
13
|
-
};
|
|
14
|
-
z_$$bindings?: Bindings;
|
|
15
|
-
}
|
|
16
|
-
declare const FlowMetadata: $$__sveltets_2_IsomorphicComponent<{
|
|
3
|
+
interface Props {
|
|
17
4
|
job: Job;
|
|
18
5
|
scheduleEditor: ScheduleEditor;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
type FlowMetadata = InstanceType<typeof FlowMetadata>;
|
|
6
|
+
}
|
|
7
|
+
declare const FlowMetadata: import("svelte").Component<Props, {}, "">;
|
|
8
|
+
type FlowMetadata = ReturnType<typeof FlowMetadata>;
|
|
23
9
|
export default FlowMetadata;
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
<script lang="ts">import { Plug } from 'lucide-svelte';
|
|
2
2
|
import { Button } from './common';
|
|
3
3
|
import AnimatedButton from './common/button/AnimatedButton.svelte';
|
|
4
|
+
import { twMerge } from 'tailwind-merge';
|
|
4
5
|
export let connecting;
|
|
5
6
|
export let id = undefined;
|
|
7
|
+
export let wrapperClasses = '';
|
|
6
8
|
</script>
|
|
7
9
|
|
|
8
10
|
<AnimatedButton animate={connecting} baseRadius="6px" animationDuration="2s" marginWidth="2px">
|
|
@@ -10,10 +12,14 @@ export let id = undefined;
|
|
|
10
12
|
variant="border"
|
|
11
13
|
color="light"
|
|
12
14
|
size="xs2"
|
|
13
|
-
btnClasses={
|
|
15
|
+
btnClasses={twMerge(
|
|
16
|
+
connecting ? 'text-blue-500' : 'text-tertiary',
|
|
17
|
+
'group/plug-btn overflow-clip flex p-0'
|
|
18
|
+
)}
|
|
14
19
|
on:click
|
|
15
20
|
{...id ? { id } : {}}
|
|
21
|
+
{wrapperClasses}
|
|
16
22
|
>
|
|
17
|
-
<Plug size={
|
|
23
|
+
<Plug size={14} />
|
|
18
24
|
</Button>
|
|
19
25
|
</AnimatedButton>
|
|
@@ -14,6 +14,7 @@ interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> =
|
|
|
14
14
|
declare const FlowPlugConnect: $$__sveltets_2_IsomorphicComponent<{
|
|
15
15
|
connecting: boolean;
|
|
16
16
|
id?: undefined | string;
|
|
17
|
+
wrapperClasses?: string;
|
|
17
18
|
}, {
|
|
18
19
|
click: CustomEvent<any>;
|
|
19
20
|
} & {
|
|
@@ -9,7 +9,7 @@ import SchemaForm from './SchemaForm.svelte';
|
|
|
9
9
|
import SchemaFormWithArgPicker from './SchemaFormWithArgPicker.svelte';
|
|
10
10
|
import FlowStatusViewer from '../components/FlowStatusViewer.svelte';
|
|
11
11
|
import FlowProgressBar from './flows/FlowProgressBar.svelte';
|
|
12
|
-
import { AlertTriangle, ArrowRight, CornerDownLeft, Play, RefreshCw, X } from 'lucide-svelte';
|
|
12
|
+
import { AlertTriangle, ArrowRight, CornerDownLeft, Loader2, Play, RefreshCw, X } from 'lucide-svelte';
|
|
13
13
|
import { emptyString, sendUserToast } from '../utils';
|
|
14
14
|
import { dfs } from './flows/dfs';
|
|
15
15
|
import { sliceModules } from './flows/flowStateUtils.svelte';
|
|
@@ -20,6 +20,7 @@ import FlowHistoryJobPicker from './FlowHistoryJobPicker.svelte';
|
|
|
20
20
|
import { getStepHistoryLoaderContext } from './stepHistoryLoader.svelte';
|
|
21
21
|
import { aiChatManager } from './copilot/chat/AIChatManager.svelte';
|
|
22
22
|
import { stateSnapshot } from '../svelte5Utils.svelte';
|
|
23
|
+
import FlowChatInterface from './flows/FlowChatInterface.svelte';
|
|
23
24
|
let { previewMode = $bindable(), open, preventEscape = $bindable(false), jobId = $bindable(undefined), job = $bindable(undefined), initial = $bindable(false), selectedJobStep = $bindable(undefined), selectedJobStepIsTopLevel = $bindable(undefined), selectedJobStepType = $bindable('single'), rightColumnSelect = $bindable('timeline'), branchOrIterationN = $bindable(0), scrollTop = $bindable(0), localModuleStates = $bindable({}), localDurationStatuses = $bindable({}), onRunPreview, render = false, onJobDone, upToId = undefined } = $props();
|
|
24
25
|
let restartBranchNames = [];
|
|
25
26
|
let isRunning = $state(false);
|
|
@@ -29,9 +30,9 @@ let schemaHeight = $state(0);
|
|
|
29
30
|
let isValid = $state(true);
|
|
30
31
|
let suspendStatus = $state({ val: {} });
|
|
31
32
|
let isOwner = $state(false);
|
|
32
|
-
export function test() {
|
|
33
|
+
export async function test() {
|
|
33
34
|
renderCount++;
|
|
34
|
-
runPreview(previewArgs.val, undefined);
|
|
35
|
+
return await runPreview(previewArgs.val, undefined);
|
|
35
36
|
}
|
|
36
37
|
const { selectedId, previewArgs, flowStateStore, flowStore, pathStore, initialPathStore, fakeInitialPath, customUi, executionCount } = $state(getContext('FlowEditorContext'));
|
|
37
38
|
const dispatch = createEventDispatcher();
|
|
@@ -40,6 +41,7 @@ let schemaFormWithArgPicker = $state(undefined);
|
|
|
40
41
|
let currentJobId = $state(undefined);
|
|
41
42
|
let stepHistoryLoader = getStepHistoryLoaderContext();
|
|
42
43
|
let flowProgressBar = $state(undefined);
|
|
44
|
+
let loadingHistory = $state(false);
|
|
43
45
|
function extractFlow(previewMode) {
|
|
44
46
|
const previewFlow = aiChatManager.flowAiChatHelpers?.getPreviewFlow();
|
|
45
47
|
if (previewMode === 'whole') {
|
|
@@ -57,6 +59,7 @@ function extractFlow(previewMode) {
|
|
|
57
59
|
}
|
|
58
60
|
let lastPreviewFlow = $state(undefined);
|
|
59
61
|
export async function runPreview(args, restartedFrom) {
|
|
62
|
+
let newJobId = undefined;
|
|
60
63
|
if (stepHistoryLoader?.flowJobInitial !== false) {
|
|
61
64
|
stepHistoryLoader?.setFlowJobInitial(false);
|
|
62
65
|
}
|
|
@@ -64,7 +67,8 @@ export async function runPreview(args, restartedFrom) {
|
|
|
64
67
|
lastPreviewFlow = JSON.stringify(flowStore.val);
|
|
65
68
|
flowProgressBar?.reset();
|
|
66
69
|
const newFlow = extractFlow(previewMode);
|
|
67
|
-
|
|
70
|
+
newJobId = await runFlowPreview(args, newFlow, $pathStore, restartedFrom);
|
|
71
|
+
jobId = newJobId;
|
|
68
72
|
isRunning = true;
|
|
69
73
|
if (inputSelected) {
|
|
70
74
|
savedArgs = $state.snapshot(previewArgs.val);
|
|
@@ -78,6 +82,7 @@ export async function runPreview(args, restartedFrom) {
|
|
|
78
82
|
jobId = undefined;
|
|
79
83
|
}
|
|
80
84
|
schemaFormWithArgPicker?.refreshHistory();
|
|
85
|
+
return newJobId;
|
|
81
86
|
}
|
|
82
87
|
function onKeyDown(event) {
|
|
83
88
|
if (open) {
|
|
@@ -322,25 +327,27 @@ export function flowHasChanged() {
|
|
|
322
327
|
</Popover>
|
|
323
328
|
{/if}
|
|
324
329
|
{/if}
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
330
|
+
{#if !flowStore.val.value?.chat_input_enabled}
|
|
331
|
+
<Button
|
|
332
|
+
variant="contained"
|
|
333
|
+
startIcon={{ icon: isRunning ? RefreshCw : Play }}
|
|
334
|
+
color="dark"
|
|
335
|
+
size="sm"
|
|
336
|
+
btnClasses="w-full max-w-lg"
|
|
337
|
+
on:click={() => runPreview(previewArgs.val, undefined)}
|
|
338
|
+
id="flow-editor-test-flow-drawer"
|
|
339
|
+
shortCut={{ Icon: CornerDownLeft }}
|
|
340
|
+
>
|
|
341
|
+
{#if previewMode == 'upTo'}
|
|
342
|
+
Test up to
|
|
343
|
+
<Badge baseClass="ml-1" color="indigo">
|
|
344
|
+
{$selectedId}
|
|
345
|
+
</Badge>
|
|
346
|
+
{:else}
|
|
347
|
+
Test flow
|
|
348
|
+
{/if}
|
|
349
|
+
</Button>
|
|
350
|
+
{/if}
|
|
344
351
|
</div>
|
|
345
352
|
{/if}
|
|
346
353
|
</div>
|
|
@@ -365,81 +372,96 @@ export function flowHasChanged() {
|
|
|
365
372
|
onscroll={(e) => handleScroll()}
|
|
366
373
|
>
|
|
367
374
|
{#if render}
|
|
368
|
-
|
|
369
|
-
<
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
}}
|
|
401
|
-
/>
|
|
402
|
-
</div>
|
|
403
|
-
</div>
|
|
404
|
-
{#if jsonView}
|
|
405
|
-
<div class="py-2" style="height: {Math.max(schemaHeight, 100)}px" data-schema-picker>
|
|
406
|
-
<JsonInputs
|
|
407
|
-
bind:this={jsonEditor}
|
|
408
|
-
on:select={(e) => {
|
|
409
|
-
if (e.detail) {
|
|
410
|
-
previewArgs.val = e.detail
|
|
411
|
-
}
|
|
412
|
-
}}
|
|
413
|
-
updateOnBlur={false}
|
|
414
|
-
placeholder={`Write args as JSON.<br/><br/>Example:<br/><br/>{<br/> "foo": "12"<br/>}`}
|
|
375
|
+
{#if flowStore.val.value?.chat_input_enabled}
|
|
376
|
+
<div class="flex flex-row justify-center w-full">
|
|
377
|
+
<FlowChatInterface
|
|
378
|
+
onRunFlow={async (userMessage, _conversationId) => {
|
|
379
|
+
await runPreview({ user_message: userMessage }, undefined)
|
|
380
|
+
return jobId ?? ''
|
|
381
|
+
}}
|
|
382
|
+
createConversation={async () => {
|
|
383
|
+
const newConversationId = crypto.randomUUID()
|
|
384
|
+
return newConversationId
|
|
385
|
+
}}
|
|
386
|
+
/>
|
|
387
|
+
</div>
|
|
388
|
+
{:else}
|
|
389
|
+
<div class="border-b">
|
|
390
|
+
<SchemaFormWithArgPicker
|
|
391
|
+
bind:this={schemaFormWithArgPicker}
|
|
392
|
+
runnableId={$initialPathStore}
|
|
393
|
+
stablePathForCaptures={$initialPathStore || fakeInitialPath}
|
|
394
|
+
runnableType={'FlowPath'}
|
|
395
|
+
previewArgs={previewArgs.val}
|
|
396
|
+
on:openTriggers
|
|
397
|
+
on:select={(e) => {
|
|
398
|
+
selectInput(e.detail.payload, e.detail?.type)
|
|
399
|
+
}}
|
|
400
|
+
{isValid}
|
|
401
|
+
{jsonView}
|
|
402
|
+
>
|
|
403
|
+
<div class="w-full flex flex-row justify-between">
|
|
404
|
+
<InputSelectedBadge
|
|
405
|
+
onReject={() => schemaFormWithArgPicker?.resetSelected()}
|
|
406
|
+
{inputSelected}
|
|
415
407
|
/>
|
|
408
|
+
<div class="flex flex-row gap-2">
|
|
409
|
+
<Toggle
|
|
410
|
+
bind:checked={jsonView}
|
|
411
|
+
label="JSON View"
|
|
412
|
+
size="xs"
|
|
413
|
+
options={{
|
|
414
|
+
right: 'JSON',
|
|
415
|
+
rightTooltip: 'Fill args from JSON'
|
|
416
|
+
}}
|
|
417
|
+
lightMode
|
|
418
|
+
on:change={(e) => {
|
|
419
|
+
jsonEditor?.setCode(JSON.stringify(previewArgs.val ?? {}, null, '\t'))
|
|
420
|
+
refresh()
|
|
421
|
+
}}
|
|
422
|
+
/>
|
|
423
|
+
</div>
|
|
416
424
|
</div>
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
on:change={() => {
|
|
426
|
-
savedArgs = $state.snapshot(previewArgs.val)
|
|
425
|
+
{#if jsonView}
|
|
426
|
+
<div class="py-2" style="height: {Math.max(schemaHeight, 100)}px" data-schema-picker>
|
|
427
|
+
<JsonInputs
|
|
428
|
+
bind:this={jsonEditor}
|
|
429
|
+
on:select={(e) => {
|
|
430
|
+
if (e.detail) {
|
|
431
|
+
previewArgs.val = e.detail
|
|
432
|
+
}
|
|
427
433
|
}}
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
flowStore.val.schema?.['x-windmill-dyn-select-lang']
|
|
431
|
-
? {
|
|
432
|
-
type: 'inline',
|
|
433
|
-
code: flowStore.val.schema['x-windmill-dyn-select-code'] as string,
|
|
434
|
-
lang: flowStore.val.schema['x-windmill-dyn-select-lang'] as ScriptLang
|
|
435
|
-
}
|
|
436
|
-
: undefined}
|
|
434
|
+
updateOnBlur={false}
|
|
435
|
+
placeholder={`Write args as JSON.<br/><br/>Example:<br/><br/>{<br/> "foo": "12"<br/>}`}
|
|
437
436
|
/>
|
|
438
437
|
</div>
|
|
439
|
-
{
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
438
|
+
{:else}
|
|
439
|
+
{#key renderCount}
|
|
440
|
+
<div bind:clientHeight={schemaHeight} class="min-h-[40vh]">
|
|
441
|
+
<SchemaForm
|
|
442
|
+
noVariablePicker
|
|
443
|
+
compact
|
|
444
|
+
schema={flowStore.val.schema}
|
|
445
|
+
bind:args={previewArgs.val}
|
|
446
|
+
on:change={() => {
|
|
447
|
+
savedArgs = $state.snapshot(previewArgs.val)
|
|
448
|
+
}}
|
|
449
|
+
bind:isValid
|
|
450
|
+
helperScript={flowStore.val.schema?.['x-windmill-dyn-select-code'] &&
|
|
451
|
+
flowStore.val.schema?.['x-windmill-dyn-select-lang']
|
|
452
|
+
? {
|
|
453
|
+
source: 'inline',
|
|
454
|
+
code: flowStore.val.schema['x-windmill-dyn-select-code'] as string,
|
|
455
|
+
lang: flowStore.val.schema['x-windmill-dyn-select-lang'] as ScriptLang
|
|
456
|
+
}
|
|
457
|
+
: undefined}
|
|
458
|
+
/>
|
|
459
|
+
</div>
|
|
460
|
+
{/key}
|
|
461
|
+
{/if}
|
|
462
|
+
</SchemaFormWithArgPicker>
|
|
463
|
+
</div>
|
|
464
|
+
{/if}
|
|
443
465
|
{/if}
|
|
444
466
|
<div class="pt-4 flex flex-col grow relative">
|
|
445
467
|
<div
|
|
@@ -463,6 +485,7 @@ export function flowHasChanged() {
|
|
|
463
485
|
currentJobId = undefined
|
|
464
486
|
}}
|
|
465
487
|
path={$initialPathStore == '' ? $pathStore : $initialPathStore}
|
|
488
|
+
bind:loading={loadingHistory}
|
|
466
489
|
/>
|
|
467
490
|
{/if}
|
|
468
491
|
</div>
|
|
@@ -490,7 +513,7 @@ export function flowHasChanged() {
|
|
|
490
513
|
bind:suspendStatus
|
|
491
514
|
hideDownloadInGraph={customUi?.downloadLogs === false}
|
|
492
515
|
wideResults
|
|
493
|
-
bind:
|
|
516
|
+
bind:flowState={flowStateStore.val}
|
|
494
517
|
{jobId}
|
|
495
518
|
onDone={() => {
|
|
496
519
|
isRunning = false
|
|
@@ -503,6 +526,10 @@ export function flowHasChanged() {
|
|
|
503
526
|
{render}
|
|
504
527
|
{customUi}
|
|
505
528
|
/>
|
|
529
|
+
{:else if loadingHistory}
|
|
530
|
+
<div class="italic text-tertiary h-full grow mx-auto flex flex-row items-center gap-2">
|
|
531
|
+
<Loader2 class="animate-spin" /> <span> Loading history... </span>
|
|
532
|
+
</div>
|
|
506
533
|
{:else}
|
|
507
534
|
<div class="italic text-tertiary h-full grow"> Flow status will be displayed here </div>
|
|
508
535
|
{/if}
|
|
@@ -43,8 +43,8 @@ declare const FlowPreviewContent: $$__sveltets_2_IsomorphicComponent<Props, {
|
|
|
43
43
|
} & {
|
|
44
44
|
[evt: string]: CustomEvent<any>;
|
|
45
45
|
}, {}, {
|
|
46
|
-
test: () =>
|
|
47
|
-
runPreview: (args: Record<string, any>, restartedFrom: RestartedFrom | undefined) => Promise<
|
|
46
|
+
test: () => Promise<string | undefined>;
|
|
47
|
+
runPreview: (args: Record<string, any>, restartedFrom: RestartedFrom | undefined) => Promise<string | undefined>;
|
|
48
48
|
refresh: () => void;
|
|
49
49
|
cancelTest: () => Promise<void>;
|
|
50
50
|
getLocalModuleStates: () => Record<string, GraphModuleState>;
|
|
@@ -57,6 +57,6 @@ declare const FlowPreviewContent: $$__sveltets_2_IsomorphicComponent<Props, {
|
|
|
57
57
|
getIsOwner: () => boolean;
|
|
58
58
|
getJob: () => Job | undefined;
|
|
59
59
|
flowHasChanged: () => boolean;
|
|
60
|
-
}, "initial" | "preventEscape" | "job" | "
|
|
60
|
+
}, "initial" | "preventEscape" | "job" | "jobId" | "scrollTop" | "localModuleStates" | "localDurationStatuses" | "rightColumnSelect" | "selectedJobStep" | "previewMode" | "selectedJobStepIsTopLevel" | "selectedJobStepType" | "branchOrIterationN">;
|
|
61
61
|
type FlowPreviewContent = InstanceType<typeof FlowPreviewContent>;
|
|
62
62
|
export default FlowPreviewContent;
|
|
@@ -2,13 +2,12 @@
|
|
|
2
2
|
import { setContext, untrack } from 'svelte';
|
|
3
3
|
import { isOwner as loadIsOwner } from '../utils';
|
|
4
4
|
import { userStore, workspaceStore } from '../stores';
|
|
5
|
-
let { jobId, initialJob = undefined, workspaceId = undefined,
|
|
5
|
+
let { jobId, initialJob = undefined, workspaceId = undefined, flowState = $bindable({}), selectedJobStep = $bindable(undefined), hideFlowResult = false, hideTimeline = false, hideDownloadInGraph = false, hideNodeDefinition = false, hideJobId = false, hideDownloadLogs = false, rightColumnSelect = $bindable('timeline'), isOwner = $bindable(false), wideResults = false, localModuleStates = $bindable({}), localDurationStatuses = $bindable({}), job = $bindable(undefined), render = true, suspendStatus = $bindable({ val: {} }), customUi, onStart, onJobsLoaded, onDone } = $props();
|
|
6
6
|
let lastJobId = jobId;
|
|
7
7
|
let retryStatus = $state({ val: {} });
|
|
8
8
|
let globalRefreshes = $state({});
|
|
9
|
-
let globalIterationBounds = $state({});
|
|
10
9
|
setContext('FlowStatusViewer', {
|
|
11
|
-
|
|
10
|
+
flowState,
|
|
12
11
|
suspendStatus,
|
|
13
12
|
retryStatus,
|
|
14
13
|
hideDownloadInGraph,
|
|
@@ -22,11 +21,15 @@ function loadOwner(path) {
|
|
|
22
21
|
}
|
|
23
22
|
async function updateJobId() {
|
|
24
23
|
if (jobId !== lastJobId) {
|
|
24
|
+
console.log('updateJobId 3', jobId);
|
|
25
25
|
lastJobId = jobId;
|
|
26
26
|
retryStatus.val = {};
|
|
27
27
|
suspendStatus.val = {};
|
|
28
28
|
globalRefreshes = {};
|
|
29
|
-
|
|
29
|
+
for (let key in localModuleStates)
|
|
30
|
+
delete flowState[key];
|
|
31
|
+
localDurationStatuses = {};
|
|
32
|
+
localModuleStates = {};
|
|
30
33
|
}
|
|
31
34
|
}
|
|
32
35
|
let lastScriptPath = $state(undefined);
|
|
@@ -47,59 +50,60 @@ let storedToolCallJobs = $state({});
|
|
|
47
50
|
let toolCallIndicesToLoad = $state([]);
|
|
48
51
|
</script>
|
|
49
52
|
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
lastScriptPath
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
onJobsLoaded?.({ job, force })
|
|
58
|
-
}}
|
|
59
|
-
globalModuleStates={[]}
|
|
60
|
-
{globalIterationBounds}
|
|
61
|
-
bind:localModuleStates
|
|
62
|
-
bind:selectedNode={selectedJobStep}
|
|
63
|
-
bind:localDurationStatuses
|
|
64
|
-
{onStart}
|
|
65
|
-
{onDone}
|
|
66
|
-
bind:job
|
|
67
|
-
{initialJob}
|
|
68
|
-
{jobId}
|
|
69
|
-
{workspaceId}
|
|
70
|
-
{isOwner}
|
|
71
|
-
{wideResults}
|
|
72
|
-
bind:rightColumnSelect
|
|
73
|
-
{render}
|
|
74
|
-
{customUi}
|
|
75
|
-
graphTabOpen={true}
|
|
76
|
-
isNodeSelected={true}
|
|
77
|
-
{refreshGlobal}
|
|
78
|
-
{updateGlobalRefresh}
|
|
79
|
-
toolCallStore={{
|
|
80
|
-
getStoredToolCallJob: (storeKey: string) => storedToolCallJobs[storeKey],
|
|
81
|
-
setStoredToolCallJob: (storeKey: string, job: Job) => {
|
|
82
|
-
storedToolCallJobs[storeKey] = job
|
|
83
|
-
},
|
|
84
|
-
getLocalToolCallJobs: (prefix: string) => {
|
|
85
|
-
// we return a map from tool call index to job
|
|
86
|
-
// to do so, we filter the storedToolCallJobs object by the prefix and we make sure what's left in the key is a tool call index: 2 part of format agentModuleId-toolCallIndex
|
|
87
|
-
// and not a further nested tool call index
|
|
88
|
-
return Object.fromEntries(
|
|
89
|
-
Object.entries(storedToolCallJobs)
|
|
90
|
-
.filter(
|
|
91
|
-
([key]) => key.startsWith(prefix) && key.replace(prefix, '').split('-').length === 2
|
|
92
|
-
)
|
|
93
|
-
.map(([key, job]) => [Number(key.replace(prefix, '').split('-').pop()), job])
|
|
94
|
-
)
|
|
95
|
-
},
|
|
96
|
-
isToolCallToBeLoaded: (storeKey: string) => {
|
|
97
|
-
return toolCallIndicesToLoad.includes(storeKey)
|
|
98
|
-
},
|
|
99
|
-
addToolCallToLoad: (storeKey: string) => {
|
|
100
|
-
if (!toolCallIndicesToLoad.includes(storeKey)) {
|
|
101
|
-
toolCallIndicesToLoad.push(storeKey)
|
|
53
|
+
{#key jobId}
|
|
54
|
+
<FlowStatusViewerInner
|
|
55
|
+
{hideFlowResult}
|
|
56
|
+
onJobsLoaded={({ job, force }) => {
|
|
57
|
+
if (job.script_path != lastScriptPath && job.script_path) {
|
|
58
|
+
lastScriptPath = job.script_path
|
|
59
|
+
loadOwner(lastScriptPath ?? '')
|
|
102
60
|
}
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
61
|
+
onJobsLoaded?.({ job, force })
|
|
62
|
+
}}
|
|
63
|
+
globalModuleStates={[]}
|
|
64
|
+
bind:localModuleStates
|
|
65
|
+
bind:selectedNode={selectedJobStep}
|
|
66
|
+
bind:localDurationStatuses
|
|
67
|
+
{onStart}
|
|
68
|
+
{onDone}
|
|
69
|
+
bind:job
|
|
70
|
+
{initialJob}
|
|
71
|
+
{jobId}
|
|
72
|
+
{workspaceId}
|
|
73
|
+
{isOwner}
|
|
74
|
+
{wideResults}
|
|
75
|
+
bind:rightColumnSelect
|
|
76
|
+
{render}
|
|
77
|
+
{customUi}
|
|
78
|
+
graphTabOpen={true}
|
|
79
|
+
isNodeSelected={true}
|
|
80
|
+
{refreshGlobal}
|
|
81
|
+
{updateGlobalRefresh}
|
|
82
|
+
toolCallStore={{
|
|
83
|
+
getStoredToolCallJob: (storeKey: string) => storedToolCallJobs[storeKey],
|
|
84
|
+
setStoredToolCallJob: (storeKey: string, job: Job) => {
|
|
85
|
+
storedToolCallJobs[storeKey] = job
|
|
86
|
+
},
|
|
87
|
+
getLocalToolCallJobs: (prefix: string) => {
|
|
88
|
+
// we return a map from tool call index to job
|
|
89
|
+
// to do so, we filter the storedToolCallJobs object by the prefix and we make sure what's left in the key is a tool call index: 2 part of format agentModuleId-toolCallIndex
|
|
90
|
+
// and not a further nested tool call index
|
|
91
|
+
return Object.fromEntries(
|
|
92
|
+
Object.entries(storedToolCallJobs)
|
|
93
|
+
.filter(
|
|
94
|
+
([key]) => key.startsWith(prefix) && key.replace(prefix, '').split('-').length === 2
|
|
95
|
+
)
|
|
96
|
+
.map(([key, job]) => [Number(key.replace(prefix, '').split('-').pop()), job])
|
|
97
|
+
)
|
|
98
|
+
},
|
|
99
|
+
isToolCallToBeLoaded: (storeKey: string) => {
|
|
100
|
+
return toolCallIndicesToLoad.includes(storeKey)
|
|
101
|
+
},
|
|
102
|
+
addToolCallToLoad: (storeKey: string) => {
|
|
103
|
+
if (!toolCallIndicesToLoad.includes(storeKey)) {
|
|
104
|
+
toolCallIndicesToLoad.push(storeKey)
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}}
|
|
108
|
+
/>
|
|
109
|
+
{/key}
|
|
@@ -6,7 +6,7 @@ interface Props {
|
|
|
6
6
|
jobId: string;
|
|
7
7
|
initialJob?: Job | undefined;
|
|
8
8
|
workspaceId?: string | undefined;
|
|
9
|
-
|
|
9
|
+
flowState?: FlowState;
|
|
10
10
|
selectedJobStep?: string | undefined;
|
|
11
11
|
hideFlowResult?: boolean;
|
|
12
12
|
hideTimeline?: boolean;
|
|
@@ -37,6 +37,6 @@ interface Props {
|
|
|
37
37
|
job: CompletedJob;
|
|
38
38
|
}) => void;
|
|
39
39
|
}
|
|
40
|
-
declare const FlowStatusViewer: import("svelte").Component<Props, {}, "job" | "isOwner" | "suspendStatus" | "localModuleStates" | "
|
|
40
|
+
declare const FlowStatusViewer: import("svelte").Component<Props, {}, "job" | "isOwner" | "suspendStatus" | "localModuleStates" | "localDurationStatuses" | "flowState" | "rightColumnSelect" | "selectedJobStep">;
|
|
41
41
|
type FlowStatusViewer = ReturnType<typeof FlowStatusViewer>;
|
|
42
42
|
export default FlowStatusViewer;
|