windmill-components 1.655.1 → 1.665.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/components/ApiConnectForm.svelte +6 -6
- package/package/components/ApiConnectForm.svelte.d.ts +3 -2
- package/package/components/AppConnectDrawer.svelte +3 -1
- package/package/components/AppConnectDrawer.svelte.d.ts +2 -0
- package/package/components/AppConnectInner.svelte +137 -72
- package/package/components/AppConnectInner.svelte.d.ts +1 -0
- package/package/components/CompareWorkspaces.svelte +32 -24
- package/package/components/DBManager.svelte +7 -13
- package/package/components/DBTable.svelte +2 -2
- package/package/components/DBTableEditor.svelte +39 -31
- package/package/components/DBTableEditor.svelte.d.ts +2 -2
- package/package/components/DedicatedWorkersSelector.svelte +292 -85
- package/package/components/DeployWorkspace.svelte +30 -26
- package/package/components/Dev.svelte +7 -2
- package/package/components/Dev.svelte.d.ts +3 -0
- package/package/components/Editor.svelte +17 -13
- package/package/components/EditorBar.svelte.d.ts +1 -1
- package/package/components/FilterSearchbar.svelte +1 -1
- package/package/components/FirstStepInputs.svelte +0 -1
- package/package/components/FlowBuilder.svelte +5 -0
- package/package/components/FlowGraphDiffViewer.svelte +3 -0
- package/package/components/FlowGraphViewer.svelte +7 -4
- package/package/components/FlowGraphViewer.svelte.d.ts +1 -0
- package/package/components/FlowGraphViewerStep.svelte +3 -3
- package/package/components/FlowGraphViewerStep.svelte.d.ts +1 -0
- package/package/components/FlowPreviewContent.svelte +11 -1
- package/package/components/FlowStatusViewer.svelte +4 -1
- package/package/components/FlowStatusViewer.svelte.d.ts +3 -1
- package/package/components/FlowStatusViewerInner.svelte +46 -11
- package/package/components/FlowStatusViewerInner.svelte.d.ts +4 -1
- package/package/components/FlowStatusWaitingForEvents.svelte +48 -103
- package/package/components/FlowTimeline.svelte +76 -84
- package/package/components/FlowViewer.svelte +40 -22
- package/package/components/FlowViewer.svelte.d.ts +8 -2
- package/package/components/GroupEditor.svelte +7 -9
- package/package/components/HistoricList.svelte +12 -4
- package/package/components/InstanceGroupEditor.svelte +92 -19
- package/package/components/InstanceSetting.svelte +16 -6
- package/package/components/InstanceSettings.svelte +51 -7
- package/package/components/InstanceSettings.svelte.d.ts +2 -1
- package/package/components/JobLoader.svelte +5 -4
- package/package/components/JobLoader.svelte.d.ts +1 -1
- package/package/components/Login.svelte +9 -1
- package/package/components/NoMainFuncBadge.svelte +2 -2
- package/package/components/OnBehalfOfSelector.svelte +49 -37
- package/package/components/OnBehalfOfSelector.svelte.d.ts +16 -6
- package/package/components/ResourceEditor.svelte +16 -11
- package/package/components/ResourceEditor.svelte.d.ts +1 -0
- package/package/components/ResourceEditorDrawer.svelte +3 -1
- package/package/components/ResourceEditorDrawer.svelte.d.ts +6 -2
- package/package/components/ResourcePicker.svelte +10 -5
- package/package/components/ResourcePicker.svelte.d.ts +2 -0
- package/package/components/S3FilePickerInner.svelte +12 -4
- package/package/components/SchemaForm.svelte +20 -14
- package/package/components/SchemaForm.svelte.d.ts +2 -2
- package/package/components/ScriptBuilder.svelte +158 -18
- package/package/components/ScriptEditor.svelte +674 -150
- package/package/components/ScriptEditor.svelte.d.ts +7 -3
- package/package/components/SuperadminSettings.svelte +4 -1
- package/package/components/SuperadminSettingsInner.svelte +176 -67
- package/package/components/SuperadminSettingsInner.svelte.d.ts +3 -1
- package/package/components/SyncResourceTypes.svelte +31 -0
- package/package/components/SyncResourceTypes.svelte.d.ts +6 -0
- package/package/components/TimelineBar.svelte +14 -8
- package/package/components/TimelineBar.svelte.d.ts +1 -0
- package/package/components/WorkerGroup.svelte +11 -4
- package/package/components/WorkflowTimeline.svelte +386 -58
- package/package/components/WorkflowTimeline.svelte.d.ts +6 -1
- package/package/components/WorkspaceDependenciesEditor.svelte +32 -2
- package/package/components/apps/components/display/dbtable/DeleteRow.svelte +2 -2
- package/package/components/apps/components/display/dbtable/InsertRowRunnable.svelte +2 -2
- package/package/components/apps/components/display/dbtable/UpdateCell.svelte +2 -2
- package/package/components/apps/components/display/dbtable/metadata.js +44 -222
- package/package/components/apps/components/display/dbtable/queries/count.d.ts +9 -0
- package/package/components/apps/components/display/dbtable/queries/delete.d.ts +9 -0
- package/package/components/apps/components/display/dbtable/queries/insert.d.ts +9 -0
- package/package/components/apps/components/display/dbtable/queries/relationalKeys.d.ts +7 -0
- package/package/components/apps/components/display/dbtable/queries/relationalKeys.js +1 -1
- package/package/components/apps/components/display/dbtable/queries/select.d.ts +9 -0
- package/package/components/apps/components/display/dbtable/queries/update.d.ts +9 -0
- package/package/components/apps/editor/AppEditorHeaderDeploy.svelte +11 -9
- package/package/components/apps/editor/appUtilsS3.js +2 -2
- package/package/components/apps/editor/inlineScriptsPanel/InlineScriptsPanel.svelte +53 -10
- package/package/components/common/clearableInput/ClearableInput.svelte +3 -7
- package/package/components/common/confirmationModal/ConfirmationModal.svelte +7 -1
- package/package/components/common/confirmationModal/ConfirmationModal.svelte.d.ts +1 -0
- package/package/components/common/drawer/Disposable.svelte +24 -2
- package/package/components/common/drawer/Disposable.svelte.d.ts +5 -0
- package/package/components/common/modal/Modal.svelte +84 -58
- package/package/components/common/table/AppRow.svelte.d.ts +1 -1
- package/package/components/common/table/FlowRow.svelte.d.ts +1 -1
- package/package/components/common/table/ScriptRow.svelte +31 -3
- package/package/components/common/table/ScriptRow.svelte.d.ts +1 -1
- package/package/components/copilot/MetadataGen.svelte +8 -5
- package/package/components/copilot/MetadataGen.svelte.d.ts +1 -0
- package/package/components/copilot/TestAIKey.svelte +2 -1
- package/package/components/copilot/TestAIKey.svelte.d.ts +1 -0
- package/package/components/copilot/chat/AIChatManager.svelte.js +62 -80
- package/package/components/copilot/chat/HistoryManager.svelte.d.ts +1 -0
- package/package/components/copilot/chat/HistoryManager.svelte.js +3 -0
- package/package/components/copilot/chat/__tests__/app/appChat.eval.test.js +47 -31
- package/package/components/copilot/chat/__tests__/app/appEvalComparison.d.ts +1 -6
- package/package/components/copilot/chat/__tests__/app/appEvalComparison.js +18 -13
- package/package/components/copilot/chat/__tests__/app/appEvalRunner.d.ts +14 -5
- package/package/components/copilot/chat/__tests__/app/appEvalRunner.js +13 -12
- package/package/components/copilot/chat/__tests__/flow/flowChat.eval.test.js +46 -29
- package/package/components/copilot/chat/__tests__/flow/flowEvalComparison.js +1 -4
- package/package/components/copilot/chat/__tests__/flow/flowEvalRunner.d.ts +14 -5
- package/package/components/copilot/chat/__tests__/flow/flowEvalRunner.js +13 -12
- package/package/components/copilot/chat/__tests__/shared/baseEvalRunner.d.ts +5 -8
- package/package/components/copilot/chat/__tests__/shared/baseEvalRunner.js +82 -108
- package/package/components/copilot/chat/__tests__/shared/baseLLMEvaluator.d.ts +4 -7
- package/package/components/copilot/chat/__tests__/shared/baseLLMEvaluator.js +19 -11
- package/package/components/copilot/chat/__tests__/shared/types.d.ts +3 -0
- package/package/components/copilot/chat/anthropic.d.ts +9 -2
- package/package/components/copilot/chat/anthropic.js +12 -6
- package/package/components/copilot/chat/app/core.js +5 -12
- package/package/components/copilot/chat/chatLoop.d.ts +40 -0
- package/package/components/copilot/chat/chatLoop.js +97 -0
- package/package/components/copilot/chat/openai-responses.d.ts +8 -2
- package/package/components/copilot/chat/openai-responses.js +17 -17
- package/package/components/copilot/chat/shared.d.ts +2 -1
- package/package/components/copilot/chat/shared.js +2 -2
- package/package/components/copilot/lib.d.ts +14 -5
- package/package/components/copilot/lib.js +68 -48
- package/package/components/custom_ui.d.ts +1 -0
- package/package/components/dbOps.d.ts +2 -2
- package/package/components/dbOps.js +129 -53
- package/package/components/debug/debugUtils.d.ts +5 -0
- package/package/components/debug/debugUtils.js +20 -0
- package/package/components/debug/index.d.ts +1 -1
- package/package/components/debug/index.js +3 -7
- package/package/components/flows/CreateActionsFlow.svelte +221 -43
- package/package/components/flows/DebounceLimit.svelte +42 -9
- package/package/components/flows/common/FlowCard.svelte +2 -1
- package/package/components/flows/common/FlowCard.svelte.d.ts +1 -0
- package/package/components/flows/common/FlowCardHeader.svelte +14 -10
- package/package/components/flows/common/FlowCardHeader.svelte.d.ts +1 -0
- package/package/components/flows/content/AgentToolWrapper.svelte +2 -1
- package/package/components/flows/content/AgentToolWrapper.svelte.d.ts +1 -0
- package/package/components/flows/content/FlowEditorPanel.svelte +1 -0
- package/package/components/flows/content/FlowInputs.svelte +1 -1
- package/package/components/flows/content/FlowInputsQuick.svelte +1 -1
- package/package/components/flows/content/FlowModuleComponent.svelte +32 -18
- package/package/components/flows/content/FlowModuleComponent.svelte.d.ts +1 -0
- package/package/components/flows/content/FlowModuleDebounce.svelte +46 -0
- package/package/components/flows/content/FlowModuleDebounce.svelte.d.ts +8 -0
- package/package/components/flows/content/FlowModuleEarlyStop.svelte +26 -5
- package/package/components/flows/content/FlowModuleWrapper.svelte +1 -0
- package/package/components/flows/content/FlowRetries.svelte +57 -57
- package/package/components/flows/content/FlowSelectionPanel.svelte +9 -14
- package/package/components/flows/content/FlowSelectionPanel.svelte.d.ts +1 -0
- package/package/components/flows/content/FlowSettings.svelte +6 -6
- package/package/components/flows/content/ScriptEditorDrawer.svelte +1 -1
- package/package/components/flows/content/SuspendDrawer.svelte +0 -18
- package/package/components/flows/header/FlowYamlEditor.svelte +20 -4
- package/package/components/flows/map/FlowErrorHandlerItem.svelte +32 -14
- package/package/components/flows/map/FlowErrorHandlerItem.svelte.d.ts +1 -0
- package/package/components/flows/map/FlowModuleSchemaItem.svelte +7 -10
- package/package/components/flows/map/FlowModuleSchemaItemViewer.svelte +1 -8
- package/package/components/flows/map/FlowModuleSchemaItemViewer.svelte.d.ts +0 -2
- package/package/components/flows/map/FlowModuleSchemaMap.svelte +343 -137
- package/package/components/flows/map/FlowModuleSchemaMap.svelte.d.ts +1 -0
- package/package/components/flows/map/FlowStickyNode.svelte +24 -16
- package/package/components/flows/map/FlowStickyNode.svelte.d.ts +1 -0
- package/package/components/flows/map/InsertModuleInner.svelte +2 -0
- package/package/components/flows/map/VirtualItemWrapper.svelte +1 -1
- package/package/components/flows/pickers/PickHubScriptQuick.svelte.d.ts +1 -1
- package/package/components/flows/propPicker/OutputPickerInner.svelte +5 -1
- package/package/components/flows/scheduleUtils.js +3 -1
- package/package/components/flows/utils.svelte.js +6 -1
- package/package/components/git_sync/GitSyncContext.svelte.js +13 -2
- package/package/components/git_sync/GitSyncSection.svelte +135 -99
- package/package/components/graph/DragGhost.svelte +11 -2
- package/package/components/graph/FlowGraphV2.svelte +138 -42
- package/package/components/graph/FlowGraphV2.svelte.d.ts +15 -1
- package/package/components/graph/GroupActionBar.svelte +124 -0
- package/package/components/graph/GroupActionBar.svelte.d.ts +20 -0
- package/package/components/graph/GroupHeader.svelte +98 -0
- package/package/components/graph/GroupHeader.svelte.d.ts +11 -0
- package/package/components/graph/GroupHeaderBlock.svelte +58 -0
- package/package/components/graph/GroupHeaderBlock.svelte.d.ts +13 -0
- package/package/components/graph/GroupModuleIcons.svelte +163 -0
- package/package/components/graph/GroupModuleIcons.svelte.d.ts +11 -0
- package/package/components/graph/GroupNodeCard.svelte +127 -0
- package/package/components/graph/GroupNodeCard.svelte.d.ts +18 -0
- package/package/components/graph/GroupNoteArea.svelte +132 -0
- package/package/components/graph/GroupNoteArea.svelte.d.ts +11 -0
- package/package/components/graph/GroupOverlay.svelte +71 -0
- package/package/components/graph/GroupOverlay.svelte.d.ts +12 -0
- package/package/components/graph/MiniFlowGraph.svelte +17 -2
- package/package/components/graph/SelectionBoundingBox.svelte +14 -14
- package/package/components/graph/compoundLayout.d.ts +17 -1
- package/package/components/graph/compoundLayout.js +129 -14
- package/package/components/graph/flowStructure.d.ts +63 -0
- package/package/components/graph/flowStructure.js +422 -0
- package/package/components/graph/flowStructure.test.d.ts +1 -0
- package/package/components/graph/flowStructure.test.js +205 -0
- package/package/components/graph/graphBuilder.svelte.d.ts +52 -3
- package/package/components/graph/graphBuilder.svelte.js +170 -67
- package/package/components/graph/graphContext.d.ts +7 -0
- package/package/components/graph/groupDetectionUtils.d.ts +24 -1
- package/package/components/graph/groupDetectionUtils.js +101 -1
- package/package/components/graph/groupEditor.svelte.d.ts +105 -0
- package/package/components/graph/groupEditor.svelte.js +253 -0
- package/package/components/graph/groupedModulesProxy.svelte.d.ts +55 -0
- package/package/components/graph/groupedModulesProxy.svelte.js +130 -0
- package/package/components/graph/model.d.ts +2 -1
- package/package/components/graph/moveManager.svelte.js +0 -3
- package/package/components/graph/nodeExtraSpace.d.ts +32 -0
- package/package/components/graph/nodeExtraSpace.js +113 -0
- package/package/components/graph/noteColors.d.ts +1 -0
- package/package/components/graph/noteColors.js +20 -10
- package/package/components/graph/noteUtils.svelte.d.ts +0 -18
- package/package/components/graph/noteUtils.svelte.js +6 -41
- package/package/components/graph/renderers/edges/BaseEdge.svelte +26 -11
- package/package/components/graph/renderers/nodes/AIToolNode.svelte +24 -49
- package/package/components/graph/renderers/nodes/AIToolNode.svelte.d.ts +1 -4
- package/package/components/graph/renderers/nodes/AssetNode.svelte +1 -27
- package/package/components/graph/renderers/nodes/AssetNode.svelte.d.ts +0 -4
- package/package/components/graph/renderers/nodes/CollapsedGroupNode.svelte +85 -0
- package/package/components/graph/renderers/nodes/CollapsedGroupNode.svelte.d.ts +8 -0
- package/package/components/graph/renderers/nodes/ForLoopStartNode.svelte +3 -2
- package/package/components/graph/renderers/nodes/GroupEndNode.svelte +9 -0
- package/package/components/graph/renderers/nodes/GroupEndNode.svelte.d.ts +6 -0
- package/package/components/graph/renderers/nodes/GroupHeadNode.svelte +20 -0
- package/package/components/graph/renderers/nodes/GroupHeadNode.svelte.d.ts +8 -0
- package/package/components/graph/renderers/nodes/ModuleNode.svelte +8 -5
- package/package/components/graph/renderers/triggers/TriggersWrapper.svelte +1 -1
- package/package/components/graph/util.d.ts +5 -1
- package/package/components/graph/util.js +7 -5
- package/package/components/home/Item.svelte +1 -0
- package/package/components/home/ItemsList.svelte +1 -1
- package/package/components/icons/ActiveCampaignIcon.svelte +10 -0
- package/package/components/icons/ActiveCampaignIcon.svelte.d.ts +7 -0
- package/package/components/icons/AlgoliaIcon.svelte +7 -0
- package/package/components/icons/AlgoliaIcon.svelte.d.ts +7 -0
- package/package/components/icons/ApolloIcon.svelte +7 -0
- package/package/components/icons/ApolloIcon.svelte.d.ts +7 -0
- package/package/components/icons/BambooHrIcon.svelte +7 -0
- package/package/components/icons/BambooHrIcon.svelte.d.ts +7 -0
- package/package/components/icons/BaremetricsIcon.svelte +7 -0
- package/package/components/icons/BaremetricsIcon.svelte.d.ts +7 -0
- package/package/components/icons/BitlyIcon.svelte +7 -0
- package/package/components/icons/BitlyIcon.svelte.d.ts +7 -0
- package/package/components/icons/BloggerIcon.svelte +7 -0
- package/package/components/icons/BloggerIcon.svelte.d.ts +7 -0
- package/package/components/icons/BlueskyIcon.svelte +7 -0
- package/package/components/icons/BlueskyIcon.svelte.d.ts +7 -0
- package/package/components/icons/BoxIcon.svelte +7 -0
- package/package/components/icons/BoxIcon.svelte.d.ts +7 -0
- package/package/components/icons/BrevoIcon.svelte +7 -0
- package/package/components/icons/BrevoIcon.svelte.d.ts +7 -0
- package/package/components/icons/BrexIcon.svelte +7 -0
- package/package/components/icons/BrexIcon.svelte.d.ts +7 -0
- package/package/components/icons/BrowserlessIcon.svelte +7 -0
- package/package/components/icons/BrowserlessIcon.svelte.d.ts +7 -0
- package/package/components/icons/BubbleIcon.svelte +11 -0
- package/package/components/icons/BubbleIcon.svelte.d.ts +7 -0
- package/package/components/icons/BuildkiteIcon.svelte +7 -0
- package/package/components/icons/BuildkiteIcon.svelte.d.ts +7 -0
- package/package/components/icons/CalcomIcon.svelte +1 -1
- package/package/components/icons/CalendlyIcon.svelte +7 -0
- package/package/components/icons/CalendlyIcon.svelte.d.ts +7 -0
- package/package/components/icons/CircleCiIcon.svelte +7 -0
- package/package/components/icons/CircleCiIcon.svelte.d.ts +7 -0
- package/package/components/icons/CiscoIcon.svelte +7 -0
- package/package/components/icons/CiscoIcon.svelte.d.ts +7 -0
- package/package/components/icons/ClearbitIcon.svelte +7 -0
- package/package/components/icons/ClearbitIcon.svelte.d.ts +7 -0
- package/package/components/icons/ClerkIcon.svelte +7 -0
- package/package/components/icons/ClerkIcon.svelte.d.ts +7 -0
- package/package/components/icons/CloseIcon.svelte +37 -0
- package/package/components/icons/CloseIcon.svelte.d.ts +7 -0
- package/package/components/icons/CloudinaryIcon.svelte +7 -0
- package/package/components/icons/CloudinaryIcon.svelte.d.ts +7 -0
- package/package/components/icons/CockroachDbIcon.svelte +7 -0
- package/package/components/icons/CockroachDbIcon.svelte.d.ts +7 -0
- package/package/components/icons/CodaIcon.svelte +7 -0
- package/package/components/icons/CodaIcon.svelte.d.ts +7 -0
- package/package/components/icons/CohereIcon.svelte +16 -0
- package/package/components/icons/CohereIcon.svelte.d.ts +7 -0
- package/package/components/icons/CoinMarketCapIcon.svelte +7 -0
- package/package/components/icons/CoinMarketCapIcon.svelte.d.ts +7 -0
- package/package/components/icons/CoinbaseIcon.svelte +7 -0
- package/package/components/icons/CoinbaseIcon.svelte.d.ts +7 -0
- package/package/components/icons/ConfluenceIcon.svelte +7 -0
- package/package/components/icons/ConfluenceIcon.svelte.d.ts +7 -0
- package/package/components/icons/ContentfulIcon.svelte +7 -0
- package/package/components/icons/ContentfulIcon.svelte.d.ts +7 -0
- package/package/components/icons/ConvertKitIcon.svelte +7 -0
- package/package/components/icons/ConvertKitIcon.svelte.d.ts +7 -0
- package/package/components/icons/DatoCmsIcon.svelte +7 -0
- package/package/components/icons/DatoCmsIcon.svelte.d.ts +7 -0
- package/package/components/icons/DeelIcon.svelte +7 -0
- package/package/components/icons/DeelIcon.svelte.d.ts +7 -0
- package/package/components/icons/DeepLIcon.svelte +7 -0
- package/package/components/icons/DeepLIcon.svelte.d.ts +7 -0
- package/package/components/icons/DigitalOceanIcon.svelte +7 -0
- package/package/components/icons/DigitalOceanIcon.svelte.d.ts +7 -0
- package/package/components/icons/DiscourseIcon.svelte +7 -0
- package/package/components/icons/DiscourseIcon.svelte.d.ts +7 -0
- package/package/components/icons/DocusignIcon.svelte +7 -0
- package/package/components/icons/DocusignIcon.svelte.d.ts +7 -0
- package/package/components/icons/DropboxIcon.svelte +7 -0
- package/package/components/icons/DropboxIcon.svelte.d.ts +7 -0
- package/package/components/icons/EdgeDbIcon.svelte +16 -20
- package/package/components/icons/EventbriteIcon.svelte +10 -0
- package/package/components/icons/EventbriteIcon.svelte.d.ts +7 -0
- package/package/components/icons/FigmaIcon.svelte +7 -0
- package/package/components/icons/FigmaIcon.svelte.d.ts +7 -0
- package/package/components/icons/FlyIcon.svelte +7 -0
- package/package/components/icons/FlyIcon.svelte.d.ts +7 -0
- package/package/components/icons/FreshdeskIcon.svelte +7 -0
- package/package/components/icons/FreshdeskIcon.svelte.d.ts +7 -0
- package/package/components/icons/FrontAppIcon.svelte +7 -0
- package/package/components/icons/FrontAppIcon.svelte.d.ts +7 -0
- package/package/components/icons/GhostCmsIcon.svelte +7 -0
- package/package/components/icons/GhostCmsIcon.svelte.d.ts +7 -0
- package/package/components/icons/GiphyIcon.svelte +7 -0
- package/package/components/icons/GiphyIcon.svelte.d.ts +7 -0
- package/package/components/icons/GitBookIcon.svelte +7 -0
- package/package/components/icons/GitBookIcon.svelte.d.ts +7 -0
- package/package/components/icons/GroqIcon.svelte +7 -0
- package/package/components/icons/GroqIcon.svelte.d.ts +7 -0
- package/package/components/icons/HoneybadgerIcon.svelte +7 -0
- package/package/components/icons/HoneybadgerIcon.svelte.d.ts +7 -0
- package/package/components/icons/HttpIcon.svelte +1 -0
- package/package/components/icons/IftttIcon.svelte +7 -0
- package/package/components/icons/IftttIcon.svelte.d.ts +7 -0
- package/package/components/icons/IntercomIcon.svelte +7 -0
- package/package/components/icons/IntercomIcon.svelte.d.ts +7 -0
- package/package/components/icons/JoomlaIcon.svelte +7 -0
- package/package/components/icons/JoomlaIcon.svelte.d.ts +7 -0
- package/package/components/icons/LineIcon.svelte +7 -0
- package/package/components/icons/LineIcon.svelte.d.ts +7 -0
- package/package/components/icons/LinearIcon.svelte +7 -0
- package/package/components/icons/LinearIcon.svelte.d.ts +7 -0
- package/package/components/icons/LinodeIcon.svelte +7 -0
- package/package/components/icons/LinodeIcon.svelte.d.ts +7 -0
- package/package/components/icons/LumaAiIcon.svelte +39 -0
- package/package/components/icons/LumaAiIcon.svelte.d.ts +7 -0
- package/package/components/icons/MSTeamsIcon.svelte +20 -38
- package/package/components/icons/MSTeamsIcon.svelte.d.ts +2 -0
- package/package/components/icons/MagentoIcon.svelte +7 -0
- package/package/components/icons/MagentoIcon.svelte.d.ts +7 -0
- package/package/components/icons/MailchimpIcon.svelte +25 -13
- package/package/components/icons/MandrillIcon.svelte +7 -0
- package/package/components/icons/MandrillIcon.svelte.d.ts +7 -0
- package/package/components/icons/MauticIcon.svelte +7 -0
- package/package/components/icons/MauticIcon.svelte.d.ts +7 -0
- package/package/components/icons/MediumIcon.svelte +7 -0
- package/package/components/icons/MediumIcon.svelte.d.ts +7 -0
- package/package/components/icons/MiroIcon.svelte +7 -0
- package/package/components/icons/MiroIcon.svelte.d.ts +7 -0
- package/package/components/icons/MistralIcon.svelte +7 -0
- package/package/components/icons/MistralIcon.svelte.d.ts +7 -0
- package/package/components/icons/MixpanelIcon.svelte +7 -0
- package/package/components/icons/MixpanelIcon.svelte.d.ts +7 -0
- package/package/components/icons/MondayIcon.svelte +7 -0
- package/package/components/icons/MondayIcon.svelte.d.ts +7 -0
- package/package/components/icons/NeonDbIcon.svelte +23 -0
- package/package/components/icons/NeonDbIcon.svelte.d.ts +7 -0
- package/package/components/icons/NetlifyIcon.svelte +7 -0
- package/package/components/icons/NetlifyIcon.svelte.d.ts +7 -0
- package/package/components/icons/OneSignalIcon.svelte +9 -0
- package/package/components/icons/OneSignalIcon.svelte.d.ts +7 -0
- package/package/components/icons/OpenWeatherIcon.svelte +7 -0
- package/package/components/icons/OpenWeatherIcon.svelte.d.ts +7 -0
- package/package/components/icons/PagerDutyIcon.svelte +7 -0
- package/package/components/icons/PagerDutyIcon.svelte.d.ts +7 -0
- package/package/components/icons/PandaDocIcon.svelte +7 -0
- package/package/components/icons/PandaDocIcon.svelte.d.ts +7 -0
- package/package/components/icons/PaypalIcon.svelte +7 -0
- package/package/components/icons/PaypalIcon.svelte.d.ts +7 -0
- package/package/components/icons/PersonioIcon.svelte +7 -0
- package/package/components/icons/PersonioIcon.svelte.d.ts +7 -0
- package/package/components/icons/PinterestIcon.svelte +7 -0
- package/package/components/icons/PinterestIcon.svelte.d.ts +7 -0
- package/package/components/icons/PipedriveIcon.svelte +11 -0
- package/package/components/icons/PipedriveIcon.svelte.d.ts +7 -0
- package/package/components/icons/PlanetScaleIcon.svelte +7 -0
- package/package/components/icons/PlanetScaleIcon.svelte.d.ts +7 -0
- package/package/components/icons/PostmarkIcon.svelte +7 -0
- package/package/components/icons/PostmarkIcon.svelte.d.ts +7 -0
- package/package/components/icons/PusherIcon.svelte +7 -0
- package/package/components/icons/PusherIcon.svelte.d.ts +7 -0
- package/package/components/icons/QuickbooksIcon.svelte +13 -1
- package/package/components/icons/RaindropIcon.svelte +27 -0
- package/package/components/icons/RaindropIcon.svelte.d.ts +7 -0
- package/package/components/icons/ReadwiseIcon.svelte +12 -0
- package/package/components/icons/ReadwiseIcon.svelte.d.ts +7 -0
- package/package/components/icons/RenderIcon.svelte +7 -0
- package/package/components/icons/RenderIcon.svelte.d.ts +7 -0
- package/package/components/icons/ReplicateIcon.svelte +7 -0
- package/package/components/icons/ReplicateIcon.svelte.d.ts +7 -0
- package/package/components/icons/ResendIcon.svelte +1 -1
- package/package/components/icons/RestIcon.svelte +1 -0
- package/package/components/icons/RingCentralIcon.svelte +7 -0
- package/package/components/icons/RingCentralIcon.svelte.d.ts +7 -0
- package/package/components/icons/RocketChatIcon.svelte +7 -0
- package/package/components/icons/RocketChatIcon.svelte.d.ts +7 -0
- package/package/components/icons/RunPodIcon.svelte +8 -0
- package/package/components/icons/RunPodIcon.svelte.d.ts +7 -0
- package/package/components/icons/RustIcon.svelte +74 -56
- package/package/components/icons/SalesforceIcon.svelte +7 -0
- package/package/components/icons/SalesforceIcon.svelte.d.ts +7 -0
- package/package/components/icons/SegmentIcon.svelte +7 -0
- package/package/components/icons/SegmentIcon.svelte.d.ts +7 -0
- package/package/components/icons/SentryIcon.svelte +7 -0
- package/package/components/icons/SentryIcon.svelte.d.ts +7 -0
- package/package/components/icons/ServiceNowIcon.svelte +7 -0
- package/package/components/icons/ServiceNowIcon.svelte.d.ts +7 -0
- package/package/components/icons/ShortcutIcon.svelte +7 -0
- package/package/components/icons/ShortcutIcon.svelte.d.ts +7 -0
- package/package/components/icons/SigNozIcon.svelte +8 -0
- package/package/components/icons/SigNozIcon.svelte.d.ts +7 -0
- package/package/components/icons/SmartsheetIcon.svelte +7 -0
- package/package/components/icons/SmartsheetIcon.svelte.d.ts +7 -0
- package/package/components/icons/SpeechifyIcon.svelte +7 -0
- package/package/components/icons/SpeechifyIcon.svelte.d.ts +7 -0
- package/package/components/icons/SplitwiseIcon.svelte +7 -0
- package/package/components/icons/SplitwiseIcon.svelte.d.ts +7 -0
- package/package/components/icons/StravaIcon.svelte +7 -0
- package/package/components/icons/StravaIcon.svelte.d.ts +7 -0
- package/package/components/icons/TallyIcon.svelte +7 -0
- package/package/components/icons/TallyIcon.svelte.d.ts +7 -0
- package/package/components/icons/TelnyxIcon.svelte +19 -0
- package/package/components/icons/TelnyxIcon.svelte.d.ts +7 -0
- package/package/components/icons/ThreadsIcon.svelte +7 -0
- package/package/components/icons/ThreadsIcon.svelte.d.ts +7 -0
- package/package/components/icons/TodoistIcon.svelte +7 -0
- package/package/components/icons/TodoistIcon.svelte.d.ts +7 -0
- package/package/components/icons/TogetherAiIcon.svelte +23 -0
- package/package/components/icons/TogetherAiIcon.svelte.d.ts +7 -0
- package/package/components/icons/TrelloIcon.svelte +22 -1
- package/package/components/icons/TursoIcon.svelte +7 -0
- package/package/components/icons/TursoIcon.svelte.d.ts +7 -0
- package/package/components/icons/TwitchIcon.svelte +7 -0
- package/package/components/icons/TwitchIcon.svelte.d.ts +7 -0
- package/package/components/icons/TwitterIcon.svelte +7 -0
- package/package/components/icons/TwitterIcon.svelte.d.ts +7 -0
- package/package/components/icons/TypeformIcon.svelte +1 -1
- package/package/components/icons/VercelIcon.svelte +7 -0
- package/package/components/icons/VercelIcon.svelte.d.ts +7 -0
- package/package/components/icons/WebflowIcon.svelte +7 -0
- package/package/components/icons/WebflowIcon.svelte.d.ts +7 -0
- package/package/components/icons/WooCommerceIcon.svelte +7 -0
- package/package/components/icons/WooCommerceIcon.svelte.d.ts +7 -0
- package/package/components/icons/WordpressIcon.svelte +7 -0
- package/package/components/icons/WordpressIcon.svelte.d.ts +7 -0
- package/package/components/icons/XataIcon.svelte +13 -0
- package/package/components/icons/XataIcon.svelte.d.ts +7 -0
- package/package/components/icons/YelpIcon.svelte +7 -0
- package/package/components/icons/YelpIcon.svelte.d.ts +7 -0
- package/package/components/icons/YnabIcon.svelte +7 -0
- package/package/components/icons/YnabIcon.svelte.d.ts +7 -0
- package/package/components/icons/YoutubeIcon.svelte +7 -0
- package/package/components/icons/YoutubeIcon.svelte.d.ts +7 -0
- package/package/components/icons/ZendeskIcon.svelte +1 -1
- package/package/components/icons/ZeroTierIcon.svelte +7 -0
- package/package/components/icons/ZeroTierIcon.svelte.d.ts +7 -0
- package/package/components/icons/ZoomIcon.svelte +7 -0
- package/package/components/icons/ZoomIcon.svelte.d.ts +7 -0
- package/package/components/icons/index.d.ts +111 -1
- package/package/components/icons/index.js +225 -2
- package/package/components/instanceSettings/GhesAppSettings.svelte +161 -0
- package/package/components/instanceSettings/GhesAppSettings.svelte.d.ts +8 -0
- package/package/components/instanceSettings/IndexerMemorySettings.svelte +19 -8
- package/package/components/instanceSettings/InstanceAISettings.svelte +132 -0
- package/package/components/instanceSettings/InstanceAISettings.svelte.d.ts +10 -0
- package/package/components/instanceSettings/WorkspaceRegistries.svelte +293 -0
- package/package/components/instanceSettings/WorkspaceRegistries.svelte.d.ts +8 -0
- package/package/components/instanceSettings/WsConnectivityTest.svelte +177 -0
- package/package/components/instanceSettings/WsConnectivityTest.svelte.d.ts +7 -0
- package/package/components/instanceSettings.d.ts +3 -1
- package/package/components/instanceSettings.js +92 -2
- package/package/components/mcp/McpScopeSelector.svelte +408 -0
- package/package/components/mcp/McpScopeSelector.svelte.d.ts +7 -0
- package/package/components/meltComponents/Popover.svelte +0 -1
- package/package/components/raw_apps/RawAppPreview.svelte +6 -2
- package/package/components/recording/FlowRecordingReplay.svelte +94 -52
- package/package/components/recording/FlowRecordingReplay.svelte.d.ts +10 -1
- package/package/components/recording/ScriptRecordingReplay.svelte +140 -76
- package/package/components/recording/ScriptRecordingReplay.svelte.d.ts +10 -1
- package/package/components/runs/JobRunsPreview.svelte +8 -1
- package/package/components/runs/TimeframeSelect.svelte +0 -1
- package/package/components/schema/JobSchemaPicker.svelte +8 -2
- package/package/components/schema/JobSchemaPicker.svelte.d.ts +1 -0
- package/package/components/schema/SchemaFormDND.svelte +15 -3
- package/package/components/scriptEditor/LogPanel.svelte +78 -68
- package/package/components/script_builder.d.ts +1 -1
- package/package/components/scripts/CreateActionsScript.svelte +3 -3
- package/package/components/scripts/WacExportDrawer.svelte +127 -0
- package/package/components/scripts/WacExportDrawer.svelte.d.ts +8 -0
- package/package/components/scripts/scriptStore.svelte.d.ts +2 -0
- package/package/components/scripts/scriptStore.svelte.js +2 -0
- package/package/components/select/SelectDropdown.svelte +1 -1
- package/package/components/settings/AIPromptsModal.svelte +5 -2
- package/package/components/settings/AIPromptsModal.svelte.d.ts +1 -1
- package/package/components/settings/CloudQuotas.svelte +152 -0
- package/package/components/settings/CloudQuotas.svelte.d.ts +3 -0
- package/package/components/settings/CreateToken.svelte +15 -430
- package/package/components/settings/Trashbin.svelte +248 -0
- package/package/components/settings/Trashbin.svelte.d.ts +3 -0
- package/package/components/sidebar/MultiplayerMenu.svelte +14 -4
- package/package/components/triggers/DeleteTriggerButton.svelte +1 -0
- package/package/components/triggers/PermissionedAsLine.svelte +66 -0
- package/package/components/triggers/PermissionedAsLine.svelte.d.ts +9 -0
- package/package/components/triggers/TriggerEditorToolbar.svelte +2 -2
- package/package/components/triggers/TriggerTokens.svelte +3 -3
- package/package/components/triggers/email/EmailTriggerEditorInner.svelte +19 -1
- package/package/components/triggers/email/utils.js +3 -1
- package/package/components/triggers/gcp/GcpTriggerEditorInner.svelte +24 -4
- package/package/components/triggers/gcp/utils.js +2 -0
- package/package/components/triggers/http/RouteEditorConfigSection.svelte +22 -3
- package/package/components/triggers/http/RouteEditorInner.svelte +28 -6
- package/package/components/triggers/http/RoutesGenerator.svelte +13 -2
- package/package/components/triggers/http/utils.js +3 -1
- package/package/components/triggers/kafka/KafkaTriggerEditorInner.svelte +23 -6
- package/package/components/triggers/kafka/utils.js +3 -1
- package/package/components/triggers/mqtt/MqttTriggerEditorInner.svelte +27 -5
- package/package/components/triggers/mqtt/utils.js +2 -0
- package/package/components/triggers/native/NativeTriggerEditor.svelte +23 -1
- package/package/components/triggers/native/NativeTriggerTable.svelte +14 -3
- package/package/components/triggers/native/utils.js +3 -2
- package/package/components/triggers/nats/NatsTriggerEditorInner.svelte +19 -1
- package/package/components/triggers/nats/utils.js +2 -0
- package/package/components/triggers/postgres/PostgresTriggerEditorInner.svelte +19 -1
- package/package/components/triggers/postgres/utils.js +2 -0
- package/package/components/triggers/schedules/ScheduleEditorInner.svelte +29 -7
- package/package/components/triggers/sqs/SqsTriggerEditorInner.svelte +19 -1
- package/package/components/triggers/sqs/utils.js +2 -0
- package/package/components/triggers/utils.js +9 -2
- package/package/components/triggers/websocket/WebsocketTriggerEditorInner.svelte +24 -4
- package/package/components/triggers/websocket/utils.js +3 -1
- package/package/components/workspaceSettings/AISettings.svelte +342 -214
- package/package/components/workspaceSettings/AISettings.svelte.d.ts +18 -10
- package/package/components/workspaceSettings/CreateWorkspace.svelte +304 -196
- package/package/components/workspaceSettings/CustomInstanceDbWizardModal.svelte +1 -2
- package/package/components/workspaceSettings/DucklakeSettings.svelte +1 -1
- package/package/components/workspaceSettings/InstanceFallbackSettings.svelte +75 -0
- package/package/components/workspaceSettings/InstanceFallbackSettings.svelte.d.ts +9 -0
- package/package/components/workspaceSettings/StorageSettings.svelte +4 -35
- package/package/components/workspaceSettings/VolumeStorageSettings.svelte +80 -0
- package/package/components/workspaceSettings/VolumeStorageSettings.svelte.d.ts +10 -0
- package/package/components/workspaceSettings/WorkspaceIntegrations.svelte +4 -1
- package/package/gen/core/OpenAPI.js +1 -1
- package/package/gen/schemas.gen.d.ts +294 -94
- package/package/gen/schemas.gen.js +294 -94
- package/package/gen/services.gen.d.ts +121 -5
- package/package/gen/services.gen.js +237 -5
- package/package/gen/types.gen.d.ts +715 -91
- package/package/githubApp.js +19 -1
- package/package/hubPaths.json +8 -4
- package/package/infer.d.ts +1 -1
- package/package/infer.js +5 -1
- package/package/logoutRedirect.d.ts +1 -0
- package/package/logoutRedirect.js +24 -0
- package/package/script_helpers.d.ts +8 -2
- package/package/script_helpers.js +15 -1
- package/package/services/trashService.d.ts +28 -0
- package/package/services/trashService.js +47 -0
- package/package/stores.d.ts +1 -0
- package/package/stores.js +1 -0
- package/package/system_prompts/index.d.ts +1 -0
- package/package/system_prompts/index.js +7 -0
- package/package/system_prompts/prompts.d.ts +7 -5
- package/package/system_prompts/prompts.js +182 -11
- package/package/templates/wac_python.py.template +42 -0
- package/package/templates/wac_typescript.ts.template +48 -0
- package/package/utils_deployable.d.ts +22 -21
- package/package/utils_deployable.js +58 -25
- package/package/utils_workspace_deploy.d.ts +15 -4
- package/package/utils_workspace_deploy.js +19 -15
- package/package/wsUrl.d.ts +1 -0
- package/package/wsUrl.js +15 -0
- package/package.json +13 -5
- package/dist/sharedUtils/assets/tokens/colorTokensConfig.d.ts +0 -2
- package/dist/sharedUtils/base.d.ts +0 -1
- package/dist/sharedUtils/cloud.d.ts +0 -1
- package/dist/sharedUtils/common.d.ts +0 -111
- package/dist/sharedUtils/components/apps/components/display/dbtable/queries/count.d.ts +0 -5
- package/dist/sharedUtils/components/apps/components/display/dbtable/queries/delete.d.ts +0 -5
- package/dist/sharedUtils/components/apps/components/display/dbtable/queries/insert.d.ts +0 -5
- package/dist/sharedUtils/components/apps/components/display/dbtable/queries/select.d.ts +0 -13
- package/dist/sharedUtils/components/apps/components/display/dbtable/queries/update.d.ts +0 -11
- package/dist/sharedUtils/components/apps/components/display/dbtable/utils.d.ts +0 -95
- package/dist/sharedUtils/components/apps/editor/appPolicy.d.ts +0 -6
- package/dist/sharedUtils/components/apps/editor/appUtilsCore.d.ts +0 -7
- package/dist/sharedUtils/components/apps/editor/appUtilsS3.d.ts +0 -33
- package/dist/sharedUtils/components/apps/editor/commonAppUtils.d.ts +0 -10
- package/dist/sharedUtils/components/apps/editor/component/components.d.ts +0 -5371
- package/dist/sharedUtils/components/apps/editor/component/default-codes.d.ts +0 -3
- package/dist/sharedUtils/components/apps/editor/component/index.d.ts +0 -3
- package/dist/sharedUtils/components/apps/editor/component/sets.d.ts +0 -7
- package/dist/sharedUtils/components/apps/editor/componentsPanel/componentDefaultProps.d.ts +0 -3
- package/dist/sharedUtils/components/apps/gridUtils.d.ts +0 -14
- package/dist/sharedUtils/components/apps/inputType.d.ts +0 -178
- package/dist/sharedUtils/components/apps/rx.d.ts +0 -29
- package/dist/sharedUtils/components/apps/sharedTypes.d.ts +0 -21
- package/dist/sharedUtils/components/apps/types.d.ts +0 -274
- package/dist/sharedUtils/components/assets/lib.d.ts +0 -25
- package/dist/sharedUtils/components/common/alert/model.d.ts +0 -2
- package/dist/sharedUtils/components/common/badge/model.d.ts +0 -8
- package/dist/sharedUtils/components/common/button/model.d.ts +0 -45
- package/dist/sharedUtils/components/common/fileInput/model.d.ts +0 -1
- package/dist/sharedUtils/components/common/index.d.ts +0 -24
- package/dist/sharedUtils/components/common/skeleton/model.d.ts +0 -21
- package/dist/sharedUtils/components/dbTypes.d.ts +0 -14
- package/dist/sharedUtils/components/diff_drawer.d.ts +0 -26
- package/dist/sharedUtils/components/ducklake.d.ts +0 -1
- package/dist/sharedUtils/components/flows/scheduleUtils.d.ts +0 -7
- package/dist/sharedUtils/components/icons/index.d.ts +0 -101
- package/dist/sharedUtils/components/random_positive_adjetive.d.ts +0 -1
- package/dist/sharedUtils/components/raw_apps/rawAppPolicy.d.ts +0 -10
- package/dist/sharedUtils/components/raw_apps/utils.d.ts +0 -15
- package/dist/sharedUtils/components/triggers/email/utils.d.ts +0 -4
- package/dist/sharedUtils/components/triggers/gcp/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers/http/utils.d.ts +0 -11
- package/dist/sharedUtils/components/triggers/kafka/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers/mqtt/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers/nats/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers/postgres/utils.d.ts +0 -8
- package/dist/sharedUtils/components/triggers/sqs/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers/triggers.svelte.d.ts +0 -32
- package/dist/sharedUtils/components/triggers/utils.d.ts +0 -80
- package/dist/sharedUtils/components/triggers/websocket/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers.d.ts +0 -20
- package/dist/sharedUtils/gen/core/ApiError.d.ts +0 -10
- package/dist/sharedUtils/gen/core/ApiRequestOptions.d.ts +0 -13
- package/dist/sharedUtils/gen/core/ApiResult.d.ts +0 -7
- package/dist/sharedUtils/gen/core/CancelablePromise.d.ts +0 -26
- package/dist/sharedUtils/gen/core/OpenAPI.d.ts +0 -27
- package/dist/sharedUtils/gen/core/request.d.ts +0 -29
- package/dist/sharedUtils/gen/index.d.ts +0 -6
- package/dist/sharedUtils/gen/schemas.gen.d.ts +0 -7036
- package/dist/sharedUtils/gen/services.gen.d.ts +0 -6047
- package/dist/sharedUtils/gen/types.gen.d.ts +0 -21881
- package/dist/sharedUtils/history.svelte.d.ts +0 -9
- package/dist/sharedUtils/hub.d.ts +0 -49
- package/dist/sharedUtils/jsr.json +0 -6
- package/dist/sharedUtils/lib.d.ts +0 -5
- package/dist/sharedUtils/lib.es.js +0 -1588
- package/dist/sharedUtils/package.json +0 -12
- package/dist/sharedUtils/schema.d.ts +0 -3
- package/dist/sharedUtils/stores.d.ts +0 -97
- package/dist/sharedUtils/svelte5Utils.svelte.d.ts +0 -80
- package/dist/sharedUtils/toast.d.ts +0 -8
- package/dist/sharedUtils/utils.d.ts +0 -265
- package/package/components/graph/NodeContextMenu.svelte +0 -36
- package/package/components/graph/NodeContextMenu.svelte.d.ts +0 -8
- package/package/svelte5Utils.svelte.d.ts +0 -184
|
@@ -0,0 +1,422 @@
|
|
|
1
|
+
import { getContainerInnerArrays } from './groupEditor.svelte';
|
|
2
|
+
import { VIRTUAL_NODE_IDS } from './groupDetectionUtils';
|
|
3
|
+
// ---------------------------------------------------------------------------
|
|
4
|
+
// Type guards
|
|
5
|
+
// ---------------------------------------------------------------------------
|
|
6
|
+
// Building the structure tree
|
|
7
|
+
// ---------------------------------------------------------------------------
|
|
8
|
+
export function buildStructureTree(modules, groups) {
|
|
9
|
+
const { items, consumed } = buildStructureTreeRecurse(modules, groups);
|
|
10
|
+
const unconsumed = groups.filter((g) => !consumed.has(g.id));
|
|
11
|
+
if (unconsumed.length > 0) {
|
|
12
|
+
throw new Error(`Group(s) ${unconsumed.map((g) => `'${g.id}'`).join(', ')} could not be resolved: ` +
|
|
13
|
+
`their start/end nodes do not belong to the same branch`);
|
|
14
|
+
}
|
|
15
|
+
return items;
|
|
16
|
+
}
|
|
17
|
+
export function moduleToStructureNode(mod) {
|
|
18
|
+
const innerArrays = getContainerInnerArrays(mod);
|
|
19
|
+
if (innerArrays.length === 0) {
|
|
20
|
+
return { id: mod.id, kind: 'leaf', branches: [] };
|
|
21
|
+
}
|
|
22
|
+
const kind = mod.value.type;
|
|
23
|
+
const branches = innerArrays.map(({ get, label }) => ({
|
|
24
|
+
label,
|
|
25
|
+
children: [] // filled later by recursion
|
|
26
|
+
}));
|
|
27
|
+
return { id: mod.id, kind, branches };
|
|
28
|
+
}
|
|
29
|
+
function buildStructureTreeRecurse(modules, groups) {
|
|
30
|
+
if (modules.length === 0) {
|
|
31
|
+
return { items: [], consumed: new Set() };
|
|
32
|
+
}
|
|
33
|
+
const indexMap = new Map();
|
|
34
|
+
for (let i = 0; i < modules.length; i++) {
|
|
35
|
+
indexMap.set(modules[i].id, i);
|
|
36
|
+
}
|
|
37
|
+
// Reject duplicate group IDs
|
|
38
|
+
const seenGroupIds = new Set();
|
|
39
|
+
for (const g of groups) {
|
|
40
|
+
if (seenGroupIds.has(g.id)) {
|
|
41
|
+
throw new Error(`Duplicate group id: '${g.id}'`);
|
|
42
|
+
}
|
|
43
|
+
seenGroupIds.add(g.id);
|
|
44
|
+
}
|
|
45
|
+
// Reject groups referencing virtual nodes
|
|
46
|
+
for (const g of groups) {
|
|
47
|
+
if (VIRTUAL_NODE_IDS.has(g.start_id) || VIRTUAL_NODE_IDS.has(g.end_id)) {
|
|
48
|
+
throw new Error(`Group '${g.id}' references virtual node: groups cannot include Input, Result, or Trigger`);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// Partition: groups for this level vs rest
|
|
52
|
+
const levelGroups = [];
|
|
53
|
+
const otherGroups = [];
|
|
54
|
+
for (const g of groups) {
|
|
55
|
+
if (indexMap.has(g.start_id) && indexMap.has(g.end_id)) {
|
|
56
|
+
const s = indexMap.get(g.start_id);
|
|
57
|
+
const e = indexMap.get(g.end_id);
|
|
58
|
+
if (s > e) {
|
|
59
|
+
throw new Error(`Group '${g.id}' has inverted range: start_id='${g.start_id}' (index ${s}) > end_id='${g.end_id}' (index ${e})`);
|
|
60
|
+
}
|
|
61
|
+
levelGroups.push(g);
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
otherGroups.push(g);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
// Validate no partial overlaps
|
|
68
|
+
for (let i = 0; i < levelGroups.length; i++) {
|
|
69
|
+
for (let j = i + 1; j < levelGroups.length; j++) {
|
|
70
|
+
const a = levelGroups[i];
|
|
71
|
+
const b = levelGroups[j];
|
|
72
|
+
const aStart = indexMap.get(a.start_id);
|
|
73
|
+
const aEnd = indexMap.get(a.end_id);
|
|
74
|
+
const bStart = indexMap.get(b.start_id);
|
|
75
|
+
const bEnd = indexMap.get(b.end_id);
|
|
76
|
+
if (aEnd < bStart || bEnd < aStart)
|
|
77
|
+
continue;
|
|
78
|
+
if (aStart <= bStart && bEnd <= aEnd)
|
|
79
|
+
continue;
|
|
80
|
+
if (bStart <= aStart && aEnd <= bEnd)
|
|
81
|
+
continue;
|
|
82
|
+
throw new Error(`Groups '${a.id}' and '${b.id}' overlap without nesting`);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
// Build grouped structure for this level
|
|
86
|
+
function build(startIdx, endIdx, availableGroups) {
|
|
87
|
+
const result = [];
|
|
88
|
+
let i = startIdx;
|
|
89
|
+
while (i <= endIdx) {
|
|
90
|
+
const candidates = availableGroups.filter((g) => {
|
|
91
|
+
const gStart = indexMap.get(g.start_id);
|
|
92
|
+
const gEnd = indexMap.get(g.end_id);
|
|
93
|
+
return gStart === i && gEnd <= endIdx;
|
|
94
|
+
});
|
|
95
|
+
candidates.sort((a, b) => {
|
|
96
|
+
const spanA = indexMap.get(a.end_id) - indexMap.get(a.start_id);
|
|
97
|
+
const spanB = indexMap.get(b.end_id) - indexMap.get(b.start_id);
|
|
98
|
+
return spanB - spanA;
|
|
99
|
+
});
|
|
100
|
+
const group = candidates[0];
|
|
101
|
+
if (group) {
|
|
102
|
+
const gEnd = indexMap.get(group.end_id);
|
|
103
|
+
const remaining = availableGroups.filter((g) => g.id !== group.id);
|
|
104
|
+
const innerNodes = build(i, gEnd, remaining);
|
|
105
|
+
const moduleIds = [];
|
|
106
|
+
for (let k = i; k <= gEnd; k++) {
|
|
107
|
+
moduleIds.push(modules[k].id);
|
|
108
|
+
}
|
|
109
|
+
result.push({
|
|
110
|
+
id: group.id,
|
|
111
|
+
kind: 'group',
|
|
112
|
+
group: {
|
|
113
|
+
summary: group.summary,
|
|
114
|
+
note: group.note,
|
|
115
|
+
color: group.color,
|
|
116
|
+
autocollapse: group.autocollapse,
|
|
117
|
+
start_id: group.start_id,
|
|
118
|
+
end_id: group.end_id
|
|
119
|
+
},
|
|
120
|
+
moduleIds,
|
|
121
|
+
branches: [{ children: innerNodes }]
|
|
122
|
+
});
|
|
123
|
+
i = gEnd + 1;
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
result.push(moduleToStructureNode(modules[i]));
|
|
127
|
+
i++;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
return result;
|
|
131
|
+
}
|
|
132
|
+
const result = build(0, modules.length - 1, levelGroups);
|
|
133
|
+
// Recurse into containers with remaining unconsumed groups
|
|
134
|
+
const consumed = new Set(levelGroups.map((g) => g.id));
|
|
135
|
+
let remaining = otherGroups;
|
|
136
|
+
function recurseIntoContainers(items) {
|
|
137
|
+
for (const item of items) {
|
|
138
|
+
if (item.kind === 'group') {
|
|
139
|
+
recurseIntoContainers(item.branches[0].children);
|
|
140
|
+
continue;
|
|
141
|
+
}
|
|
142
|
+
if (item.branches.length === 0)
|
|
143
|
+
continue;
|
|
144
|
+
// This is a container module — get inner FlowModule arrays and recurse
|
|
145
|
+
const modIdx = indexMap.get(item.id);
|
|
146
|
+
if (modIdx === undefined)
|
|
147
|
+
continue;
|
|
148
|
+
const mod = modules[modIdx];
|
|
149
|
+
const innerArrays = getContainerInnerArrays(mod);
|
|
150
|
+
for (let bi = 0; bi < innerArrays.length; bi++) {
|
|
151
|
+
const inner = buildStructureTreeRecurse(innerArrays[bi].get(), remaining);
|
|
152
|
+
item.branches[bi] = {
|
|
153
|
+
label: item.branches[bi]?.label,
|
|
154
|
+
children: inner.items
|
|
155
|
+
};
|
|
156
|
+
for (const id of inner.consumed)
|
|
157
|
+
consumed.add(id);
|
|
158
|
+
remaining = remaining.filter((g) => !inner.consumed.has(g.id));
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
recurseIntoContainers(result);
|
|
163
|
+
return { items: result, consumed };
|
|
164
|
+
}
|
|
165
|
+
// ---------------------------------------------------------------------------
|
|
166
|
+
// Traversal utilities
|
|
167
|
+
// ---------------------------------------------------------------------------
|
|
168
|
+
/** Generic DFS over the structure tree */
|
|
169
|
+
export function dfsStructure(nodes, fn) {
|
|
170
|
+
for (const node of nodes) {
|
|
171
|
+
fn(node, nodes);
|
|
172
|
+
for (const branch of node.branches) {
|
|
173
|
+
dfsStructure(branch.children, fn);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
/** Flatten to ordered module IDs (groups are transparent) */
|
|
178
|
+
export function flattenStructureIds(nodes) {
|
|
179
|
+
const ids = [];
|
|
180
|
+
for (const node of nodes) {
|
|
181
|
+
if (node.kind === 'group') {
|
|
182
|
+
ids.push(...flattenStructureIds(node.branches[0].children));
|
|
183
|
+
}
|
|
184
|
+
else {
|
|
185
|
+
ids.push(node.id);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
return ids;
|
|
189
|
+
}
|
|
190
|
+
/** Collect leaf module IDs recursively (including inside containers) */
|
|
191
|
+
export function collectLeafIds(nodes) {
|
|
192
|
+
const ids = [];
|
|
193
|
+
for (const node of nodes) {
|
|
194
|
+
if (node.kind === 'group') {
|
|
195
|
+
ids.push(...collectLeafIds(node.branches[0].children));
|
|
196
|
+
}
|
|
197
|
+
else {
|
|
198
|
+
ids.push(node.id);
|
|
199
|
+
for (const branch of node.branches) {
|
|
200
|
+
ids.push(...collectLeafIds(branch.children));
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
return ids;
|
|
205
|
+
}
|
|
206
|
+
export function findInStructure(nodes, id) {
|
|
207
|
+
for (let i = 0; i < nodes.length; i++) {
|
|
208
|
+
const node = nodes[i];
|
|
209
|
+
if (node.id === id)
|
|
210
|
+
return { parentChildren: nodes, index: i };
|
|
211
|
+
for (const branch of node.branches) {
|
|
212
|
+
const found = findInStructure(branch.children, id);
|
|
213
|
+
if (found)
|
|
214
|
+
return found;
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
return undefined;
|
|
218
|
+
}
|
|
219
|
+
/**
|
|
220
|
+
* Match a structure node against a graph node ID.
|
|
221
|
+
* Handles group head/end IDs (group:X, group:X-end) and collapsed-group:X.
|
|
222
|
+
*/
|
|
223
|
+
export function matchStructureNode(node, nodeId) {
|
|
224
|
+
if (node.id === nodeId)
|
|
225
|
+
return true;
|
|
226
|
+
if (node.kind === 'group') {
|
|
227
|
+
return (nodeId === `group:${node.id}` ||
|
|
228
|
+
nodeId === `group:${node.id}-end` ||
|
|
229
|
+
nodeId === `collapsed-group:${node.id}`);
|
|
230
|
+
}
|
|
231
|
+
return false;
|
|
232
|
+
}
|
|
233
|
+
/**
|
|
234
|
+
* Find insert index using graph node IDs (handles group:X-end etc.).
|
|
235
|
+
* Returns the index OF the matched item (insert before it).
|
|
236
|
+
* For group-end nodes, returns index AFTER the group (insert after it).
|
|
237
|
+
*/
|
|
238
|
+
export function findInsertIndexByNodeId(items, targetNodeId) {
|
|
239
|
+
// group-end: insert after the group
|
|
240
|
+
if (targetNodeId.startsWith('group:') && targetNodeId.endsWith('-end')) {
|
|
241
|
+
const groupId = targetNodeId.slice('group:'.length, -'-end'.length);
|
|
242
|
+
const idx = items.findIndex((n) => n.kind === 'group' && n.id === groupId);
|
|
243
|
+
return idx >= 0 ? idx + 1 : items.length;
|
|
244
|
+
}
|
|
245
|
+
// Everything else: insert at the matched item's position
|
|
246
|
+
for (let i = 0; i < items.length; i++) {
|
|
247
|
+
if (matchStructureNode(items[i], targetNodeId))
|
|
248
|
+
return i;
|
|
249
|
+
}
|
|
250
|
+
return items.length;
|
|
251
|
+
}
|
|
252
|
+
// ---------------------------------------------------------------------------
|
|
253
|
+
// Deriving groups from the structure tree
|
|
254
|
+
// ---------------------------------------------------------------------------
|
|
255
|
+
export function deriveGroupsFromStructure(nodes) {
|
|
256
|
+
const groups = [];
|
|
257
|
+
for (const node of nodes) {
|
|
258
|
+
if (node.kind === 'group' && node.group) {
|
|
259
|
+
const flatIds = flattenStructureIds(node.branches[0].children);
|
|
260
|
+
if (flatIds.length === 0) {
|
|
261
|
+
console.warn(`deriveGroupsFromStructure: skipping empty group "${node.id}"`);
|
|
262
|
+
continue;
|
|
263
|
+
}
|
|
264
|
+
groups.push({
|
|
265
|
+
...node.group,
|
|
266
|
+
start_id: flatIds[0],
|
|
267
|
+
end_id: flatIds[flatIds.length - 1]
|
|
268
|
+
});
|
|
269
|
+
// Recurse for nested groups
|
|
270
|
+
groups.push(...deriveGroupsFromStructure(node.branches[0].children));
|
|
271
|
+
}
|
|
272
|
+
else {
|
|
273
|
+
for (const branch of node.branches) {
|
|
274
|
+
groups.push(...deriveGroupsFromStructure(branch.children));
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
return groups;
|
|
279
|
+
}
|
|
280
|
+
// ---------------------------------------------------------------------------
|
|
281
|
+
// Syncing structure back to FlowModule[]
|
|
282
|
+
// ---------------------------------------------------------------------------
|
|
283
|
+
/**
|
|
284
|
+
* Reconstruct a FlowModule[] from the structure tree, looking up originals
|
|
285
|
+
* from moduleMap and patching container inner arrays to match the tree ordering.
|
|
286
|
+
*/
|
|
287
|
+
export function applyStructureToModules(nodes, moduleMap) {
|
|
288
|
+
const result = [];
|
|
289
|
+
for (const node of nodes) {
|
|
290
|
+
if (node.kind === 'group') {
|
|
291
|
+
// Groups are transparent — splice their children into this level
|
|
292
|
+
result.push(...applyStructureToModules(node.branches[0].children, moduleMap));
|
|
293
|
+
}
|
|
294
|
+
else {
|
|
295
|
+
const mod = moduleMap.get(node.id);
|
|
296
|
+
if (!mod)
|
|
297
|
+
continue;
|
|
298
|
+
// Patch container inner arrays
|
|
299
|
+
if (node.branches.length > 0) {
|
|
300
|
+
const innerArrays = getContainerInnerArrays(mod);
|
|
301
|
+
for (let bi = 0; bi < innerArrays.length && bi < node.branches.length; bi++) {
|
|
302
|
+
innerArrays[bi].set(applyStructureToModules(node.branches[bi].children, moduleMap));
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
result.push(mod);
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
return result;
|
|
309
|
+
}
|
|
310
|
+
// ---------------------------------------------------------------------------
|
|
311
|
+
// Empty groups cleanup
|
|
312
|
+
// ---------------------------------------------------------------------------
|
|
313
|
+
/**
|
|
314
|
+
* Walk the tree, remove group nodes that have no leaf modules, and return
|
|
315
|
+
* the removed groups. Mutates the input array in-place.
|
|
316
|
+
* Recurses depth-first so inner groups are cleaned before checking outer ones.
|
|
317
|
+
*/
|
|
318
|
+
export function removeEmptyGroups(nodes) {
|
|
319
|
+
const removed = [];
|
|
320
|
+
for (let i = nodes.length - 1; i >= 0; i--) {
|
|
321
|
+
const node = nodes[i];
|
|
322
|
+
if (node.kind === 'group' && node.group) {
|
|
323
|
+
// Recurse first — inner groups may become empty too
|
|
324
|
+
removed.push(...removeEmptyGroups(node.branches[0].children));
|
|
325
|
+
if (flattenStructureIds(node.branches[0].children).length === 0) {
|
|
326
|
+
removed.push(node.group);
|
|
327
|
+
nodes.splice(i, 1);
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
else {
|
|
331
|
+
for (const branch of node.branches) {
|
|
332
|
+
removed.push(...removeEmptyGroups(branch.children));
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
}
|
|
336
|
+
return removed;
|
|
337
|
+
}
|
|
338
|
+
/** Walk the structure tree to compute nesting depth for each group (O(n)). */
|
|
339
|
+
export function computeGroupDepths(tree) {
|
|
340
|
+
const depths = {};
|
|
341
|
+
function walk(nodes, groupDepth) {
|
|
342
|
+
for (const node of nodes) {
|
|
343
|
+
if (node.kind === 'group') {
|
|
344
|
+
depths[node.id] = groupDepth;
|
|
345
|
+
for (const branch of node.branches) {
|
|
346
|
+
walk(branch.children, groupDepth + 1);
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
else {
|
|
350
|
+
for (const branch of node.branches) {
|
|
351
|
+
walk(branch.children, groupDepth);
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
walk(tree, 0);
|
|
357
|
+
return depths;
|
|
358
|
+
}
|
|
359
|
+
/**
|
|
360
|
+
* Find duplicate groups in the structure tree (same start_id:end_id after mutation).
|
|
361
|
+
* Returns the groups that should be removed (keeps the first, removes subsequent duplicates).
|
|
362
|
+
*/
|
|
363
|
+
export function findDuplicateGroups(nodes) {
|
|
364
|
+
const duplicates = [];
|
|
365
|
+
const seen = new Set();
|
|
366
|
+
function walk(items) {
|
|
367
|
+
for (const node of items) {
|
|
368
|
+
if (node.kind === 'group' && node.group) {
|
|
369
|
+
const flatIds = flattenStructureIds(node.branches[0].children);
|
|
370
|
+
if (flatIds.length > 0) {
|
|
371
|
+
const key = `${flatIds[0]}:${flatIds[flatIds.length - 1]}`;
|
|
372
|
+
if (seen.has(key)) {
|
|
373
|
+
duplicates.push(node.group);
|
|
374
|
+
}
|
|
375
|
+
else {
|
|
376
|
+
seen.add(key);
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
walk(node.branches[0].children);
|
|
380
|
+
}
|
|
381
|
+
else {
|
|
382
|
+
for (const branch of node.branches) {
|
|
383
|
+
walk(branch.children);
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
}
|
|
388
|
+
walk(nodes);
|
|
389
|
+
return duplicates;
|
|
390
|
+
}
|
|
391
|
+
/** Remove duplicate groups from the structure tree (keeps first occurrence). */
|
|
392
|
+
export function removeDuplicateGroups(nodes) {
|
|
393
|
+
const removed = [];
|
|
394
|
+
const seen = new Set();
|
|
395
|
+
function walk(items) {
|
|
396
|
+
for (let i = items.length - 1; i >= 0; i--) {
|
|
397
|
+
const node = items[i];
|
|
398
|
+
if (node.kind === 'group' && node.group) {
|
|
399
|
+
walk(node.branches[0].children);
|
|
400
|
+
const flatIds = flattenStructureIds(node.branches[0].children);
|
|
401
|
+
if (flatIds.length > 0) {
|
|
402
|
+
const key = `${flatIds[0]}:${flatIds[flatIds.length - 1]}`;
|
|
403
|
+
if (seen.has(key)) {
|
|
404
|
+
// Replace group node with its children (ungroup)
|
|
405
|
+
removed.push(node.group);
|
|
406
|
+
items.splice(i, 1, ...node.branches[0].children);
|
|
407
|
+
}
|
|
408
|
+
else {
|
|
409
|
+
seen.add(key);
|
|
410
|
+
}
|
|
411
|
+
}
|
|
412
|
+
}
|
|
413
|
+
else {
|
|
414
|
+
for (const branch of node.branches) {
|
|
415
|
+
walk(branch.children);
|
|
416
|
+
}
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
}
|
|
420
|
+
walk(nodes);
|
|
421
|
+
return removed;
|
|
422
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import { describe, it, expect, vi } from 'vitest';
|
|
2
|
+
// Mock modules that transitively import CSS/Monaco
|
|
3
|
+
vi.mock('monaco-editor', () => ({}));
|
|
4
|
+
vi.mock('@xyflow/svelte', () => ({}));
|
|
5
|
+
vi.mock('./renderers/nodes/AssetNode.svelte', () => ({
|
|
6
|
+
assetDisplaysAsOutputInFlowGraph: () => false
|
|
7
|
+
}));
|
|
8
|
+
vi.mock('../modulesTest.svelte', () => ({}));
|
|
9
|
+
import { buildStructureTree, flattenStructureIds, deriveGroupsFromStructure, collectLeafIds, findInStructure } from './flowStructure';
|
|
10
|
+
function makeModule(id) {
|
|
11
|
+
return {
|
|
12
|
+
id,
|
|
13
|
+
value: { type: 'rawscript', content: '', language: 'python3' }
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
function makeBranchAll(id, branchInnerIds) {
|
|
17
|
+
return {
|
|
18
|
+
id,
|
|
19
|
+
value: {
|
|
20
|
+
type: 'branchall',
|
|
21
|
+
branches: branchInnerIds.map((ids) => ({ modules: ids.map((iid) => makeModule(iid)) }))
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
function makeForloop(id, innerIds) {
|
|
26
|
+
return {
|
|
27
|
+
id,
|
|
28
|
+
value: {
|
|
29
|
+
type: 'forloopflow',
|
|
30
|
+
modules: innerIds.map((iid) => makeModule(iid)),
|
|
31
|
+
iterator: { type: 'javascript', expr: '' }
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
function makeGroup(id, start_id, end_id, moduleIds = []) {
|
|
36
|
+
return { id, start_id, end_id, moduleIds };
|
|
37
|
+
}
|
|
38
|
+
describe('buildStructureTree', () => {
|
|
39
|
+
const modules = [makeModule('a'), makeModule('b'), makeModule('c')];
|
|
40
|
+
it('builds structure tree for a valid group', () => {
|
|
41
|
+
const groups = [makeGroup('g1', 'a', 'b', ['a', 'b'])];
|
|
42
|
+
const result = buildStructureTree(modules, groups);
|
|
43
|
+
// Should have a group node + the remaining leaf 'c'
|
|
44
|
+
expect(result).toHaveLength(2);
|
|
45
|
+
expect(result[0].kind).toBe('group');
|
|
46
|
+
expect(result[0].id).toBe('g1');
|
|
47
|
+
expect(result[0].branches[0].children).toHaveLength(2);
|
|
48
|
+
expect(result[1].kind).toBe('leaf');
|
|
49
|
+
expect(result[1].id).toBe('c');
|
|
50
|
+
});
|
|
51
|
+
it('throws on duplicate group IDs', () => {
|
|
52
|
+
const groups = [makeGroup('g1', 'a', 'a', ['a']), makeGroup('g1', 'b', 'c', ['b', 'c'])];
|
|
53
|
+
expect(() => buildStructureTree(modules, groups)).toThrow(/duplicate group id.*g1/i);
|
|
54
|
+
});
|
|
55
|
+
it('throws on inverted range (start_id after end_id)', () => {
|
|
56
|
+
const groups = [makeGroup('g1', 'c', 'a', ['a', 'b', 'c'])];
|
|
57
|
+
expect(() => buildStructureTree(modules, groups)).toThrow(/inverted range/i);
|
|
58
|
+
});
|
|
59
|
+
it('throws on partially overlapping groups', () => {
|
|
60
|
+
const groups = [makeGroup('g1', 'a', 'b', ['a', 'b']), makeGroup('g2', 'b', 'c', ['b', 'c'])];
|
|
61
|
+
expect(() => buildStructureTree(modules, groups)).toThrow(/overlap without nesting/i);
|
|
62
|
+
});
|
|
63
|
+
it('throws when group start_id is a virtual node (Input)', () => {
|
|
64
|
+
const groups = [makeGroup('g1', 'Input', 'b', ['a', 'b'])];
|
|
65
|
+
expect(() => buildStructureTree(modules, groups)).toThrow(/virtual node/i);
|
|
66
|
+
});
|
|
67
|
+
it('throws when group end_id is a virtual node (Result)', () => {
|
|
68
|
+
const groups = [makeGroup('g1', 'a', 'Result', ['a', 'b', 'c'])];
|
|
69
|
+
expect(() => buildStructureTree(modules, groups)).toThrow(/virtual node/i);
|
|
70
|
+
});
|
|
71
|
+
it('throws when group references Trigger', () => {
|
|
72
|
+
const groups = [makeGroup('g1', 'Trigger', 'c', ['a', 'b', 'c'])];
|
|
73
|
+
expect(() => buildStructureTree(modules, groups)).toThrow(/virtual node/i);
|
|
74
|
+
});
|
|
75
|
+
it('allows fully nested groups', () => {
|
|
76
|
+
const mods = [makeModule('a'), makeModule('b'), makeModule('c'), makeModule('d')];
|
|
77
|
+
const groups = [
|
|
78
|
+
makeGroup('outer', 'a', 'd', ['a', 'b', 'c', 'd']),
|
|
79
|
+
makeGroup('inner', 'b', 'c', ['b', 'c'])
|
|
80
|
+
];
|
|
81
|
+
const result = buildStructureTree(mods, groups);
|
|
82
|
+
expect(result).toHaveLength(1); // outer group contains everything
|
|
83
|
+
expect(result[0].kind).toBe('group');
|
|
84
|
+
// Inner group should be nested
|
|
85
|
+
const outerChildren = result[0].branches[0].children;
|
|
86
|
+
expect(outerChildren).toHaveLength(3); // a, inner-group, d
|
|
87
|
+
expect(outerChildren[1].kind).toBe('group');
|
|
88
|
+
expect(outerChildren[1].id).toBe('inner');
|
|
89
|
+
});
|
|
90
|
+
it('handles empty modules', () => {
|
|
91
|
+
const result = buildStructureTree([], []);
|
|
92
|
+
expect(result).toHaveLength(0);
|
|
93
|
+
});
|
|
94
|
+
it('handles container modules (forloop)', () => {
|
|
95
|
+
const mods = [makeForloop('loop', ['x', 'y']), makeModule('c')];
|
|
96
|
+
const result = buildStructureTree(mods, []);
|
|
97
|
+
expect(result).toHaveLength(2);
|
|
98
|
+
expect(result[0].kind).toBe('forloopflow');
|
|
99
|
+
expect(result[0].branches).toHaveLength(1);
|
|
100
|
+
expect(result[0].branches[0].children).toHaveLength(2);
|
|
101
|
+
expect(result[0].branches[0].children[0].id).toBe('x');
|
|
102
|
+
});
|
|
103
|
+
it('handles groups inside containers', () => {
|
|
104
|
+
const mods = [makeForloop('loop', ['x', 'y', 'z'])];
|
|
105
|
+
const groups = [makeGroup('g1', 'x', 'y', ['x', 'y'])];
|
|
106
|
+
const result = buildStructureTree(mods, groups);
|
|
107
|
+
expect(result).toHaveLength(1);
|
|
108
|
+
expect(result[0].kind).toBe('forloopflow');
|
|
109
|
+
const innerChildren = result[0].branches[0].children;
|
|
110
|
+
expect(innerChildren).toHaveLength(2); // group + z
|
|
111
|
+
expect(innerChildren[0].kind).toBe('group');
|
|
112
|
+
expect(innerChildren[0].id).toBe('g1');
|
|
113
|
+
});
|
|
114
|
+
it('throws when group spans parallel branches (branchall)', () => {
|
|
115
|
+
const mods = [
|
|
116
|
+
makeModule('a'),
|
|
117
|
+
makeBranchAll('ba', [
|
|
118
|
+
['x', 'y'],
|
|
119
|
+
['p', 'q']
|
|
120
|
+
]),
|
|
121
|
+
makeModule('c')
|
|
122
|
+
];
|
|
123
|
+
const groups = [makeGroup('g1', 'x', 'q', ['x', 'q'])];
|
|
124
|
+
expect(() => buildStructureTree(mods, groups)).toThrow(/could not be resolved/);
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
describe('flattenStructureIds', () => {
|
|
128
|
+
it('flattens a simple tree', () => {
|
|
129
|
+
const modules = [makeModule('a'), makeModule('b'), makeModule('c')];
|
|
130
|
+
const groups = [makeGroup('g1', 'a', 'b', ['a', 'b'])];
|
|
131
|
+
const tree = buildStructureTree(modules, groups);
|
|
132
|
+
const ids = flattenStructureIds(tree);
|
|
133
|
+
expect(ids).toEqual(['a', 'b', 'c']);
|
|
134
|
+
});
|
|
135
|
+
it('flattens nested groups', () => {
|
|
136
|
+
const mods = [makeModule('a'), makeModule('b'), makeModule('c'), makeModule('d')];
|
|
137
|
+
const groups = [
|
|
138
|
+
makeGroup('outer', 'a', 'd', ['a', 'b', 'c', 'd']),
|
|
139
|
+
makeGroup('inner', 'b', 'c', ['b', 'c'])
|
|
140
|
+
];
|
|
141
|
+
const tree = buildStructureTree(mods, groups);
|
|
142
|
+
const ids = flattenStructureIds(tree);
|
|
143
|
+
expect(ids).toEqual(['a', 'b', 'c', 'd']);
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
describe('deriveGroupsFromStructure', () => {
|
|
147
|
+
it('derives group definitions with correct start/end', () => {
|
|
148
|
+
const modules = [makeModule('a'), makeModule('b'), makeModule('c')];
|
|
149
|
+
const groups = [makeGroup('g1', 'a', 'b', ['a', 'b'])];
|
|
150
|
+
const tree = buildStructureTree(modules, groups);
|
|
151
|
+
const derived = deriveGroupsFromStructure(tree);
|
|
152
|
+
expect(derived).toHaveLength(1);
|
|
153
|
+
expect(derived[0].start_id).toBe('a');
|
|
154
|
+
expect(derived[0].end_id).toBe('b');
|
|
155
|
+
});
|
|
156
|
+
it('derives nested groups', () => {
|
|
157
|
+
const mods = [makeModule('a'), makeModule('b'), makeModule('c'), makeModule('d')];
|
|
158
|
+
const groups = [
|
|
159
|
+
makeGroup('outer', 'a', 'd', ['a', 'b', 'c', 'd']),
|
|
160
|
+
makeGroup('inner', 'b', 'c', ['b', 'c'])
|
|
161
|
+
];
|
|
162
|
+
const tree = buildStructureTree(mods, groups);
|
|
163
|
+
const derived = deriveGroupsFromStructure(tree);
|
|
164
|
+
expect(derived).toHaveLength(2);
|
|
165
|
+
expect(derived[0].start_id).toBe('a');
|
|
166
|
+
expect(derived[0].end_id).toBe('d');
|
|
167
|
+
expect(derived[1].start_id).toBe('b');
|
|
168
|
+
expect(derived[1].end_id).toBe('c');
|
|
169
|
+
});
|
|
170
|
+
});
|
|
171
|
+
describe('findInStructure', () => {
|
|
172
|
+
it('finds a leaf node', () => {
|
|
173
|
+
const modules = [makeModule('a'), makeModule('b')];
|
|
174
|
+
const tree = buildStructureTree(modules, []);
|
|
175
|
+
const found = findInStructure(tree, 'b');
|
|
176
|
+
expect(found).toBeDefined();
|
|
177
|
+
expect(found.index).toBe(1);
|
|
178
|
+
});
|
|
179
|
+
it('finds a node inside a group', () => {
|
|
180
|
+
const modules = [makeModule('a'), makeModule('b'), makeModule('c')];
|
|
181
|
+
const groups = [makeGroup('g1', 'a', 'b', ['a', 'b'])];
|
|
182
|
+
const tree = buildStructureTree(modules, groups);
|
|
183
|
+
const found = findInStructure(tree, 'b');
|
|
184
|
+
expect(found).toBeDefined();
|
|
185
|
+
expect(found.index).toBe(1);
|
|
186
|
+
// parentChildren should be the group's branch children
|
|
187
|
+
expect(found.parentChildren).toHaveLength(2);
|
|
188
|
+
});
|
|
189
|
+
it('finds a group node by group id', () => {
|
|
190
|
+
const modules = [makeModule('a'), makeModule('b')];
|
|
191
|
+
const groups = [makeGroup('g1', 'a', 'b', ['a', 'b'])];
|
|
192
|
+
const tree = buildStructureTree(modules, groups);
|
|
193
|
+
const found = findInStructure(tree, 'g1');
|
|
194
|
+
expect(found).toBeDefined();
|
|
195
|
+
expect(found.index).toBe(0);
|
|
196
|
+
});
|
|
197
|
+
});
|
|
198
|
+
describe('collectLeafIds', () => {
|
|
199
|
+
it('collects all leaf module IDs including inside containers', () => {
|
|
200
|
+
const mods = [makeForloop('loop', ['x', 'y']), makeModule('c')];
|
|
201
|
+
const tree = buildStructureTree(mods, []);
|
|
202
|
+
const ids = collectLeafIds(tree);
|
|
203
|
+
expect(ids).toEqual(['loop', 'x', 'y', 'c']);
|
|
204
|
+
});
|
|
205
|
+
});
|