windmill-components 1.623.1 → 1.623.2
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/assets/tokens/tokens.json +11 -1
- package/package/ata/apis.js +78 -5
- package/package/cancelable-promise-utils.js +4 -2
- package/package/components/AddUser.svelte +1 -1
- package/package/components/ApiConnectForm.svelte +6 -0
- package/package/components/AppConnectDrawer.svelte +1 -0
- package/package/components/AppConnectInner.svelte +1 -0
- package/package/components/AuthSettings.svelte +3 -1
- package/package/components/BedrockCredentialsCheck.svelte +241 -0
- package/package/components/BedrockCredentialsCheck.svelte.d.ts +3 -0
- package/package/components/CenteredModal.svelte +32 -24
- package/package/components/CenteredModal.svelte.d.ts +7 -27
- package/package/components/CenteredPage.svelte +6 -2
- package/package/components/CenteredPage.svelte.d.ts +3 -0
- package/package/components/CompareWorkspaces.svelte +74 -16
- package/package/components/ConcurrentJobsChart.svelte +3 -2
- package/package/components/ConcurrentJobsChart.svelte.d.ts +2 -2
- package/package/components/CustomPopover.svelte +20 -23
- package/package/components/CustomPopover.svelte.d.ts +14 -39
- package/package/components/DBManager.svelte +134 -42
- package/package/components/DBManager.svelte.d.ts +13 -2
- package/package/components/DBManagerContent.svelte +25 -63
- package/package/components/DBManagerContent.svelte.d.ts +38 -4
- package/package/components/DBManagerDrawer.svelte +7 -9
- package/package/components/DBTable.svelte +1 -1
- package/package/components/DBTable.svelte.d.ts +3 -1
- package/package/components/DBTableEditor.svelte +234 -178
- package/package/components/DBTableEditor.svelte.d.ts +22 -3
- package/package/components/DateInput.svelte +29 -35
- package/package/components/DateInput.svelte.d.ts +10 -11
- package/package/components/DedicatedWorkersSelector.svelte +569 -0
- package/package/components/DedicatedWorkersSelector.svelte.d.ts +8 -0
- package/package/components/DeployWorkspace.svelte +106 -29
- package/package/components/Description.svelte +3 -2
- package/package/components/Dev.svelte +36 -2
- package/package/components/DiffDrawer.svelte +8 -29
- package/package/components/DiffEditor.svelte +32 -2
- package/package/components/DisplayResult.svelte +32 -24
- package/package/components/DropdownV2.svelte +2 -1
- package/package/components/DropdownV2.svelte.d.ts +1 -0
- package/package/components/Editor.svelte +71 -26
- package/package/components/Editor.svelte.d.ts +3 -0
- package/package/components/EditorBar.svelte +1 -1
- package/package/components/FakeMonacoPlaceHolder.svelte +1 -1
- package/package/components/FlowBuilder.svelte +17 -11
- package/package/components/FlowDiffViewer.svelte +37 -0
- package/package/components/FlowDiffViewer.svelte.d.ts +7 -0
- package/package/components/FlowGraphViewer.svelte +5 -2
- package/package/components/FlowGraphViewer.svelte.d.ts +2 -0
- package/package/components/FlowLoopIterationPreview.svelte.d.ts +1 -1
- package/package/components/FlowPreviewContent.svelte +3 -2
- package/package/components/FlowPreviewContent.svelte.d.ts +1 -1
- package/package/components/FlowPreviewResult.svelte +0 -4
- package/package/components/FlowRestartButton.svelte +2 -3
- package/package/components/FlowRestartButton.svelte.d.ts +3 -0
- package/package/components/FlowStatusViewerInner.svelte +55 -35
- package/package/components/FlowStatusViewerInner.svelte.d.ts +1 -1
- package/package/components/FlowStatusWaitingForEvents.svelte +27 -23
- package/package/components/FlowStatusWaitingForEvents.svelte.d.ts +4 -18
- package/package/components/FlowViewer.svelte +103 -2
- package/package/components/FlowViewer.svelte.d.ts +9 -3
- package/package/components/ForkWorkspaceBanner.svelte +32 -13
- package/package/components/GraphqlSchemaViewer.svelte +8 -1
- package/package/components/HistoricInputs.svelte +25 -27
- package/package/components/HistoricInputs.svelte.d.ts +2 -2
- package/package/components/InfiniteList.svelte +27 -20
- package/package/components/InfiniteList.svelte.d.ts +2 -0
- package/package/components/InstanceSetting.svelte +38 -0
- package/package/components/InviteUser.svelte +16 -42
- package/package/components/InviteUser.svelte.d.ts +4 -18
- package/package/components/JobLoader.svelte.d.ts +1 -1
- package/package/components/JobOtelTraces.svelte +287 -0
- package/package/components/JobOtelTraces.svelte.d.ts +6 -0
- package/package/components/JsonInputs.svelte +6 -8
- package/package/components/JsonInputs.svelte.d.ts +7 -8
- package/package/components/LogViewer.svelte +91 -33
- package/package/components/Login.svelte +27 -0
- package/package/components/ManualPopover.svelte +5 -6
- package/package/components/ManualPopover.svelte.d.ts +9 -35
- package/package/components/MemoryFootprintViewer.svelte +2 -6
- package/package/components/ModulePreview.svelte +23 -21
- package/package/components/ModulePreview.svelte.d.ts +1 -0
- package/package/components/NextcloudSetting.svelte +1 -1
- package/package/components/OAuthSetting.svelte +1 -0
- package/package/components/Path.svelte +2 -2
- package/package/components/Path.svelte.d.ts +1 -1
- package/package/components/PocketIdSetting.svelte +82 -0
- package/package/components/PocketIdSetting.svelte.d.ts +6 -0
- package/package/components/ResourceEditor.svelte +4 -4
- package/package/components/ResourcePicker.svelte +4 -0
- package/package/components/ResourcePicker.svelte.d.ts +1 -0
- package/package/components/RunButton.svelte +5 -15
- package/package/components/RunButton.svelte.d.ts +7 -19
- package/package/components/RunChart.svelte +8 -4
- package/package/components/RunChart.svelte.d.ts +2 -2
- package/package/components/RunForm.svelte +9 -17
- package/package/components/RunForm.svelte.d.ts +0 -1
- package/package/components/RunFormAdvancedPopup.svelte +1 -1
- package/package/components/RunsPage.svelte +202 -537
- package/package/components/RunsPage.svelte.d.ts +5 -5
- package/package/components/S3FilePicker.svelte +7 -11
- package/package/components/S3FilePickerInner.svelte +2 -3
- package/package/components/S3FilePickerInner.svelte.d.ts +2 -2
- package/package/components/SavedInputsPicker.svelte +1 -1
- package/package/components/SavedInputsV2.svelte +35 -36
- package/package/components/SchemaForm.svelte +26 -19
- package/package/components/SchemaFormWithArgPicker.svelte +4 -3
- package/package/components/ScriptBuilder.svelte +1 -1
- package/package/components/ScriptEditor.svelte +575 -101
- package/package/components/Section.svelte +4 -2
- package/package/components/ServiceLogsInner.svelte +4 -4
- package/package/components/ShareModal.svelte.d.ts +1 -1
- package/package/components/SimpleEditor.svelte +46 -2
- package/package/components/Star.svelte +8 -12
- package/package/components/Star.svelte.d.ts +6 -19
- package/package/components/StringTypeNarrowing.svelte.d.ts +1 -1
- package/package/components/SuperadminSettingsInner.svelte +1 -1
- package/package/components/TemplateEditor.svelte +54 -29
- package/package/components/TemplateEditor.svelte.d.ts +13 -102
- package/package/components/TimeAgo.svelte +49 -7
- package/package/components/TimeAgo.svelte.d.ts +1 -0
- package/package/components/Toast.svelte +5 -1
- package/package/components/UserSettings.svelte +1 -1
- package/package/components/WorkerGroup.svelte +35 -20
- package/package/components/WorkerGroup.svelte.d.ts +1 -0
- package/package/components/WorkerTagPicker.svelte +1 -1
- package/package/components/WorkerTagSelect.svelte +5 -2
- package/package/components/WorkspaceTutorials.svelte +5 -0
- package/package/components/apps/components/buttons/AppButton.svelte +21 -6
- package/package/components/apps/components/buttons/AppForm.svelte +2 -1
- package/package/components/apps/components/buttons/AppFormButton.svelte +2 -1
- package/package/components/apps/components/display/InsertRowDrawerButton.svelte +1 -1
- package/package/components/apps/components/display/dbtable/AppDbExplorer.svelte +2 -5
- package/package/components/apps/components/display/dbtable/dbFeatures.d.ts +9 -0
- package/package/components/apps/components/display/dbtable/dbFeatures.js +32 -0
- package/package/components/apps/components/display/dbtable/metadata.d.ts +3 -3
- package/package/components/apps/components/display/dbtable/metadata.js +177 -148
- package/package/components/apps/components/display/dbtable/queries/alterTable.d.ts +46 -0
- package/package/components/apps/components/display/dbtable/queries/alterTable.js +322 -0
- package/package/components/apps/components/display/dbtable/queries/alterTable.test.d.ts +1 -0
- package/package/components/apps/components/display/dbtable/queries/alterTable.test.js +867 -0
- package/package/components/apps/components/display/dbtable/queries/createTable.d.ts +2 -24
- package/package/components/apps/components/display/dbtable/queries/createTable.js +13 -25
- package/package/components/apps/components/display/dbtable/queries/dbQueriesUtils.d.ts +9 -0
- package/package/components/apps/components/display/dbtable/queries/dbQueriesUtils.js +45 -0
- package/package/components/apps/components/display/dbtable/queries/relationalKeys.d.ts +45 -0
- package/package/components/apps/components/display/dbtable/queries/relationalKeys.js +401 -0
- package/package/components/apps/components/display/dbtable/queries/select.d.ts +2 -0
- package/package/components/apps/components/display/dbtable/queries/select.js +37 -6
- package/package/components/apps/components/display/dbtable/tableEditor.d.ts +35 -0
- package/package/components/apps/components/display/dbtable/tableEditor.js +67 -0
- package/package/components/apps/components/display/dbtable/utils.d.ts +2 -0
- package/package/components/apps/components/display/dbtable/utils.js +61 -36
- package/package/components/apps/components/display/table/AppAggridTable.svelte +8 -0
- package/package/components/apps/components/display/table/AppAggridTableActions.svelte +9 -9
- package/package/components/apps/components/display/table/AppAggridTableActions.svelte.d.ts +1 -1
- package/package/components/apps/components/helpers/HiddenComponent.svelte +1 -1
- package/package/components/apps/components/helpers/InputValue.svelte +1 -1
- package/package/components/apps/components/helpers/ResolveConfig.svelte +1 -1
- package/package/components/apps/components/helpers/RunnableComponent.svelte +3 -2
- package/package/components/apps/components/helpers/RunnableComponent.svelte.d.ts +1 -1
- package/package/components/apps/components/helpers/RunnableWrapper.svelte +2 -2
- package/package/components/apps/components/inputs/AppMultiSelectV2.svelte +2 -4
- package/package/components/apps/editor/AppEditorHeader.svelte +8 -1
- package/package/components/apps/editor/AppEditorHeaderDeploy.svelte +32 -29
- package/package/components/apps/editor/AppEditorHeaderDeploy.svelte.d.ts +2 -2
- package/package/components/apps/editor/AppEditorHeaderDeployInitialDraft.svelte +4 -4
- package/package/components/apps/editor/AppEditorHeaderDeployInitialDraft.svelte.d.ts +3 -3
- package/package/components/apps/editor/PublicApp.svelte +49 -30
- package/package/components/apps/editor/PublicApp.svelte.d.ts +1 -0
- package/package/components/apps/editor/inlineScriptsPanel/InlineScriptRunnableByPath.svelte +77 -7
- package/package/components/apps/editor/inlineScriptsPanel/InlineScriptRunnableByPath.svelte.d.ts +2 -2
- package/package/components/apps/editor/inlineScriptsPanel/utils.d.ts +2 -2
- package/package/components/apps/editor/inlineScriptsPanel/utils.js +10 -1
- package/package/components/apps/inputType.d.ts +6 -1
- package/package/components/assets/AssetsDropdownButton.svelte +1 -1
- package/package/components/assets/AssetsUsageDrawer.svelte +98 -27
- package/package/components/assets/AssetsUsageDrawer.svelte.d.ts +5 -6
- package/package/components/assets/lib.d.ts +3 -2
- package/package/components/assets/lib.js +3 -1
- package/package/components/auditLogs/AuditLogsFilters.svelte +9 -17
- package/package/components/auditLogs/AuditLogsFilters.svelte.d.ts +1 -1
- package/package/components/common/CloseButton.svelte +2 -1
- package/package/components/common/CloseButton.svelte.d.ts +1 -0
- package/package/components/common/badge/CountBadge.svelte +4 -3
- package/package/components/common/badge/CountBadge.svelte.d.ts +1 -0
- package/package/components/common/button/Button.svelte +1 -1
- package/package/components/common/button/model.js +1 -1
- package/package/components/common/calendarPicker/CalendarPicker.svelte.d.ts +1 -1
- package/package/components/common/confirmationModal/ConfirmationModal.svelte +2 -1
- package/package/components/common/confirmationModal/ConfirmationModal.svelte.d.ts +1 -0
- package/package/components/common/drawer/Drawer.svelte +4 -1
- package/package/components/common/drawer/DrawerContent.svelte +6 -3
- package/package/components/common/drawer/DrawerContent.svelte.d.ts +1 -0
- package/package/components/common/languageIcons/TypeScript.svelte +5 -3
- package/package/components/common/languageIcons/TypeScript.svelte.d.ts +1 -0
- package/package/components/common/modal/Modal.svelte +3 -3
- package/package/components/common/modal/Modal2.svelte +1 -0
- package/package/components/common/table/AppRow.svelte +4 -1
- package/package/components/common/table/FlowRow.svelte +4 -1
- package/package/components/common/table/RawAppRow.svelte +4 -1
- package/package/components/common/table/Row.svelte +11 -21
- package/package/components/common/table/Row.svelte.d.ts +4 -20
- package/package/components/common/table/RowIcon.svelte +6 -2
- package/package/components/common/table/RowIcon.svelte.d.ts +1 -1
- package/package/components/common/table/ScriptRow.svelte +4 -1
- package/package/components/copilot/autocomplete/Autocompletor.d.ts +1 -1
- package/package/components/copilot/autocomplete/Autocompletor.js +7 -6
- package/package/components/copilot/autocomplete/request.js +13 -9
- package/package/components/copilot/chat/AIButtonStyle.d.ts +1 -1
- package/package/components/copilot/chat/AIButtonStyle.js +2 -1
- package/package/components/copilot/chat/AIChat.svelte +3 -1
- package/package/components/copilot/chat/AIChatDisplay.svelte +89 -4
- package/package/components/copilot/chat/AIChatInput.svelte +275 -0
- package/package/components/copilot/chat/AIChatManager.svelte.js +107 -1
- package/package/components/copilot/chat/AiChatLayout.svelte +15 -30
- package/package/components/copilot/chat/AppAvailableContextList.svelte +263 -0
- package/package/components/copilot/chat/AppAvailableContextList.svelte.d.ts +13 -0
- package/package/components/copilot/chat/ContextElementBadge.svelte +44 -0
- package/package/components/copilot/chat/DatatableCreationPolicy.svelte +32 -33
- package/package/components/copilot/chat/ProviderModelSelector.svelte +1 -1
- package/package/components/copilot/chat/__tests__/app/appEvalHelpers.js +3 -0
- package/package/components/copilot/chat/__tests__/flow/flowEvalHelpers.js +4 -0
- package/package/components/copilot/chat/app/core.d.ts +56 -15
- package/package/components/copilot/chat/app/core.js +141 -22
- package/package/components/copilot/chat/context.d.ts +59 -2
- package/package/components/copilot/chat/context.js +6 -2
- package/package/components/copilot/chat/flow/FlowAIChat.svelte +22 -0
- package/package/components/copilot/chat/flow/core.d.ts +3 -1
- package/package/components/copilot/chat/flow/core.js +29 -2
- package/package/components/copilot/chat/flow/openFlow.json +1 -1
- package/package/components/copilot/chat/flow/openFlowZod.d.ts +1 -0
- package/package/components/copilot/chat/flow/openFlowZod.js +14 -2
- package/package/components/copilot/chat/script/core.d.ts +4 -1
- package/package/components/copilot/chat/script/core.js +43 -6
- package/package/components/copilot/chat/shared.d.ts +10 -0
- package/package/components/copilot/chat/shared.js +24 -0
- package/package/components/copilot/lib.d.ts +1 -1
- package/package/components/copilot/lib.js +2 -9
- package/package/components/copilot/utils.d.ts +5 -0
- package/package/components/copilot/utils.js +8 -0
- package/package/components/custom_ui.d.ts +2 -0
- package/package/components/dbOps.d.ts +18 -4
- package/package/components/dbOps.js +25 -3
- package/package/components/debug/DebugConsole.svelte +277 -0
- package/package/components/debug/DebugConsole.svelte.d.ts +13 -0
- package/package/components/debug/DebugPanel.svelte +97 -0
- package/package/components/debug/DebugPanel.svelte.d.ts +11 -0
- package/package/components/debug/DebugToolbar.svelte +148 -0
- package/package/components/debug/DebugToolbar.svelte.d.ts +17 -0
- package/package/components/debug/DebugVariableViewer.svelte +115 -0
- package/package/components/debug/DebugVariableViewer.svelte.d.ts +11 -0
- package/package/components/debug/MonacoDebugger.svelte +384 -0
- package/package/components/debug/MonacoDebugger.svelte.d.ts +15 -0
- package/package/components/debug/dapClient.d.ts +192 -0
- package/package/components/debug/dapClient.js +426 -0
- package/package/components/debug/debugUtils.d.ts +30 -0
- package/package/components/debug/debugUtils.js +131 -0
- package/package/components/debug/index.d.ts +75 -0
- package/package/components/debug/index.js +82 -0
- package/package/components/details/DetailPageHeader.svelte +21 -7
- package/package/components/details/DetailPageHeader.svelte.d.ts +2 -1
- package/package/components/details/DetailPageLayout.svelte +10 -1
- package/package/components/details/DetailPageLayout.svelte.d.ts +1 -0
- package/package/components/flows/CreateActionsApp.svelte +6 -4
- package/package/components/flows/DebounceLimit.svelte.d.ts +1 -1
- package/package/components/flows/FlowHistoryInner.svelte +15 -4
- package/package/components/flows/content/AgentToolWrapper.svelte +1 -1
- package/package/components/flows/content/FlowEditorDrawer.svelte +124 -0
- package/package/components/flows/content/FlowEditorDrawer.svelte.d.ts +22 -0
- package/package/components/flows/content/FlowInput.svelte +211 -37
- package/package/components/flows/content/FlowModuleComponent.svelte +553 -67
- package/package/components/flows/content/FlowModuleEarlyStop.svelte +8 -10
- package/package/components/flows/content/FlowModuleHeader.svelte +7 -4
- package/package/components/flows/content/FlowModuleWorkerTagSelect.svelte +1 -1
- package/package/components/flows/content/McpOAuthConnect.svelte +217 -0
- package/package/components/flows/content/McpOAuthConnect.svelte.d.ts +7 -0
- package/package/components/flows/content/McpToolEditor.svelte +50 -37
- package/package/components/flows/content/McpToolEditor.svelte.d.ts +0 -1
- package/package/components/flows/conversations/FlowChat.svelte +16 -2
- package/package/components/flows/conversations/FlowChat.svelte.d.ts +2 -1
- package/package/components/flows/conversations/FlowChatInterface.svelte +103 -6
- package/package/components/flows/conversations/FlowChatInterface.svelte.d.ts +2 -0
- package/package/components/flows/conversations/FlowChatManager.svelte.js +53 -21
- package/package/components/flows/conversations/FlowConversationsSidebar.svelte +79 -77
- package/package/components/flows/header/FlowImportExportMenu.svelte +1 -1
- package/package/components/flows/propPicker/OutputPickerInner.svelte.d.ts +1 -1
- package/package/components/flows/propPicker/PropPickerWrapper.svelte +3 -1
- package/package/components/flows/types.d.ts +2 -0
- package/package/components/git_sync/GitSyncRepositoryCard.svelte +16 -8
- package/package/components/graph/FlowGraphV2.svelte +7 -1
- package/package/components/graph/renderers/triggers/TriggersBadge.svelte +41 -24
- package/package/components/home/ItemsList.svelte +7 -6
- package/package/components/home/TutorialBanner.svelte +34 -18
- package/package/components/home/treeViewUtils.js +1 -1
- package/package/components/icons/CssIcon.svelte +20 -0
- package/package/components/icons/CssIcon.svelte.d.ts +7 -25
- package/package/components/icons/HtmlIcon.svelte +20 -0
- package/package/components/icons/HtmlIcon.svelte.d.ts +8 -0
- package/package/components/icons/JavaScriptIcon.svelte +10 -2
- package/package/components/icons/JavaScriptIcon.svelte.d.ts +1 -0
- package/package/components/icons/JsonIcon.svelte +8 -2
- package/package/components/icons/JsonIcon.svelte.d.ts +1 -0
- package/package/components/icons/LessIcon.svelte +16 -0
- package/package/components/icons/LessIcon.svelte.d.ts +8 -0
- package/package/components/icons/MarkdownIcon.svelte +20 -0
- package/package/components/icons/MarkdownIcon.svelte.d.ts +8 -0
- package/package/components/icons/NextcloudIcon.svelte +3 -2
- package/package/components/icons/NextcloudIcon.svelte.d.ts +2 -0
- package/package/components/icons/PocketIdIcon.svelte +9 -0
- package/package/components/icons/PocketIdIcon.svelte.d.ts +9 -0
- package/package/components/icons/ReactIcon.svelte +10 -2
- package/package/components/icons/ReactIcon.svelte.d.ts +1 -0
- package/package/components/icons/SassIcon.svelte +28 -0
- package/package/components/icons/SassIcon.svelte.d.ts +8 -0
- package/package/components/icons/SvelteIcon.svelte +10 -2
- package/package/components/icons/SvelteIcon.svelte.d.ts +1 -0
- package/package/components/icons/VueIcon.svelte +10 -2
- package/package/components/icons/VueIcon.svelte.d.ts +1 -0
- package/package/components/icons/YamlIcon.svelte +20 -0
- package/package/components/icons/YamlIcon.svelte.d.ts +8 -0
- package/package/components/icons/index.js +3 -1
- package/package/components/instanceSettings/SecretBackendConfig.svelte +514 -0
- package/package/components/instanceSettings/SecretBackendConfig.svelte.d.ts +8 -0
- package/package/components/instanceSettings.d.ts +2 -1
- package/package/components/instanceSettings.js +33 -1
- package/package/components/jobs/JobPreview.svelte +46 -39
- package/package/components/jobs/JobPreview.svelte.d.ts +1 -0
- package/package/components/monacoLanguagesOptions.js +16 -15
- package/package/components/propertyPicker/PropPicker.svelte +16 -2
- package/package/components/propertyPicker/PropPicker.svelte.d.ts +2 -0
- package/package/components/raw_apps/DefaultDatabaseSelector.svelte +9 -5
- package/package/components/raw_apps/FileEditorIcon.svelte +12 -7
- package/package/components/raw_apps/FileEditorIcon.svelte.d.ts +2 -0
- package/package/components/raw_apps/FileTreeNode.svelte +119 -83
- package/package/components/raw_apps/RawAppBackgroundRunner.svelte +88 -8
- package/package/components/raw_apps/RawAppDataTableDrawer.svelte +1 -3
- package/package/components/raw_apps/RawAppDataTableList.svelte +12 -9
- package/package/components/raw_apps/RawAppEditor.svelte +218 -68
- package/package/components/raw_apps/RawAppEditorHeader.svelte +33 -16
- package/package/components/raw_apps/RawAppHistoryList.svelte +264 -80
- package/package/components/raw_apps/RawAppHistoryList.svelte.d.ts +1 -0
- package/package/components/raw_apps/RawAppHistoryManager.svelte.d.ts +15 -1
- package/package/components/raw_apps/RawAppHistoryManager.svelte.js +46 -12
- package/package/components/raw_apps/RawAppInlineScriptEditor.svelte +549 -47
- package/package/components/raw_apps/RawAppInlineScriptEditor.svelte.d.ts +31 -5
- package/package/components/raw_apps/RawAppInlineScriptPanelList.svelte +25 -18
- package/package/components/raw_apps/RawAppInlineScriptPanelList.svelte.d.ts +1 -0
- package/package/components/raw_apps/RawAppInlineScriptRunnable.svelte +141 -10
- package/package/components/raw_apps/RawAppInlineScriptRunnable.svelte.d.ts +8 -0
- package/package/components/raw_apps/RawAppInlineScriptsPanel.svelte +2 -1
- package/package/components/raw_apps/RawAppInlineScriptsPanel.svelte.d.ts +9 -1
- package/package/components/raw_apps/RawAppInputsSpecEditor.svelte +47 -3
- package/package/components/raw_apps/RawAppInputsSpecEditor.svelte.d.ts +2 -2
- package/package/components/raw_apps/RawAppModules.svelte +13 -7
- package/package/components/raw_apps/RawAppPreview.svelte +48 -6
- package/package/components/raw_apps/RawAppSidebar.svelte +194 -125
- package/package/components/raw_apps/RawAppSidebar.svelte.d.ts +1 -0
- package/package/components/raw_apps/RunnableRow.svelte +41 -0
- package/package/components/raw_apps/RunnableRow.svelte.d.ts +11 -0
- package/package/components/raw_apps/datatableUtils.svelte.js +1 -1
- package/package/components/raw_apps/utils.d.ts +1 -1
- package/package/components/raw_apps/utils.js +76 -18
- package/package/components/runs/ManuelDatePicker.svelte +3 -3
- package/package/components/runs/ManuelDatePicker.svelte.d.ts +3 -3
- package/package/components/runs/NoWorkerWithTagWarning.svelte +5 -1
- package/package/components/runs/RunsFilter.svelte +75 -63
- package/package/components/runs/RunsFilter.svelte.d.ts +35 -4
- package/package/components/runs/RunsQueue.svelte.d.ts +1 -1
- package/package/components/runs/RunsTable.svelte +1 -1
- package/package/components/runs/RunsTable.svelte.d.ts +1 -1
- package/package/components/runs/useJobsLoader.svelte.d.ts +34 -0
- package/package/components/runs/useJobsLoader.svelte.js +507 -0
- package/package/components/schema/EditableSchemaWrapper.svelte +2 -2
- package/package/components/scriptEditor/LogPanel.svelte +17 -2
- package/package/components/scriptEditor/LogPanel.svelte.d.ts +2 -0
- package/package/components/select/MultiSelect.svelte +1 -1
- package/package/components/select/SelectDropdown.svelte +17 -5
- package/package/components/settings/AIPromptsModal.svelte +88 -0
- package/package/components/settings/AIPromptsModal.svelte.d.ts +11 -0
- package/package/components/settings/ChangeWorkspaceColor.svelte +4 -3
- package/package/components/settings/ChangeWorkspaceId.svelte +16 -11
- package/package/components/settings/ChangeWorkspaceName.svelte +7 -6
- package/package/components/settings/CreateToken.svelte +4 -4
- package/package/components/settings/UserAIPromptsSettings.svelte +56 -15
- package/package/components/settings/WorkspaceOperatorSettings.svelte +68 -85
- package/package/components/settings/WorkspaceUserSettings.svelte +537 -411
- package/package/components/sidebar/MenuButton.svelte +54 -24
- package/package/components/sidebar/MenuButton.svelte.d.ts +2 -0
- package/package/components/sidebar/MultiplayerMenu.svelte +4 -4
- package/package/components/sidebar/OperatorMenu.svelte +63 -88
- package/package/components/sidebar/SidebarContent.svelte +39 -6
- package/package/components/sidebar/UserMenu.svelte +3 -3
- package/package/components/sidebar/WorkspaceMenu.svelte +35 -85
- package/package/components/sqlTypeService.js +4 -3
- package/package/components/table/DataTable.svelte +8 -3
- package/package/components/table/DataTable.svelte.d.ts +2 -0
- package/package/components/text_input/TextInput.svelte +3 -0
- package/package/components/text_input/TextInput.svelte.d.ts +2 -0
- package/package/components/triggers/AddTriggersButton.svelte +17 -4
- package/package/components/triggers/TriggersEditor.svelte +4 -0
- package/package/components/triggers/TriggersWrapper.svelte +14 -0
- package/package/components/triggers/native/NativeTriggerEditor.svelte +379 -0
- package/package/components/triggers/native/NativeTriggerEditor.svelte.d.ts +26 -0
- package/package/components/triggers/native/NativeTriggerTable.svelte +155 -0
- package/package/components/triggers/native/NativeTriggerTable.svelte.d.ts +16 -0
- package/package/components/triggers/native/NativeTriggersPanel.svelte +40 -0
- package/package/components/triggers/native/NativeTriggersPanel.svelte.d.ts +15 -0
- package/package/components/triggers/native/services/nextcloud/NextcloudTriggerForm.svelte +104 -0
- package/package/components/triggers/native/services/nextcloud/NextcloudTriggerForm.svelte.d.ts +18 -0
- package/package/components/triggers/native/utils.d.ts +74 -0
- package/package/components/triggers/native/utils.js +152 -0
- package/package/components/triggers/triggers.svelte.d.ts +2 -1
- package/package/components/triggers/triggers.svelte.js +36 -8
- package/package/components/triggers/utils.js +18 -6
- package/package/components/triggers.d.ts +1 -1
- package/package/components/tutorials/FlowBuilderLiveTutorial.svelte +6 -35
- package/package/components/tutorials/RunsTutorial.svelte +399 -0
- package/package/components/{schema/SchemaPicker.svelte.d.ts → tutorials/RunsTutorial.svelte.d.ts} +11 -12
- package/package/components/tutorials/TroubleshootFlowTutorial.svelte +5 -20
- package/package/components/tutorials/utils.d.ts +16 -0
- package/package/components/tutorials/utils.js +96 -0
- package/package/components/tutorials/workspace/WorkspaceOnboardingOperatorTutorial.svelte +133 -0
- package/package/components/{SavedInputs.svelte.d.ts → tutorials/workspace/WorkspaceOnboardingOperatorTutorial.svelte.d.ts} +8 -11
- package/package/components/vscode.js +6 -6
- package/package/components/workspace/WorkspaceCard.svelte +184 -0
- package/package/components/workspace/WorkspaceCard.svelte.d.ts +24 -0
- package/package/components/workspace/WorkspaceIcon.svelte +21 -0
- package/package/components/workspace/WorkspaceIcon.svelte.d.ts +9 -0
- package/package/components/workspace/WorkspaceTreeView.svelte +331 -0
- package/package/components/workspace/WorkspaceTreeView.svelte.d.ts +15 -0
- package/package/components/workspaceSettings/AISettings.svelte +147 -108
- package/package/components/workspaceSettings/CreateWorkspace.svelte +26 -12
- package/package/components/workspaceSettings/CustomInstanceDbSelect.svelte +1 -0
- package/package/components/workspaceSettings/CustomInstanceDbWizardModal.svelte +3 -1
- package/package/components/workspaceSettings/DataTableSettings.svelte +2 -1
- package/package/components/workspaceSettings/DucklakeSettings.svelte +54 -26
- package/package/components/workspaceSettings/DucklakeSettings.svelte.d.ts +2 -1
- package/package/components/workspaceSettings/ModelTokenLimits.svelte +14 -18
- package/package/components/workspaceSettings/OAuthClientConfig.svelte +180 -0
- package/package/components/workspaceSettings/OAuthClientConfig.svelte.d.ts +14 -0
- package/package/components/workspaceSettings/StorageSettings.svelte +285 -241
- package/package/components/workspaceSettings/StorageSettings.svelte.d.ts +1 -0
- package/package/components/workspaceSettings/WorkspaceIntegrations.svelte +302 -0
- package/package/components/workspaceSettings/WorkspaceIntegrations.svelte.d.ts +3 -0
- package/package/consts.js +4 -3
- package/package/gen/core/OpenAPI.js +1 -1
- package/package/gen/schemas.gen.d.ts +517 -4
- package/package/gen/schemas.gen.js +523 -4
- package/package/gen/services.gen.d.ts +359 -22
- package/package/gen/services.gen.js +702 -44
- package/package/gen/types.gen.d.ts +1501 -121
- package/package/hub.js +2 -2
- package/package/hubPaths.json +3 -2
- package/package/infer.js +2 -0
- package/package/logout.d.ts +0 -2
- package/package/logout.js +2 -23
- package/package/logoutKit.d.ts +2 -0
- package/package/logoutKit.js +26 -0
- package/package/monaco_workers/graphql.worker.bundle.js +121 -121
- package/package/navigation.d.ts +1 -1
- package/package/rawAppWmillTs.d.ts +11 -0
- package/package/rawAppWmillTs.js +38 -1
- package/package/refreshUser.d.ts +5 -1
- package/package/refreshUser.js +20 -30
- package/package/storeUtils.js +2 -0
- package/package/svelte5Utils.svelte.d.ts +68 -1
- package/package/svelte5Utils.svelte.js +193 -2
- package/package/svelte5UtilsKit.svelte.d.ts +3 -0
- package/package/svelte5UtilsKit.svelte.js +30 -0
- package/package/tutorialUtils.js +0 -4
- package/package/tutorials/config.js +31 -3
- package/package/tutorials/roleUtils.d.ts +1 -1
- package/package/tutorials/roleUtils.js +6 -2
- package/package/utils.js +162 -1
- package/package.json +1 -1
- package/package/components/SavedInputs.svelte +0 -416
- package/package/components/runs/JobsLoader.svelte +0 -468
- package/package/components/runs/JobsLoader.svelte.d.ts +0 -49
- package/package/components/schema/SchemaPicker.svelte +0 -92
|
@@ -0,0 +1,507 @@
|
|
|
1
|
+
import { onDestroy, onMount, untrack } from 'svelte';
|
|
2
|
+
import { JobService, ConcurrencyGroupsService, CancelablePromise, CancelError } from '../../gen';
|
|
3
|
+
import { sendUserToast } from '../../toast';
|
|
4
|
+
import { tweened } from 'svelte/motion';
|
|
5
|
+
import { subtractDaysFromDateString } from '../../utils';
|
|
6
|
+
import { CancelablePromiseUtils } from '../../cancelable-promise-utils';
|
|
7
|
+
export function computeJobKinds(jobKindsCat) {
|
|
8
|
+
if (jobKindsCat == 'all') {
|
|
9
|
+
return '';
|
|
10
|
+
}
|
|
11
|
+
else if (jobKindsCat == 'dependencies') {
|
|
12
|
+
let kinds = ['dependencies', 'flowdependencies', 'appdependencies'];
|
|
13
|
+
return kinds.join(',');
|
|
14
|
+
}
|
|
15
|
+
else if (jobKindsCat == 'previews') {
|
|
16
|
+
let kinds = ['preview', 'flowpreview'];
|
|
17
|
+
return kinds.join(',');
|
|
18
|
+
}
|
|
19
|
+
else if (jobKindsCat == 'deploymentcallbacks') {
|
|
20
|
+
let kinds = ['deploymentcallback'];
|
|
21
|
+
return kinds.join(',');
|
|
22
|
+
}
|
|
23
|
+
else if (jobKindsCat == 'runs') {
|
|
24
|
+
let kinds = ['script', 'flow', 'singlestepflow'];
|
|
25
|
+
return kinds.join(',');
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
let kinds = [
|
|
29
|
+
'script',
|
|
30
|
+
'flow',
|
|
31
|
+
'flowscript',
|
|
32
|
+
'flownode',
|
|
33
|
+
'appscript'
|
|
34
|
+
];
|
|
35
|
+
return kinds.join(',');
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
export function useJobsLoader(args) {
|
|
39
|
+
let _args = $derived(args());
|
|
40
|
+
let currentWorkspace = $derived(_args.currentWorkspace);
|
|
41
|
+
let filters = $derived(_args.filters);
|
|
42
|
+
let jobKinds = $derived(_args.jobKinds);
|
|
43
|
+
let autoRefresh = $derived(_args.autoRefresh ?? true);
|
|
44
|
+
let argError = $derived(_args.argError ?? '');
|
|
45
|
+
let resultError = $derived(_args.resultError ?? '');
|
|
46
|
+
let refreshRate = $derived(_args.refreshRate ?? 5000);
|
|
47
|
+
let syncQueuedRunsCount = $derived(_args.syncQueuedRunsCount ?? true);
|
|
48
|
+
let computeMinAndMax = $derived(_args.computeMinAndMax);
|
|
49
|
+
let lookback = $derived(_args.lookback ?? 0);
|
|
50
|
+
let onSetMinMaxTs = $derived(_args.onSetMinMaxTs);
|
|
51
|
+
let onSetPerPage = $derived(_args.onSetPerPage);
|
|
52
|
+
let label = $derived(filters?.label ?? null);
|
|
53
|
+
let worker = $derived(filters?.worker ?? null);
|
|
54
|
+
let success = $derived(filters?.success ?? null);
|
|
55
|
+
let showSkipped = $derived(filters?.show_skipped ?? false);
|
|
56
|
+
let showSchedules = $derived(filters?.show_schedules ?? true);
|
|
57
|
+
let showFutureJobs = $derived(filters?.show_future_jobs ?? true);
|
|
58
|
+
let resultFilter = $derived(filters?.result);
|
|
59
|
+
let jobTriggerKind = $derived(filters?.job_trigger_kind ?? null);
|
|
60
|
+
let schedulePath = $derived(filters?.schedule_path ?? null);
|
|
61
|
+
let jobKindsCat = $derived(filters?.job_kinds ?? null);
|
|
62
|
+
let allWorkspaces = $derived(filters?.all_workspaces ?? false);
|
|
63
|
+
let allowWildcards = $derived(filters?.allow_wildcards ?? false);
|
|
64
|
+
let concurrencyKey = $derived(filters?.concurrency_key);
|
|
65
|
+
let tag = $derived(filters?.tag);
|
|
66
|
+
let user = $derived(filters?.user);
|
|
67
|
+
let folder = $derived(filters?.folder);
|
|
68
|
+
let path = $derived(filters?.path);
|
|
69
|
+
let argFilter = $derived(filters?.arg);
|
|
70
|
+
let minTs = $derived(filters?.min_ts ?? null);
|
|
71
|
+
let maxTs = $derived(filters?.max_ts ?? null);
|
|
72
|
+
let perPage = $derived(filters?.per_page ?? 100);
|
|
73
|
+
let queue_count = $state();
|
|
74
|
+
let suspended_count = $state();
|
|
75
|
+
let loading = $state(false);
|
|
76
|
+
let lastFetchWentToEnd = $state(false);
|
|
77
|
+
let completedJobs = $state();
|
|
78
|
+
let externalJobs = $state();
|
|
79
|
+
let extendedJobs = $state();
|
|
80
|
+
let jobs = $state();
|
|
81
|
+
let intervalId = $state();
|
|
82
|
+
let sync = true;
|
|
83
|
+
function onParamChanges() {
|
|
84
|
+
resetJobs();
|
|
85
|
+
let promise = loadJobsIntern(true);
|
|
86
|
+
promise = CancelablePromiseUtils.onTimeout(promise, 4000, () => {
|
|
87
|
+
sendUserToast('Loading jobs is taking longer than expected...', true, perPage > 25 && onSetPerPage
|
|
88
|
+
? [{ label: 'Reduce to 25 items per page', callback: () => onSetPerPage(25) }]
|
|
89
|
+
: []);
|
|
90
|
+
});
|
|
91
|
+
promise = CancelablePromiseUtils.catchErr(promise, (e) => {
|
|
92
|
+
if (e instanceof CancelError) {
|
|
93
|
+
return CancelablePromiseUtils.pure(undefined);
|
|
94
|
+
}
|
|
95
|
+
return CancelablePromiseUtils.err(e);
|
|
96
|
+
});
|
|
97
|
+
return promise;
|
|
98
|
+
}
|
|
99
|
+
let loadingFetch = false;
|
|
100
|
+
async function loadExtraJobs() {
|
|
101
|
+
if (jobs && jobs.length > 0) {
|
|
102
|
+
let minQueueTs = undefined;
|
|
103
|
+
let minCompletedTs = undefined;
|
|
104
|
+
let cursor = 0;
|
|
105
|
+
while (jobs && cursor < jobs?.length) {
|
|
106
|
+
cursor++;
|
|
107
|
+
const job = jobs[jobs.length - 1 - cursor];
|
|
108
|
+
if (job.type == 'CompletedJob') {
|
|
109
|
+
minCompletedTs = job.completed_at;
|
|
110
|
+
break;
|
|
111
|
+
}
|
|
112
|
+
else if (job.type == 'QueuedJob' && minQueueTs == undefined) {
|
|
113
|
+
minQueueTs = job.created_at;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
const ts = minCompletedTs ?? minQueueTs;
|
|
117
|
+
if (!ts) {
|
|
118
|
+
sendUserToast('No jobs to load from');
|
|
119
|
+
lastFetchWentToEnd = false;
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
// const minCreated = lastJob?.created_at
|
|
123
|
+
const minCreated = new Date(new Date(ts).getTime() - 1).toISOString();
|
|
124
|
+
let olderJobs = await fetchJobs(minCreated, minTs, undefined);
|
|
125
|
+
jobs = updateWithNewJobs(olderJobs ?? [], jobs ?? []);
|
|
126
|
+
computeCompletedJobs();
|
|
127
|
+
lastFetchWentToEnd = olderJobs?.length < perPage;
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
lastFetchWentToEnd = false;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
function fetchJobs(completedBefore, completedAfter, createdAfterQueue) {
|
|
134
|
+
if (_args.skip)
|
|
135
|
+
return CancelablePromiseUtils.pure([]);
|
|
136
|
+
loadingFetch = true;
|
|
137
|
+
let scriptPathStart = folder === null || folder === '' ? undefined : `f/${folder}/`;
|
|
138
|
+
let scriptPathExact = path === null || path === '' ? undefined : path;
|
|
139
|
+
let promise = JobService.listJobs({
|
|
140
|
+
workspace: currentWorkspace,
|
|
141
|
+
completedBefore: completedBefore ?? undefined,
|
|
142
|
+
completedAfter: completedAfter ?? undefined,
|
|
143
|
+
createdAfterQueue,
|
|
144
|
+
schedulePath: schedulePath ?? undefined,
|
|
145
|
+
scriptPathExact,
|
|
146
|
+
createdBy: user === null || user === '' ? undefined : user,
|
|
147
|
+
scriptPathStart: scriptPathStart,
|
|
148
|
+
jobKinds: jobKindsCat == 'all' || jobKinds == '' ? undefined : jobKinds,
|
|
149
|
+
success: success == 'success' ? true : success == 'failure' ? false : undefined,
|
|
150
|
+
running: success == 'running' || success == 'suspended'
|
|
151
|
+
? true
|
|
152
|
+
: success == 'waiting'
|
|
153
|
+
? false
|
|
154
|
+
: undefined,
|
|
155
|
+
isSkipped: showSkipped ? undefined : false,
|
|
156
|
+
// isFlowStep: jobKindsCat != 'all' ? false : undefined,
|
|
157
|
+
hasNullParent: jobKindsCat != 'all' ? true : undefined,
|
|
158
|
+
label: label === null || label === '' ? undefined : label,
|
|
159
|
+
tag: tag === null || tag === '' ? undefined : tag,
|
|
160
|
+
worker: worker === null || worker === '' ? undefined : worker,
|
|
161
|
+
isNotSchedule: showSchedules == false ? true : undefined,
|
|
162
|
+
suspended: success == 'waiting' ? false : success == 'suspended' ? true : undefined,
|
|
163
|
+
scheduledForBeforeNow: showFutureJobs == false || success == 'waiting' || success == 'suspended'
|
|
164
|
+
? true
|
|
165
|
+
: undefined,
|
|
166
|
+
args: argFilter && argFilter != '{}' && argFilter != '' && argError == '' ? argFilter : undefined,
|
|
167
|
+
result: resultFilter && resultFilter != '{}' && resultFilter != '' && resultError == ''
|
|
168
|
+
? resultFilter
|
|
169
|
+
: undefined,
|
|
170
|
+
triggerKind: jobTriggerKind ?? undefined,
|
|
171
|
+
allWorkspaces: allWorkspaces ? true : undefined,
|
|
172
|
+
perPage,
|
|
173
|
+
allowWildcards: allowWildcards ? true : undefined
|
|
174
|
+
});
|
|
175
|
+
promise = CancelablePromiseUtils.catchErr(promise, (e) => {
|
|
176
|
+
if (e instanceof CancelError)
|
|
177
|
+
return CancelablePromiseUtils.err(e);
|
|
178
|
+
sendUserToast('There was an issue loading jobs, see browser console for more details', true);
|
|
179
|
+
console.error(e);
|
|
180
|
+
return CancelablePromiseUtils.pure([]);
|
|
181
|
+
});
|
|
182
|
+
CancelablePromiseUtils.pipe(promise, () => {
|
|
183
|
+
loadingFetch = false;
|
|
184
|
+
});
|
|
185
|
+
return promise;
|
|
186
|
+
}
|
|
187
|
+
function fetchExtendedJobs(concurrencyKey, createdBeforeQueue, completedAfter) {
|
|
188
|
+
if (_args.skip)
|
|
189
|
+
return CancelablePromiseUtils.pure({ jobs: [], obscured_jobs: [] });
|
|
190
|
+
loadingFetch = true;
|
|
191
|
+
let promise = ConcurrencyGroupsService.listExtendedJobs({
|
|
192
|
+
rowLimit: perPage,
|
|
193
|
+
concurrencyKey: concurrencyKey == null || concurrencyKey == '' ? undefined : concurrencyKey,
|
|
194
|
+
workspace: currentWorkspace,
|
|
195
|
+
completedAfter: completedAfter ?? undefined,
|
|
196
|
+
createdBeforeQueue: createdBeforeQueue ?? undefined,
|
|
197
|
+
// createdOrStartedBefore: startedBefore,
|
|
198
|
+
// createdOrStartedAfter: startedAfter,
|
|
199
|
+
// createdOrStartedAfterCompletedJobs: startedAfterCompletedJobs,
|
|
200
|
+
schedulePath: schedulePath ?? undefined,
|
|
201
|
+
scriptPathExact: path === null || path === '' ? undefined : path,
|
|
202
|
+
createdBy: user === null || user === '' ? undefined : user,
|
|
203
|
+
scriptPathStart: folder === null || folder === '' ? undefined : `f/${folder}/`,
|
|
204
|
+
jobKinds: jobKindsCat == 'all' || jobKinds == '' ? undefined : jobKinds,
|
|
205
|
+
success: success == 'success' ? true : success == 'failure' ? false : undefined,
|
|
206
|
+
running: success == 'running' ? true : undefined,
|
|
207
|
+
isSkipped: showSkipped ? undefined : false,
|
|
208
|
+
isFlowStep: jobKindsCat != 'all' ? false : undefined,
|
|
209
|
+
label: label === null || label === '' ? undefined : label,
|
|
210
|
+
tag: tag === null || tag === '' ? undefined : tag,
|
|
211
|
+
isNotSchedule: showSchedules == false ? true : undefined,
|
|
212
|
+
scheduledForBeforeNow: showFutureJobs == false ? true : undefined,
|
|
213
|
+
args: argFilter && argFilter != '{}' && argFilter != '' && argError == '' ? argFilter : undefined,
|
|
214
|
+
result: resultFilter && resultFilter != '{}' && resultFilter != '' && resultError == ''
|
|
215
|
+
? resultFilter
|
|
216
|
+
: undefined,
|
|
217
|
+
triggerKind: jobTriggerKind ?? undefined,
|
|
218
|
+
allWorkspaces: allWorkspaces ? true : undefined,
|
|
219
|
+
perPage,
|
|
220
|
+
allowWildcards
|
|
221
|
+
});
|
|
222
|
+
promise = CancelablePromiseUtils.catchErr(promise, (e) => {
|
|
223
|
+
sendUserToast('There was an issue loading jobs, see browser console for more details', true);
|
|
224
|
+
console.error(e);
|
|
225
|
+
return CancelablePromiseUtils.pure({ jobs: [], obscured_jobs: [] });
|
|
226
|
+
});
|
|
227
|
+
promise = CancelablePromiseUtils.pipe(promise, () => {
|
|
228
|
+
loadingFetch = false;
|
|
229
|
+
});
|
|
230
|
+
return promise;
|
|
231
|
+
}
|
|
232
|
+
async function loadJobs(reset, shouldGetCount) {
|
|
233
|
+
if (reset)
|
|
234
|
+
resetJobs();
|
|
235
|
+
await loadJobsIntern(shouldGetCount);
|
|
236
|
+
}
|
|
237
|
+
function resetJobs() {
|
|
238
|
+
jobs = undefined;
|
|
239
|
+
completedJobs = undefined;
|
|
240
|
+
externalJobs = undefined;
|
|
241
|
+
extendedJobs = undefined;
|
|
242
|
+
lastFetchWentToEnd = false;
|
|
243
|
+
intervalId && clearInterval(intervalId);
|
|
244
|
+
intervalId = setInterval(syncer, refreshRate);
|
|
245
|
+
}
|
|
246
|
+
function loadJobsIntern(shouldGetCount) {
|
|
247
|
+
if (shouldGetCount) {
|
|
248
|
+
getCount();
|
|
249
|
+
}
|
|
250
|
+
loading = true;
|
|
251
|
+
// Extend MinTs to fetch jobs mefore minTs and show a correct concurrency graph
|
|
252
|
+
// TODO: when an ended_at column is created on the completed_job table,
|
|
253
|
+
// lookback won't be needed anymore (just filter ended_at > minTs instead
|
|
254
|
+
const extendedMinTs = subtractDaysFromDateString(minTs, lookback);
|
|
255
|
+
if (concurrencyKey == null || concurrencyKey === '') {
|
|
256
|
+
return CancelablePromiseUtils.map(fetchJobs(maxTs, null, extendedMinTs), (newJobs) => {
|
|
257
|
+
extendedJobs = { jobs: newJobs, obscured_jobs: [] };
|
|
258
|
+
// Filter on minTs here and not in the backend
|
|
259
|
+
// to get enough data for the concurrency graph
|
|
260
|
+
jobs = sortMinDate(minTs, newJobs);
|
|
261
|
+
externalJobs = [];
|
|
262
|
+
computeCompletedJobs();
|
|
263
|
+
loading = false;
|
|
264
|
+
});
|
|
265
|
+
}
|
|
266
|
+
else {
|
|
267
|
+
return CancelablePromiseUtils.map(fetchExtendedJobs(concurrencyKey, maxTs, extendedMinTs ?? null), (newExtendedJobs) => {
|
|
268
|
+
extendedJobs = newExtendedJobs;
|
|
269
|
+
const newJobs = newExtendedJobs.jobs;
|
|
270
|
+
const newExternalJobs = newExtendedJobs.obscured_jobs;
|
|
271
|
+
// Filter on minTs here and not in the backend
|
|
272
|
+
// to get enough data for the concurrency graph
|
|
273
|
+
if (minTs != undefined) {
|
|
274
|
+
const minDate = new Date(minTs);
|
|
275
|
+
jobs = newJobs.filter((x) => x.started_at
|
|
276
|
+
? new Date(x.started_at) > minDate
|
|
277
|
+
: x.created_at
|
|
278
|
+
? new Date(x.created_at) > minDate
|
|
279
|
+
: false);
|
|
280
|
+
externalJobs = computeExternalJobs(newExternalJobs.filter((x) => x.started_at && new Date(x.started_at) > minDate));
|
|
281
|
+
}
|
|
282
|
+
else {
|
|
283
|
+
jobs = newJobs;
|
|
284
|
+
externalJobs = computeExternalJobs(newExternalJobs);
|
|
285
|
+
}
|
|
286
|
+
computeCompletedJobs();
|
|
287
|
+
loading = false;
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
async function getCount() {
|
|
292
|
+
if (_args.skip)
|
|
293
|
+
return;
|
|
294
|
+
const { database_length, suspended } = await JobService.getQueueCount({
|
|
295
|
+
workspace: currentWorkspace,
|
|
296
|
+
allWorkspaces
|
|
297
|
+
});
|
|
298
|
+
if (queue_count) {
|
|
299
|
+
queue_count.set(database_length);
|
|
300
|
+
}
|
|
301
|
+
else {
|
|
302
|
+
queue_count = tweened(database_length, { duration: 1000 });
|
|
303
|
+
}
|
|
304
|
+
if (suspended_count) {
|
|
305
|
+
suspended_count.set(suspended ?? 0);
|
|
306
|
+
}
|
|
307
|
+
else {
|
|
308
|
+
suspended_count = tweened(suspended ?? 0, { duration: 1000 });
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
let lastQueueTs = undefined;
|
|
312
|
+
async function syncer() {
|
|
313
|
+
if (success == 'waiting') {
|
|
314
|
+
onSetMinMaxTs?.(null, null);
|
|
315
|
+
}
|
|
316
|
+
if (loadingFetch) {
|
|
317
|
+
return;
|
|
318
|
+
}
|
|
319
|
+
if (sync) {
|
|
320
|
+
if (syncQueuedRunsCount) {
|
|
321
|
+
getCount();
|
|
322
|
+
}
|
|
323
|
+
const ts = computeMinAndMax?.();
|
|
324
|
+
if (ts) {
|
|
325
|
+
onSetMinMaxTs?.(ts.minTs, ts.maxTs);
|
|
326
|
+
if (maxTs != undefined) {
|
|
327
|
+
loadJobsIntern(false);
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
if (jobs && maxTs == undefined) {
|
|
331
|
+
if (success == 'running') {
|
|
332
|
+
loadJobsIntern(false);
|
|
333
|
+
}
|
|
334
|
+
else {
|
|
335
|
+
let minQueueCreatedAt = undefined;
|
|
336
|
+
let completedTs = null;
|
|
337
|
+
let cursor = 0;
|
|
338
|
+
if (minTs == undefined) {
|
|
339
|
+
while (cursor < jobs.length) {
|
|
340
|
+
const cjob = jobs[cursor];
|
|
341
|
+
if (cjob.type == 'QueuedJob') {
|
|
342
|
+
minQueueCreatedAt = cjob.created_at;
|
|
343
|
+
}
|
|
344
|
+
else if (cjob.type == 'CompletedJob' && completedTs == undefined) {
|
|
345
|
+
completedTs = new Date(cjob.completed_at).toISOString();
|
|
346
|
+
}
|
|
347
|
+
cursor++;
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
let queueTs;
|
|
351
|
+
if (minQueueCreatedAt) {
|
|
352
|
+
const queueTs = new Date(minQueueCreatedAt).toISOString();
|
|
353
|
+
lastQueueTs = queueTs;
|
|
354
|
+
}
|
|
355
|
+
else {
|
|
356
|
+
queueTs = lastQueueTs;
|
|
357
|
+
}
|
|
358
|
+
loading = true;
|
|
359
|
+
let newJobs;
|
|
360
|
+
if (concurrencyKey == null || concurrencyKey === '') {
|
|
361
|
+
newJobs = await fetchJobs(maxTs, minTs ?? completedTs, queueTs);
|
|
362
|
+
}
|
|
363
|
+
else {
|
|
364
|
+
// Obscured jobs have no ids, so we have to do the full request
|
|
365
|
+
extendedJobs = await fetchExtendedJobs(concurrencyKey, maxTs, minTs ?? completedTs);
|
|
366
|
+
externalJobs = computeExternalJobs(extendedJobs.obscured_jobs);
|
|
367
|
+
// Filter on minTs here and not in the backend
|
|
368
|
+
// to get enough data for the concurrency graph
|
|
369
|
+
newJobs = sortMinDate(minTs ?? completedTs, extendedJobs.jobs);
|
|
370
|
+
}
|
|
371
|
+
if (newJobs && newJobs.length > 0 && jobs) {
|
|
372
|
+
jobs = updateWithNewJobs(jobs, newJobs);
|
|
373
|
+
if (concurrencyKey == null || concurrencyKey === '') {
|
|
374
|
+
if (!extendedJobs) {
|
|
375
|
+
extendedJobs = { jobs: jobs, obscured_jobs: [] };
|
|
376
|
+
}
|
|
377
|
+
else {
|
|
378
|
+
extendedJobs.jobs = updateWithNewJobs(extendedJobs.jobs, newJobs);
|
|
379
|
+
extendedJobs = extendedJobs;
|
|
380
|
+
}
|
|
381
|
+
externalJobs = [];
|
|
382
|
+
}
|
|
383
|
+
computeCompletedJobs();
|
|
384
|
+
}
|
|
385
|
+
loading = false;
|
|
386
|
+
}
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
function updateWithNewJobs(jobs, newJobs) {
|
|
391
|
+
const oldJobs = jobs?.map((x) => x.id);
|
|
392
|
+
let ret = newJobs.filter((x) => !oldJobs.includes(x.id)).concat(jobs);
|
|
393
|
+
newJobs
|
|
394
|
+
.filter((x) => oldJobs.includes(x.id))
|
|
395
|
+
.forEach((x) => (ret[ret?.findIndex((y) => y.id == x.id)] = x));
|
|
396
|
+
return ret;
|
|
397
|
+
}
|
|
398
|
+
function sortMinDate(minTs, jobs) {
|
|
399
|
+
if (minTs) {
|
|
400
|
+
const minDate = new Date(minTs);
|
|
401
|
+
return jobs.filter((x) => x.started_at
|
|
402
|
+
? new Date(x.started_at) > minDate
|
|
403
|
+
: x.created_at
|
|
404
|
+
? new Date(x.created_at) > minDate
|
|
405
|
+
: false);
|
|
406
|
+
}
|
|
407
|
+
else {
|
|
408
|
+
return jobs;
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
function computeCompletedJobs() {
|
|
412
|
+
completedJobs =
|
|
413
|
+
jobs?.filter((x) => x.type == 'CompletedJob').map((x) => x) ?? [];
|
|
414
|
+
}
|
|
415
|
+
function onVisibilityChange() {
|
|
416
|
+
if (document.hidden) {
|
|
417
|
+
sync = false;
|
|
418
|
+
}
|
|
419
|
+
else {
|
|
420
|
+
sync = true;
|
|
421
|
+
}
|
|
422
|
+
}
|
|
423
|
+
function computeExternalJobs(obscuredJobs) {
|
|
424
|
+
return obscuredJobs.map((x) => ({
|
|
425
|
+
type: x.typ,
|
|
426
|
+
started_at: x.started_at,
|
|
427
|
+
running: x.started_at != undefined,
|
|
428
|
+
id: '-',
|
|
429
|
+
script_path: '-',
|
|
430
|
+
created_by: '-',
|
|
431
|
+
created_at: '-',
|
|
432
|
+
success: false,
|
|
433
|
+
canceled: false,
|
|
434
|
+
is_flow_step: false,
|
|
435
|
+
is_skipped: false,
|
|
436
|
+
visible_to_owner: false,
|
|
437
|
+
email: '-',
|
|
438
|
+
permissioned_as: '-',
|
|
439
|
+
tag: '-',
|
|
440
|
+
job_kind: 'script',
|
|
441
|
+
duration_ms: x.duration_ms
|
|
442
|
+
}));
|
|
443
|
+
}
|
|
444
|
+
onMount(() => {
|
|
445
|
+
document.addEventListener('visibilitychange', onVisibilityChange);
|
|
446
|
+
return () => {
|
|
447
|
+
window.removeEventListener('visibilitychange', onVisibilityChange);
|
|
448
|
+
};
|
|
449
|
+
});
|
|
450
|
+
onDestroy(() => {
|
|
451
|
+
sync = false;
|
|
452
|
+
if (intervalId) {
|
|
453
|
+
clearInterval(intervalId);
|
|
454
|
+
}
|
|
455
|
+
});
|
|
456
|
+
$effect(() => {
|
|
457
|
+
Object.keys(filters ?? {}).map((k) => filters?.[k]);
|
|
458
|
+
let p = untrack(() => onParamChanges());
|
|
459
|
+
return () => p.cancel();
|
|
460
|
+
});
|
|
461
|
+
$effect(() => {
|
|
462
|
+
;
|
|
463
|
+
[autoRefresh, refreshRate];
|
|
464
|
+
untrack(() => {
|
|
465
|
+
if (!intervalId && autoRefresh) {
|
|
466
|
+
intervalId = setInterval(syncer, refreshRate);
|
|
467
|
+
}
|
|
468
|
+
});
|
|
469
|
+
});
|
|
470
|
+
$effect(() => {
|
|
471
|
+
autoRefresh;
|
|
472
|
+
untrack(() => {
|
|
473
|
+
if (intervalId && !autoRefresh) {
|
|
474
|
+
clearInterval(intervalId);
|
|
475
|
+
intervalId = undefined;
|
|
476
|
+
}
|
|
477
|
+
});
|
|
478
|
+
});
|
|
479
|
+
return {
|
|
480
|
+
loadExtraJobs,
|
|
481
|
+
loadJobs,
|
|
482
|
+
get queue_count() {
|
|
483
|
+
return queue_count;
|
|
484
|
+
},
|
|
485
|
+
get suspended_count() {
|
|
486
|
+
return suspended_count;
|
|
487
|
+
},
|
|
488
|
+
get loading() {
|
|
489
|
+
return loading;
|
|
490
|
+
},
|
|
491
|
+
get completedJobs() {
|
|
492
|
+
return completedJobs;
|
|
493
|
+
},
|
|
494
|
+
get externalJobs() {
|
|
495
|
+
return externalJobs;
|
|
496
|
+
},
|
|
497
|
+
get extendedJobs() {
|
|
498
|
+
return extendedJobs;
|
|
499
|
+
},
|
|
500
|
+
get jobs() {
|
|
501
|
+
return jobs;
|
|
502
|
+
},
|
|
503
|
+
get lastFetchWentToEnd() {
|
|
504
|
+
return lastFetchWentToEnd;
|
|
505
|
+
}
|
|
506
|
+
};
|
|
507
|
+
}
|
|
@@ -111,9 +111,9 @@ let suggestedFileExtensions = $state([
|
|
|
111
111
|
{#if resourceIsTextFile}
|
|
112
112
|
<label
|
|
113
113
|
for="format-extension"
|
|
114
|
-
class="text-
|
|
114
|
+
class="text-xs font-semibold text-emphasis whitespace-nowrap flex items-center gap-4"
|
|
115
115
|
>
|
|
116
|
-
File extension
|
|
116
|
+
File extension:
|
|
117
117
|
<Select
|
|
118
118
|
autofocus
|
|
119
119
|
items={safeSelectItems(suggestedFileExtensions)}
|
|
@@ -14,13 +14,14 @@ import { Pane, Splitpanes } from 'svelte-splitpanes';
|
|
|
14
14
|
import SplitPanesWrapper from '../splitPanes/SplitPanesWrapper.svelte';
|
|
15
15
|
import { CheckCircle2, Loader2, XCircle } from 'lucide-svelte';
|
|
16
16
|
import ScriptFix from '../copilot/ScriptFix.svelte';
|
|
17
|
+
import JobOtelTraces from '../JobOtelTraces.svelte';
|
|
17
18
|
import Cell from '../table/Cell.svelte';
|
|
18
19
|
import DataTable from '../table/DataTable.svelte';
|
|
19
20
|
import Head from '../table/Head.svelte';
|
|
20
21
|
import WorkflowTimeline from '../WorkflowTimeline.svelte';
|
|
21
22
|
import Tooltip from '../Tooltip.svelte';
|
|
22
23
|
import { getStringError } from '../copilot/chat/utils';
|
|
23
|
-
let { lang, previewIsLoading = false, previewJob, pastPreviews = [], editor = undefined, diffEditor = undefined, args = undefined, workspace = undefined, showCaptures = false, customUi = undefined, children, capturesTab } = $props();
|
|
24
|
+
let { lang, previewIsLoading = false, previewJob, pastPreviews = [], editor = undefined, diffEditor = undefined, args = undefined, workspace = undefined, showCaptures = false, customUi = undefined, children, capturesTab, customResultPanel, showCustomResultPanel = false } = $props();
|
|
24
25
|
let selectedTab = $state('logs');
|
|
25
26
|
let drawerOpen = $state(false);
|
|
26
27
|
let drawerContent = $state(undefined);
|
|
@@ -70,6 +71,7 @@ let forceJson = $state(false);
|
|
|
70
71
|
{#if showCaptures && customUi?.disableTriggerCaptures !== true}
|
|
71
72
|
<Tab value="captures" label="Trigger captures" />
|
|
72
73
|
{/if}
|
|
74
|
+
<Tab value="tracing" label="Tracing" />
|
|
73
75
|
|
|
74
76
|
{#snippet content()}
|
|
75
77
|
<div class="grow min-h-0">
|
|
@@ -98,7 +100,11 @@ let forceJson = $state(false);
|
|
|
98
100
|
</Pane>
|
|
99
101
|
<Pane>
|
|
100
102
|
{@render children?.()}
|
|
101
|
-
{#if
|
|
103
|
+
{#if showCustomResultPanel && customResultPanel}
|
|
104
|
+
<div class="h-full">
|
|
105
|
+
{@render customResultPanel()}
|
|
106
|
+
</div>
|
|
107
|
+
{:else if previewJob != undefined && (previewJob.result_stream || previewJob.result)}
|
|
102
108
|
<div class="relative w-full h-full p-2">
|
|
103
109
|
<div class="relative h-full">
|
|
104
110
|
<DisplayResult
|
|
@@ -237,6 +243,15 @@ let forceJson = $state(false);
|
|
|
237
243
|
{#if selectedTab === 'captures'}
|
|
238
244
|
{@render capturesTab?.()}
|
|
239
245
|
{/if}
|
|
246
|
+
{#if selectedTab === 'tracing'}
|
|
247
|
+
{#if previewJob?.id}
|
|
248
|
+
<JobOtelTraces jobId={previewJob.id} />
|
|
249
|
+
{:else}
|
|
250
|
+
<div class="p-4 text-secondary">
|
|
251
|
+
Run a preview to see HTTP request traces
|
|
252
|
+
</div>
|
|
253
|
+
{/if}
|
|
254
|
+
{/if}
|
|
240
255
|
</div>
|
|
241
256
|
{/snippet}
|
|
242
257
|
</Tabs>
|
|
@@ -19,6 +19,8 @@ interface Props {
|
|
|
19
19
|
customUi?: PreviewPanelUi | undefined;
|
|
20
20
|
children?: import('svelte').Snippet;
|
|
21
21
|
capturesTab?: import('svelte').Snippet;
|
|
22
|
+
customResultPanel?: import('svelte').Snippet;
|
|
23
|
+
showCustomResultPanel?: boolean;
|
|
22
24
|
}
|
|
23
25
|
declare const LogPanel: import("svelte").Component<Props, {
|
|
24
26
|
setFocusToLogs: () => void;
|
|
@@ -90,7 +90,7 @@ export function getFilteredInputText() {
|
|
|
90
90
|
{#if allowClear && !hideMainClearBtn && !!value?.length}
|
|
91
91
|
<CloseButton
|
|
92
92
|
noBg
|
|
93
|
-
class="
|
|
93
|
+
class="ml-2 remove-all bg-transparent text-hint"
|
|
94
94
|
small
|
|
95
95
|
on:close={(e) => (clearValue(), e.stopPropagation())}
|
|
96
96
|
/>
|
|
@@ -3,6 +3,8 @@ import ConditionalPortal from '../common/drawer/ConditionalPortal.svelte';
|
|
|
3
3
|
import { untrack } from 'svelte';
|
|
4
4
|
import { twMerge } from 'tailwind-merge';
|
|
5
5
|
import { PlusIcon } from 'lucide-svelte';
|
|
6
|
+
import { useReducedMotion } from '../../svelte5Utils.svelte';
|
|
7
|
+
import { watch } from 'runed';
|
|
6
8
|
let { processedItems: _processedItems, value, filterText, listAutoWidth = true, disabled, disablePortal = false, open, noItemsMsg = 'No items found', class: className = '', ulClass = '', itemLabelWrapperClasses = '', itemButtonWrapperClasses = '', header, getInputRect, onSelectValue, startSnippet, endSnippet, bottomSnippet } = $props();
|
|
7
9
|
let processedItems = $derived(!filterText
|
|
8
10
|
? _processedItems
|
|
@@ -10,6 +12,7 @@ let processedItems = $derived(!filterText
|
|
|
10
12
|
let listEl = $state();
|
|
11
13
|
let dropdownPos = $state(computeDropdownPos());
|
|
12
14
|
let keyArrowPos = $state();
|
|
15
|
+
let reducedMotion = useReducedMotion();
|
|
13
16
|
function computeDropdownPos() {
|
|
14
17
|
if (!getInputRect || !listEl)
|
|
15
18
|
return { width: 0, height: 0, x: 0, y: 0, isBelow: true };
|
|
@@ -47,13 +50,20 @@ $effect(() => {
|
|
|
47
50
|
// Also CSS transitions are smoother because they do not rely on JS / animation frames
|
|
48
51
|
let uiState = $state({ domExists: open, visible: open, timeout: null });
|
|
49
52
|
let initial = true;
|
|
50
|
-
|
|
51
|
-
let isOpen = open && !disabled;
|
|
53
|
+
watch(() => open && !disabled, (isOpen) => {
|
|
52
54
|
untrack(() => {
|
|
53
55
|
if (initial) {
|
|
54
56
|
initial = false;
|
|
55
57
|
return;
|
|
56
58
|
}
|
|
59
|
+
if (reducedMotion.val) {
|
|
60
|
+
uiState = {
|
|
61
|
+
domExists: open && !disabled,
|
|
62
|
+
visible: open && !disabled,
|
|
63
|
+
timeout: null
|
|
64
|
+
};
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
57
67
|
if (uiState.timeout)
|
|
58
68
|
clearTimeout(uiState.timeout);
|
|
59
69
|
uiState = {
|
|
@@ -102,8 +112,9 @@ $effect(() => {
|
|
|
102
112
|
{#if uiState.domExists}
|
|
103
113
|
<div
|
|
104
114
|
class={twMerge(
|
|
105
|
-
|
|
106
|
-
'z-[5002]
|
|
115
|
+
open ? 'select-dropdown-open' : 'select-dropdown-closed',
|
|
116
|
+
disablePortal ? 'absolute z-[5002]' : 'fixed z-[10000]',
|
|
117
|
+
'text-primary text-sm select-none',
|
|
107
118
|
dropdownPos.isBelow ? '' : 'flex flex-col justify-end',
|
|
108
119
|
uiState.visible ? '' : 'pointer-events-none',
|
|
109
120
|
className
|
|
@@ -114,7 +125,8 @@ $effect(() => {
|
|
|
114
125
|
>
|
|
115
126
|
<div
|
|
116
127
|
class={twMerge(
|
|
117
|
-
'overflow-clip rounded-md drop-shadow-base
|
|
128
|
+
'overflow-clip rounded-md drop-shadow-base',
|
|
129
|
+
!reducedMotion.val ? 'transition-height' : '',
|
|
118
130
|
dropdownPos.isBelow ? '' : 'flex flex-col justify-end'
|
|
119
131
|
)}
|
|
120
132
|
style="height: {uiState.visible ? dropdownPos.height : 0}px;"
|