@foresthubai/workflow-builder 0.3.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/LICENSE +661 -0
- package/NOTICE +16 -0
- package/README.md +93 -0
- package/dist/BuilderLayout.d.ts +34 -0
- package/dist/BuilderLayout.d.ts.map +1 -0
- package/dist/BuilderLayout.js +172 -0
- package/dist/BuilderLayout.js.map +1 -0
- package/dist/Canvas.d.ts +23 -0
- package/dist/Canvas.d.ts.map +1 -0
- package/dist/Canvas.js +141 -0
- package/dist/Canvas.js.map +1 -0
- package/dist/CanvasEditor.d.ts +46 -0
- package/dist/CanvasEditor.d.ts.map +1 -0
- package/dist/CanvasEditor.js +57 -0
- package/dist/CanvasEditor.js.map +1 -0
- package/dist/CanvasTabsToolbar.d.ts +11 -0
- package/dist/CanvasTabsToolbar.d.ts.map +1 -0
- package/dist/CanvasTabsToolbar.js +101 -0
- package/dist/CanvasTabsToolbar.js.map +1 -0
- package/dist/RightConfigPanel.d.ts +27 -0
- package/dist/RightConfigPanel.d.ts.map +1 -0
- package/dist/RightConfigPanel.js +102 -0
- package/dist/RightConfigPanel.js.map +1 -0
- package/dist/WorkflowBuilder.d.ts +62 -0
- package/dist/WorkflowBuilder.d.ts.map +1 -0
- package/dist/WorkflowBuilder.js +275 -0
- package/dist/WorkflowBuilder.js.map +1 -0
- package/dist/cn.d.ts +3 -0
- package/dist/cn.d.ts.map +1 -0
- package/dist/cn.js +6 -0
- package/dist/cn.js.map +1 -0
- package/dist/components/ui/add-button.d.ts +16 -0
- package/dist/components/ui/add-button.d.ts.map +1 -0
- package/dist/components/ui/add-button.js +21 -0
- package/dist/components/ui/add-button.js.map +1 -0
- package/dist/components/ui/alert-dialog.d.ts +21 -0
- package/dist/components/ui/alert-dialog.d.ts.map +1 -0
- package/dist/components/ui/alert-dialog.js +30 -0
- package/dist/components/ui/alert-dialog.js.map +1 -0
- package/dist/components/ui/alert.d.ts +9 -0
- package/dist/components/ui/alert.d.ts.map +1 -0
- package/dist/components/ui/alert.js +23 -0
- package/dist/components/ui/alert.js.map +1 -0
- package/dist/components/ui/badge.d.ts +10 -0
- package/dist/components/ui/badge.d.ts.map +1 -0
- package/dist/components/ui/badge.js +21 -0
- package/dist/components/ui/badge.js.map +1 -0
- package/dist/components/ui/button.d.ts +13 -0
- package/dist/components/ui/button.d.ts.map +1 -0
- package/dist/components/ui/button.js +40 -0
- package/dist/components/ui/button.js.map +1 -0
- package/dist/components/ui/card.d.ts +9 -0
- package/dist/components/ui/card.d.ts.map +1 -0
- package/dist/components/ui/card.js +17 -0
- package/dist/components/ui/card.js.map +1 -0
- package/dist/components/ui/checkbox.d.ts +5 -0
- package/dist/components/ui/checkbox.d.ts.map +1 -0
- package/dist/components/ui/checkbox.js +9 -0
- package/dist/components/ui/checkbox.js.map +1 -0
- package/dist/components/ui/collapsible.d.ts +6 -0
- package/dist/components/ui/collapsible.d.ts.map +1 -0
- package/dist/components/ui/collapsible.js +6 -0
- package/dist/components/ui/collapsible.js.map +1 -0
- package/dist/components/ui/command.d.ts +82 -0
- package/dist/components/ui/command.d.ts.map +1 -0
- package/dist/components/ui/command.js +29 -0
- package/dist/components/ui/command.js.map +1 -0
- package/dist/components/ui/delete-button.d.ts +11 -0
- package/dist/components/ui/delete-button.d.ts.map +1 -0
- package/dist/components/ui/delete-button.js +14 -0
- package/dist/components/ui/delete-button.js.map +1 -0
- package/dist/components/ui/dialog.d.ts +22 -0
- package/dist/components/ui/dialog.d.ts.map +1 -0
- package/dist/components/ui/dialog.js +27 -0
- package/dist/components/ui/dialog.js.map +1 -0
- package/dist/components/ui/dropdown-menu.d.ts +28 -0
- package/dist/components/ui/dropdown-menu.d.ts.map +1 -0
- package/dist/components/ui/dropdown-menu.js +36 -0
- package/dist/components/ui/dropdown-menu.js.map +1 -0
- package/dist/components/ui/input.d.ts +13 -0
- package/dist/components/ui/input.d.ts.map +1 -0
- package/dist/components/ui/input.js +34 -0
- package/dist/components/ui/input.js.map +1 -0
- package/dist/components/ui/label.d.ts +6 -0
- package/dist/components/ui/label.d.ts.map +1 -0
- package/dist/components/ui/label.js +10 -0
- package/dist/components/ui/label.js.map +1 -0
- package/dist/components/ui/readonly-banner.d.ts +7 -0
- package/dist/components/ui/readonly-banner.d.ts.map +1 -0
- package/dist/components/ui/readonly-banner.js +12 -0
- package/dist/components/ui/readonly-banner.js.map +1 -0
- package/dist/components/ui/resizable.d.ts +24 -0
- package/dist/components/ui/resizable.d.ts.map +1 -0
- package/dist/components/ui/resizable.js +9 -0
- package/dist/components/ui/resizable.js.map +1 -0
- package/dist/components/ui/scroll-area.d.ts +45 -0
- package/dist/components/ui/scroll-area.d.ts.map +1 -0
- package/dist/components/ui/scroll-area.js +27 -0
- package/dist/components/ui/scroll-area.js.map +1 -0
- package/dist/components/ui/select.d.ts +14 -0
- package/dist/components/ui/select.d.ts.map +1 -0
- package/dist/components/ui/select.js +30 -0
- package/dist/components/ui/select.js.map +1 -0
- package/dist/components/ui/separator.d.ts +5 -0
- package/dist/components/ui/separator.d.ts.map +1 -0
- package/dist/components/ui/separator.js +8 -0
- package/dist/components/ui/separator.js.map +1 -0
- package/dist/components/ui/switch.d.ts +5 -0
- package/dist/components/ui/switch.d.ts.map +1 -0
- package/dist/components/ui/switch.js +8 -0
- package/dist/components/ui/switch.js.map +1 -0
- package/dist/components/ui/textarea.d.ts +12 -0
- package/dist/components/ui/textarea.d.ts.map +1 -0
- package/dist/components/ui/textarea.js +34 -0
- package/dist/components/ui/textarea.js.map +1 -0
- package/dist/components/ui/toast.d.ts +16 -0
- package/dist/components/ui/toast.d.ts.map +1 -0
- package/dist/components/ui/toast.js +34 -0
- package/dist/components/ui/toast.js.map +1 -0
- package/dist/components/ui/toaster.d.ts +2 -0
- package/dist/components/ui/toaster.d.ts.map +1 -0
- package/dist/components/ui/toaster.js +10 -0
- package/dist/components/ui/toaster.js.map +1 -0
- package/dist/components/ui/toggle-group.d.ts +13 -0
- package/dist/components/ui/toggle-group.d.ts.map +1 -0
- package/dist/components/ui/toggle-group.js +21 -0
- package/dist/components/ui/toggle-group.js.map +1 -0
- package/dist/components/ui/toggle.d.ts +13 -0
- package/dist/components/ui/toggle.d.ts.map +1 -0
- package/dist/components/ui/toggle.js +26 -0
- package/dist/components/ui/toggle.js.map +1 -0
- package/dist/components/ui/tooltip.d.ts +8 -0
- package/dist/components/ui/tooltip.d.ts.map +1 -0
- package/dist/components/ui/tooltip.js +14 -0
- package/dist/components/ui/tooltip.js.map +1 -0
- package/dist/dialogs/NodePickerDialog.d.ts +10 -0
- package/dist/dialogs/NodePickerDialog.d.ts.map +1 -0
- package/dist/dialogs/NodePickerDialog.js +39 -0
- package/dist/dialogs/NodePickerDialog.js.map +1 -0
- package/dist/dialogs/ValidationDialog.d.ts +17 -0
- package/dist/dialogs/ValidationDialog.d.ts.map +1 -0
- package/dist/dialogs/ValidationDialog.js +29 -0
- package/dist/dialogs/ValidationDialog.js.map +1 -0
- package/dist/graph/BaseNode.d.ts +9 -0
- package/dist/graph/BaseNode.d.ts.map +1 -0
- package/dist/graph/BaseNode.js +318 -0
- package/dist/graph/BaseNode.js.map +1 -0
- package/dist/graph/CustomEdge.d.ts +14 -0
- package/dist/graph/CustomEdge.d.ts.map +1 -0
- package/dist/graph/CustomEdge.js +107 -0
- package/dist/graph/CustomEdge.js.map +1 -0
- package/dist/graph/CustomNode.d.ts +3 -0
- package/dist/graph/CustomNode.d.ts.map +1 -0
- package/dist/graph/CustomNode.js +15 -0
- package/dist/graph/CustomNode.js.map +1 -0
- package/dist/graph/FunctionCallNode.d.ts +3 -0
- package/dist/graph/FunctionCallNode.d.ts.map +1 -0
- package/dist/graph/FunctionCallNode.js +25 -0
- package/dist/graph/FunctionCallNode.js.map +1 -0
- package/dist/graph/PortHandle.d.ts +21 -0
- package/dist/graph/PortHandle.d.ts.map +1 -0
- package/dist/graph/PortHandle.js +113 -0
- package/dist/graph/PortHandle.js.map +1 -0
- package/dist/graph/reactFlowRegistry.d.ts +65 -0
- package/dist/graph/reactFlowRegistry.d.ts.map +1 -0
- package/dist/graph/reactFlowRegistry.js +24 -0
- package/dist/graph/reactFlowRegistry.js.map +1 -0
- package/dist/hooks/use-toast.d.ts +47 -0
- package/dist/hooks/use-toast.d.ts.map +1 -0
- package/dist/hooks/use-toast.js +95 -0
- package/dist/hooks/use-toast.js.map +1 -0
- package/dist/hooks/useAvailableVariables.d.ts +12 -0
- package/dist/hooks/useAvailableVariables.d.ts.map +1 -0
- package/dist/hooks/useAvailableVariables.js +16 -0
- package/dist/hooks/useAvailableVariables.js.map +1 -0
- package/dist/hooks/useCanvasHistory.d.ts +14 -0
- package/dist/hooks/useCanvasHistory.d.ts.map +1 -0
- package/dist/hooks/useCanvasHistory.js +20 -0
- package/dist/hooks/useCanvasHistory.js.map +1 -0
- package/dist/hooks/useCanvasTabs.d.ts +23 -0
- package/dist/hooks/useCanvasTabs.d.ts.map +1 -0
- package/dist/hooks/useCanvasTabs.js +136 -0
- package/dist/hooks/useCanvasTabs.js.map +1 -0
- package/dist/hooks/useFunctionDiagnosticsSync.d.ts +14 -0
- package/dist/hooks/useFunctionDiagnosticsSync.d.ts.map +1 -0
- package/dist/hooks/useFunctionDiagnosticsSync.js +38 -0
- package/dist/hooks/useFunctionDiagnosticsSync.js.map +1 -0
- package/dist/hooks/useFunctionRegistry.d.ts +15 -0
- package/dist/hooks/useFunctionRegistry.d.ts.map +1 -0
- package/dist/hooks/useFunctionRegistry.js +22 -0
- package/dist/hooks/useFunctionRegistry.js.map +1 -0
- package/dist/hooks/useFunctions.d.ts +15 -0
- package/dist/hooks/useFunctions.d.ts.map +1 -0
- package/dist/hooks/useFunctions.js +34 -0
- package/dist/hooks/useFunctions.js.map +1 -0
- package/dist/hooks/useGraph.d.ts +40 -0
- package/dist/hooks/useGraph.d.ts.map +1 -0
- package/dist/hooks/useGraph.js +102 -0
- package/dist/hooks/useGraph.js.map +1 -0
- package/dist/hooks/useNodeDefinitions.d.ts +17 -0
- package/dist/hooks/useNodeDefinitions.d.ts.map +1 -0
- package/dist/hooks/useNodeDefinitions.js +65 -0
- package/dist/hooks/useNodeDefinitions.js.map +1 -0
- package/dist/hooks/useParamErrors.d.ts +12 -0
- package/dist/hooks/useParamErrors.d.ts.map +1 -0
- package/dist/hooks/useParamErrors.js +28 -0
- package/dist/hooks/useParamErrors.js.map +1 -0
- package/dist/hooks/useResolvedTheme.d.ts +10 -0
- package/dist/hooks/useResolvedTheme.d.ts.map +1 -0
- package/dist/hooks/useResolvedTheme.js +29 -0
- package/dist/hooks/useResolvedTheme.js.map +1 -0
- package/dist/hooks/useResourceDiagnosticsSync.d.ts +40 -0
- package/dist/hooks/useResourceDiagnosticsSync.d.ts.map +1 -0
- package/dist/hooks/useResourceDiagnosticsSync.js +39 -0
- package/dist/hooks/useResourceDiagnosticsSync.js.map +1 -0
- package/dist/hooks/useSuppressThemeTransition.d.ts +32 -0
- package/dist/hooks/useSuppressThemeTransition.d.ts.map +1 -0
- package/dist/hooks/useSuppressThemeTransition.js +75 -0
- package/dist/hooks/useSuppressThemeTransition.js.map +1 -0
- package/dist/hooks/useWorkflowSerialization.d.ts +24 -0
- package/dist/hooks/useWorkflowSerialization.d.ts.map +1 -0
- package/dist/hooks/useWorkflowSerialization.js +113 -0
- package/dist/hooks/useWorkflowSerialization.js.map +1 -0
- package/dist/i18n/index.d.ts +4 -0
- package/dist/i18n/index.d.ts.map +1 -0
- package/dist/i18n/index.js +46 -0
- package/dist/i18n/index.js.map +1 -0
- package/dist/i18n/locales/de.json +501 -0
- package/dist/i18n/locales/en.json +557 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +12 -0
- package/dist/index.js.map +1 -0
- package/dist/inputs/ExpressionInput.d.ts +12 -0
- package/dist/inputs/ExpressionInput.d.ts.map +1 -0
- package/dist/inputs/ExpressionInput.js +203 -0
- package/dist/inputs/ExpressionInput.js.map +1 -0
- package/dist/inputs/ParameterEditor.d.ts +13 -0
- package/dist/inputs/ParameterEditor.d.ts.map +1 -0
- package/dist/inputs/ParameterEditor.js +204 -0
- package/dist/inputs/ParameterEditor.js.map +1 -0
- package/dist/inputs/PortSection.d.ts +31 -0
- package/dist/inputs/PortSection.d.ts.map +1 -0
- package/dist/inputs/PortSection.js +26 -0
- package/dist/inputs/PortSection.js.map +1 -0
- package/dist/panels/BuilderSidebar.d.ts +24 -0
- package/dist/panels/BuilderSidebar.d.ts.map +1 -0
- package/dist/panels/BuilderSidebar.js +202 -0
- package/dist/panels/BuilderSidebar.js.map +1 -0
- package/dist/panels/ChannelConfigPanel.d.ts +8 -0
- package/dist/panels/ChannelConfigPanel.d.ts.map +1 -0
- package/dist/panels/ChannelConfigPanel.js +26 -0
- package/dist/panels/ChannelConfigPanel.js.map +1 -0
- package/dist/panels/ChannelsPanel.d.ts +2 -0
- package/dist/panels/ChannelsPanel.d.ts.map +1 -0
- package/dist/panels/ChannelsPanel.js +16 -0
- package/dist/panels/ChannelsPanel.js.map +1 -0
- package/dist/panels/DebugConsolePanel.d.ts +2 -0
- package/dist/panels/DebugConsolePanel.d.ts.map +1 -0
- package/dist/panels/DebugConsolePanel.js +32 -0
- package/dist/panels/DebugConsolePanel.js.map +1 -0
- package/dist/panels/DebugContextPanel.d.ts +2 -0
- package/dist/panels/DebugContextPanel.d.ts.map +1 -0
- package/dist/panels/DebugContextPanel.js +32 -0
- package/dist/panels/DebugContextPanel.js.map +1 -0
- package/dist/panels/DebugExternalIOPanel.d.ts +9 -0
- package/dist/panels/DebugExternalIOPanel.d.ts.map +1 -0
- package/dist/panels/DebugExternalIOPanel.js +66 -0
- package/dist/panels/DebugExternalIOPanel.js.map +1 -0
- package/dist/panels/DiagnosticsPanel.d.ts +8 -0
- package/dist/panels/DiagnosticsPanel.d.ts.map +1 -0
- package/dist/panels/DiagnosticsPanel.js +86 -0
- package/dist/panels/DiagnosticsPanel.js.map +1 -0
- package/dist/panels/EdgeConfigPanel.d.ts +14 -0
- package/dist/panels/EdgeConfigPanel.d.ts.map +1 -0
- package/dist/panels/EdgeConfigPanel.js +34 -0
- package/dist/panels/EdgeConfigPanel.js.map +1 -0
- package/dist/panels/FunctionConfigPanel.d.ts +16 -0
- package/dist/panels/FunctionConfigPanel.d.ts.map +1 -0
- package/dist/panels/FunctionConfigPanel.js +62 -0
- package/dist/panels/FunctionConfigPanel.js.map +1 -0
- package/dist/panels/FunctionListPanel.d.ts +14 -0
- package/dist/panels/FunctionListPanel.d.ts.map +1 -0
- package/dist/panels/FunctionListPanel.js +25 -0
- package/dist/panels/FunctionListPanel.js.map +1 -0
- package/dist/panels/MemoryConfigPanel.d.ts +8 -0
- package/dist/panels/MemoryConfigPanel.d.ts.map +1 -0
- package/dist/panels/MemoryConfigPanel.js +22 -0
- package/dist/panels/MemoryConfigPanel.js.map +1 -0
- package/dist/panels/MemoryPanel.d.ts +2 -0
- package/dist/panels/MemoryPanel.d.ts.map +1 -0
- package/dist/panels/MemoryPanel.js +25 -0
- package/dist/panels/MemoryPanel.js.map +1 -0
- package/dist/panels/ModelConfigPanel.d.ts +8 -0
- package/dist/panels/ModelConfigPanel.d.ts.map +1 -0
- package/dist/panels/ModelConfigPanel.js +14 -0
- package/dist/panels/ModelConfigPanel.js.map +1 -0
- package/dist/panels/ModelsPanel.d.ts +8 -0
- package/dist/panels/ModelsPanel.d.ts.map +1 -0
- package/dist/panels/ModelsPanel.js +24 -0
- package/dist/panels/ModelsPanel.js.map +1 -0
- package/dist/panels/NodeConfigPanel.d.ts +16 -0
- package/dist/panels/NodeConfigPanel.d.ts.map +1 -0
- package/dist/panels/NodeConfigPanel.js +248 -0
- package/dist/panels/NodeConfigPanel.js.map +1 -0
- package/dist/panels/NodeLibrary.d.ts +16 -0
- package/dist/panels/NodeLibrary.d.ts.map +1 -0
- package/dist/panels/NodeLibrary.js +125 -0
- package/dist/panels/NodeLibrary.js.map +1 -0
- package/dist/panels/ResourceConfigPanel.d.ts +37 -0
- package/dist/panels/ResourceConfigPanel.d.ts.map +1 -0
- package/dist/panels/ResourceConfigPanel.js +35 -0
- package/dist/panels/ResourceConfigPanel.js.map +1 -0
- package/dist/panels/ResourceListPanel.d.ts +35 -0
- package/dist/panels/ResourceListPanel.d.ts.map +1 -0
- package/dist/panels/ResourceListPanel.js +35 -0
- package/dist/panels/ResourceListPanel.js.map +1 -0
- package/dist/panels/VariableConfigPanel.d.ts +9 -0
- package/dist/panels/VariableConfigPanel.d.ts.map +1 -0
- package/dist/panels/VariableConfigPanel.js +50 -0
- package/dist/panels/VariableConfigPanel.js.map +1 -0
- package/dist/panels/VariablesPanel.d.ts +7 -0
- package/dist/panels/VariablesPanel.d.ts.map +1 -0
- package/dist/panels/VariablesPanel.js +56 -0
- package/dist/panels/VariablesPanel.js.map +1 -0
- package/dist/stores/canvasStore.d.ts +41 -0
- package/dist/stores/canvasStore.d.ts.map +1 -0
- package/dist/stores/canvasStore.js +187 -0
- package/dist/stores/canvasStore.js.map +1 -0
- package/dist/stores/debugStore.d.ts +42 -0
- package/dist/stores/debugStore.d.ts.map +1 -0
- package/dist/stores/debugStore.js +22 -0
- package/dist/stores/debugStore.js.map +1 -0
- package/dist/stores/diagnosticsStore.d.ts +41 -0
- package/dist/stores/diagnosticsStore.d.ts.map +1 -0
- package/dist/stores/diagnosticsStore.js +67 -0
- package/dist/stores/diagnosticsStore.js.map +1 -0
- package/dist/stores/editorStore.d.ts +76 -0
- package/dist/stores/editorStore.d.ts.map +1 -0
- package/dist/stores/editorStore.js +116 -0
- package/dist/stores/editorStore.js.map +1 -0
- package/dist/utils/categoryConstants.d.ts +4 -0
- package/dist/utils/categoryConstants.d.ts.map +1 -0
- package/dist/utils/categoryConstants.js +24 -0
- package/dist/utils/categoryConstants.js.map +1 -0
- package/dist/utils/channelOperations.d.ts +21 -0
- package/dist/utils/channelOperations.d.ts.map +1 -0
- package/dist/utils/channelOperations.js +84 -0
- package/dist/utils/channelOperations.js.map +1 -0
- package/dist/utils/connectionRules.d.ts +15 -0
- package/dist/utils/connectionRules.d.ts.map +1 -0
- package/dist/utils/connectionRules.js +113 -0
- package/dist/utils/connectionRules.js.map +1 -0
- package/dist/utils/functionOperations.d.ts +27 -0
- package/dist/utils/functionOperations.d.ts.map +1 -0
- package/dist/utils/functionOperations.js +140 -0
- package/dist/utils/functionOperations.js.map +1 -0
- package/dist/utils/graphOperations.d.ts +54 -0
- package/dist/utils/graphOperations.d.ts.map +1 -0
- package/dist/utils/graphOperations.js +461 -0
- package/dist/utils/graphOperations.js.map +1 -0
- package/dist/utils/history.d.ts +76 -0
- package/dist/utils/history.d.ts.map +1 -0
- package/dist/utils/history.js +93 -0
- package/dist/utils/history.js.map +1 -0
- package/dist/utils/memoryOperations.d.ts +14 -0
- package/dist/utils/memoryOperations.d.ts.map +1 -0
- package/dist/utils/memoryOperations.js +55 -0
- package/dist/utils/memoryOperations.js.map +1 -0
- package/dist/utils/migrateFunctionNodes.d.ts +9 -0
- package/dist/utils/migrateFunctionNodes.d.ts.map +1 -0
- package/dist/utils/migrateFunctionNodes.js +89 -0
- package/dist/utils/migrateFunctionNodes.js.map +1 -0
- package/dist/utils/modelOperations.d.ts +13 -0
- package/dist/utils/modelOperations.d.ts.map +1 -0
- package/dist/utils/modelOperations.js +53 -0
- package/dist/utils/modelOperations.js.map +1 -0
- package/dist/utils/paramDisplay.d.ts +12 -0
- package/dist/utils/paramDisplay.d.ts.map +1 -0
- package/dist/utils/paramDisplay.js +56 -0
- package/dist/utils/paramDisplay.js.map +1 -0
- package/dist/utils/resourceHelpers.d.ts +17 -0
- package/dist/utils/resourceHelpers.d.ts.map +1 -0
- package/dist/utils/resourceHelpers.js +32 -0
- package/dist/utils/resourceHelpers.js.map +1 -0
- package/dist/utils/translation.d.ts +20 -0
- package/dist/utils/translation.d.ts.map +1 -0
- package/dist/utils/translation.js +23 -0
- package/dist/utils/translation.js.map +1 -0
- package/dist/utils/variableOperations.d.ts +15 -0
- package/dist/utils/variableOperations.d.ts.map +1 -0
- package/dist/utils/variableOperations.js +71 -0
- package/dist/utils/variableOperations.js.map +1 -0
- package/package.json +79 -0
- package/src/BuilderLayout.tsx +345 -0
- package/src/Canvas.tsx +261 -0
- package/src/CanvasEditor.tsx +142 -0
- package/src/CanvasTabsToolbar.tsx +176 -0
- package/src/RightConfigPanel.tsx +266 -0
- package/src/WorkflowBuilder.tsx +412 -0
- package/src/cn.ts +6 -0
- package/src/components/ui/add-button.tsx +39 -0
- package/src/components/ui/alert-dialog.tsx +141 -0
- package/src/components/ui/alert.tsx +59 -0
- package/src/components/ui/badge.tsx +36 -0
- package/src/components/ui/button.tsx +85 -0
- package/src/components/ui/card.tsx +79 -0
- package/src/components/ui/checkbox.tsx +28 -0
- package/src/components/ui/collapsible.tsx +9 -0
- package/src/components/ui/command.tsx +153 -0
- package/src/components/ui/delete-button.tsx +23 -0
- package/src/components/ui/dialog.tsx +125 -0
- package/src/components/ui/dropdown-menu.tsx +198 -0
- package/src/components/ui/input.tsx +55 -0
- package/src/components/ui/label.tsx +24 -0
- package/src/components/ui/readonly-banner.tsx +15 -0
- package/src/components/ui/resizable.tsx +43 -0
- package/src/components/ui/scroll-area.tsx +102 -0
- package/src/components/ui/select.tsx +160 -0
- package/src/components/ui/separator.tsx +29 -0
- package/src/components/ui/switch.tsx +27 -0
- package/src/components/ui/textarea.tsx +51 -0
- package/src/components/ui/toast.tsx +127 -0
- package/src/components/ui/toaster.tsx +33 -0
- package/src/components/ui/toggle-group.tsx +59 -0
- package/src/components/ui/toggle.tsx +43 -0
- package/src/components/ui/tooltip.tsx +32 -0
- package/src/dialogs/NodePickerDialog.tsx +84 -0
- package/src/dialogs/ValidationDialog.tsx +184 -0
- package/src/graph/BaseNode.tsx +557 -0
- package/src/graph/CustomEdge.tsx +185 -0
- package/src/graph/CustomNode.tsx +16 -0
- package/src/graph/FunctionCallNode.tsx +30 -0
- package/src/graph/PortHandle.tsx +189 -0
- package/src/graph/reactFlowRegistry.ts +26 -0
- package/src/hooks/use-toast.ts +125 -0
- package/src/hooks/useAvailableVariables.ts +20 -0
- package/src/hooks/useCanvasHistory.ts +22 -0
- package/src/hooks/useCanvasTabs.ts +168 -0
- package/src/hooks/useFunctionDiagnosticsSync.ts +40 -0
- package/src/hooks/useFunctionRegistry.ts +26 -0
- package/src/hooks/useFunctions.ts +44 -0
- package/src/hooks/useGraph.ts +161 -0
- package/src/hooks/useNodeDefinitions.ts +82 -0
- package/src/hooks/useParamErrors.ts +26 -0
- package/src/hooks/useResolvedTheme.ts +30 -0
- package/src/hooks/useResourceDiagnosticsSync.ts +58 -0
- package/src/hooks/useSuppressThemeTransition.ts +79 -0
- package/src/hooks/useWorkflowSerialization.ts +127 -0
- package/src/i18n/index.ts +53 -0
- package/src/i18n/locales/de.json +501 -0
- package/src/i18n/locales/en.json +557 -0
- package/src/index.ts +27 -0
- package/src/inputs/ExpressionInput.tsx +297 -0
- package/src/inputs/ParameterEditor.tsx +515 -0
- package/src/inputs/PortSection.tsx +144 -0
- package/src/panels/BuilderSidebar.tsx +301 -0
- package/src/panels/ChannelConfigPanel.tsx +49 -0
- package/src/panels/ChannelsPanel.tsx +28 -0
- package/src/panels/DebugConsolePanel.tsx +73 -0
- package/src/panels/DebugContextPanel.tsx +77 -0
- package/src/panels/DebugExternalIOPanel.tsx +180 -0
- package/src/panels/DiagnosticsPanel.tsx +170 -0
- package/src/panels/EdgeConfigPanel.tsx +104 -0
- package/src/panels/FunctionConfigPanel.tsx +179 -0
- package/src/panels/FunctionListPanel.tsx +45 -0
- package/src/panels/MemoryConfigPanel.tsx +55 -0
- package/src/panels/MemoryPanel.tsx +40 -0
- package/src/panels/ModelConfigPanel.tsx +41 -0
- package/src/panels/ModelsPanel.tsx +36 -0
- package/src/panels/NodeConfigPanel.tsx +630 -0
- package/src/panels/NodeLibrary.tsx +288 -0
- package/src/panels/ResourceConfigPanel.tsx +132 -0
- package/src/panels/ResourceListPanel.tsx +113 -0
- package/src/panels/VariableConfigPanel.tsx +161 -0
- package/src/panels/VariablesPanel.tsx +145 -0
- package/src/stores/canvasStore.test.ts +44 -0
- package/src/stores/canvasStore.ts +245 -0
- package/src/stores/debugStore.ts +74 -0
- package/src/stores/diagnosticsStore.ts +130 -0
- package/src/stores/editorStore.ts +202 -0
- package/src/styles/index.css +526 -0
- package/src/utils/categoryConstants.ts +26 -0
- package/src/utils/channelOperations.ts +86 -0
- package/src/utils/connectionRules.ts +137 -0
- package/src/utils/functionOperations.ts +179 -0
- package/src/utils/graphOperations.ts +550 -0
- package/src/utils/history.ts +207 -0
- package/src/utils/memoryOperations.ts +57 -0
- package/src/utils/migrateFunctionNodes.ts +107 -0
- package/src/utils/modelOperations.ts +55 -0
- package/src/utils/paramDisplay.ts +71 -0
- package/src/utils/resourceHelpers.ts +32 -0
- package/src/utils/translation.ts +28 -0
- package/src/utils/variableOperations.ts +75 -0
- package/tailwind-preset.ts +166 -0
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Handle, Position } from "@xyflow/react";
|
|
3
|
+
import { Plus } from "lucide-react";
|
|
4
|
+
export const PortHandle = ({ id, nodeId, type, position, portType, label, style, disabled, showPlus, }) => {
|
|
5
|
+
const getHandleStyle = () => {
|
|
6
|
+
const baseStyle = {
|
|
7
|
+
width: "12px",
|
|
8
|
+
height: "12px",
|
|
9
|
+
// Outline matches the canonical graph-line color (same as edges + node borders).
|
|
10
|
+
border: "2px solid hsl(var(--edge-default))",
|
|
11
|
+
};
|
|
12
|
+
if (disabled) {
|
|
13
|
+
return {
|
|
14
|
+
...baseStyle,
|
|
15
|
+
backgroundColor: "hsl(var(--muted-foreground) / 0.3)",
|
|
16
|
+
border: "2px solid hsl(var(--muted-foreground) / 0.4)",
|
|
17
|
+
borderRadius: portType === "control" ? "2px" : portType === "tool" ? "2px" : "50%",
|
|
18
|
+
opacity: 0.8,
|
|
19
|
+
cursor: "not-allowed",
|
|
20
|
+
...(portType === "tool" ? { clipPath: "polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%)" } : {}),
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
switch (portType) {
|
|
24
|
+
case "control":
|
|
25
|
+
// Square shape for execution/control ports. Fill matches the node body
|
|
26
|
+
// (--card) so the port reads as a recessed hole outlined in the graph color.
|
|
27
|
+
return {
|
|
28
|
+
...baseStyle,
|
|
29
|
+
backgroundColor: "hsl(var(--card))",
|
|
30
|
+
borderRadius: "2px",
|
|
31
|
+
};
|
|
32
|
+
case "tool":
|
|
33
|
+
// Diamond via clip-path so the handle stays anchored on the node edge
|
|
34
|
+
// (rotating it would override React Flow's centering transform). A
|
|
35
|
+
// clip-path can't show a border, so the handle background is the outline
|
|
36
|
+
// color and an inset inner diamond (rendered as a child below) paints the
|
|
37
|
+
// canonical tool fill (--node-tool), leaving a 2px edge-default outline.
|
|
38
|
+
return {
|
|
39
|
+
...baseStyle,
|
|
40
|
+
backgroundColor: "hsl(var(--edge-default))",
|
|
41
|
+
border: "none",
|
|
42
|
+
borderRadius: "0",
|
|
43
|
+
clipPath: "polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%)",
|
|
44
|
+
};
|
|
45
|
+
default:
|
|
46
|
+
// Circle shape as fallback
|
|
47
|
+
return {
|
|
48
|
+
...baseStyle,
|
|
49
|
+
backgroundColor: "white",
|
|
50
|
+
borderRadius: "50%",
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
const getLabelPositionClass = () => {
|
|
55
|
+
switch (position) {
|
|
56
|
+
case Position.Left:
|
|
57
|
+
return "right-full mr-3 text-right";
|
|
58
|
+
case Position.Right:
|
|
59
|
+
return "left-full ml-3 text-left";
|
|
60
|
+
case Position.Top:
|
|
61
|
+
return "bottom-full mb-2 text-center left-1/2 -translate-x-1/2";
|
|
62
|
+
case Position.Bottom:
|
|
63
|
+
return "top-full mt-2 text-center left-1/2 -translate-x-1/2";
|
|
64
|
+
default:
|
|
65
|
+
return "left-full ml-3 text-left";
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
const getLabelStyle = () => {
|
|
69
|
+
if (position === Position.Left || position === Position.Right) {
|
|
70
|
+
return {
|
|
71
|
+
top: "50%",
|
|
72
|
+
transform: "translateY(calc(-50% + 12px))",
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
return {};
|
|
76
|
+
};
|
|
77
|
+
const getPlusPositionClass = () => {
|
|
78
|
+
// Center with a negative margin (button is w-4 h-4 = 16px, so -8px = -2),
|
|
79
|
+
// NOT a translate. The hover effect uses `transform: scale()`, and reusing
|
|
80
|
+
// transform for centering too makes the translate drop out mid-animation,
|
|
81
|
+
// which both off-centers the plus and makes it jump on hover.
|
|
82
|
+
switch (position) {
|
|
83
|
+
case Position.Bottom:
|
|
84
|
+
return "top-[15px] left-1/2 -ml-2";
|
|
85
|
+
default:
|
|
86
|
+
return "left-[15px] top-1/2 -mt-2";
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
// Nudge the *visible* dot 1px toward the node interior so it sits on the
|
|
90
|
+
// outline centerline (the SVG border is strokeW=2). The offset is on a child,
|
|
91
|
+
// NOT the Handle — React Flow anchors edges to the Handle's measured box, so
|
|
92
|
+
// keeping that on the node edge means edges still connect flush instead of
|
|
93
|
+
// stopping 1px short.
|
|
94
|
+
const dotOffset = position === Position.Top
|
|
95
|
+
? "translateY(1px)"
|
|
96
|
+
: position === Position.Bottom
|
|
97
|
+
? "translateY(-1px)"
|
|
98
|
+
: position === Position.Left
|
|
99
|
+
? "translateX(1px)"
|
|
100
|
+
: "translateX(-1px)";
|
|
101
|
+
return (_jsxs("div", { className: "absolute z-20", style: style, children: [_jsx(Handle, { id: id, type: type, position: position, isConnectable: !disabled, style: { width: "12px", height: "12px", background: "transparent", border: "none", minWidth: 0, minHeight: 0 }, children: _jsx("div", { style: { ...getHandleStyle(), position: "absolute", inset: 0, transform: dotOffset, pointerEvents: "none" }, children: portType === "tool" && !disabled && (_jsx("div", { style: {
|
|
102
|
+
position: "absolute",
|
|
103
|
+
inset: "2px",
|
|
104
|
+
backgroundColor: "hsl(var(--node-tool))",
|
|
105
|
+
clipPath: "polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%)",
|
|
106
|
+
} })) }) }), label && !disabled && (_jsx("div", { className: `absolute text-xs text-muted-foreground pointer-events-none select-none whitespace-nowrap ${getLabelPositionClass()}`, style: getLabelStyle(), children: label })), showPlus && !disabled && nodeId && (_jsx("button", { type: "button", title: "Add port", className: `nodrag absolute flex items-center justify-center w-4 h-4 rounded-full bg-muted-foreground/60 text-card hover:bg-primary hover:scale-110 transition-all cursor-pointer ${getPlusPositionClass()}`, onClick: (e) => {
|
|
107
|
+
e.stopPropagation();
|
|
108
|
+
e.preventDefault();
|
|
109
|
+
const detail = { nodeId, handleId: id, portType };
|
|
110
|
+
e.currentTarget.dispatchEvent(new CustomEvent("port-plus-click", { detail, bubbles: true }));
|
|
111
|
+
}, onPointerDown: (e) => e.stopPropagation(), children: _jsx(Plus, { className: "w-2.5 h-2.5", strokeWidth: 3 }) }))] }));
|
|
112
|
+
};
|
|
113
|
+
//# sourceMappingURL=PortHandle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PortHandle.js","sourceRoot":"","sources":["../../src/graph/PortHandle.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
export declare const nodeTypes: {
|
|
2
|
+
Standard: import("react").MemoExoticComponent<(props: import("@xyflow/react").NodeProps) => import("react/jsx-runtime").JSX.Element>;
|
|
3
|
+
FunctionCall: import("react").MemoExoticComponent<(props: import("@xyflow/react").NodeProps) => import("react/jsx-runtime").JSX.Element>;
|
|
4
|
+
Trigger: import("react").MemoExoticComponent<(props: import("@xyflow/react").NodeProps) => import("react/jsx-runtime").JSX.Element>;
|
|
5
|
+
Tool: import("react").MemoExoticComponent<(props: import("@xyflow/react").NodeProps) => import("react/jsx-runtime").JSX.Element>;
|
|
6
|
+
AI: import("react").MemoExoticComponent<(props: import("@xyflow/react").NodeProps) => import("react/jsx-runtime").JSX.Element>;
|
|
7
|
+
};
|
|
8
|
+
export declare const edgeTypes: {
|
|
9
|
+
control: ({ id, source, type, sourceX, sourceY, targetX, targetY, data, selected, }: {
|
|
10
|
+
id: string;
|
|
11
|
+
source: string;
|
|
12
|
+
type: string;
|
|
13
|
+
sourceX: number;
|
|
14
|
+
sourceY: number;
|
|
15
|
+
targetX: number;
|
|
16
|
+
targetY: number;
|
|
17
|
+
data?: import("@foresthubai/workflow-core/edge").EdgeData;
|
|
18
|
+
selected?: boolean;
|
|
19
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
20
|
+
tool: ({ id, source, type, sourceX, sourceY, targetX, targetY, data, selected, }: {
|
|
21
|
+
id: string;
|
|
22
|
+
source: string;
|
|
23
|
+
type: string;
|
|
24
|
+
sourceX: number;
|
|
25
|
+
sourceY: number;
|
|
26
|
+
targetX: number;
|
|
27
|
+
targetY: number;
|
|
28
|
+
data?: import("@foresthubai/workflow-core/edge").EdgeData;
|
|
29
|
+
selected?: boolean;
|
|
30
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
31
|
+
agentTask: ({ id, source, type, sourceX, sourceY, targetX, targetY, data, selected, }: {
|
|
32
|
+
id: string;
|
|
33
|
+
source: string;
|
|
34
|
+
type: string;
|
|
35
|
+
sourceX: number;
|
|
36
|
+
sourceY: number;
|
|
37
|
+
targetX: number;
|
|
38
|
+
targetY: number;
|
|
39
|
+
data?: import("@foresthubai/workflow-core/edge").EdgeData;
|
|
40
|
+
selected?: boolean;
|
|
41
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
42
|
+
agentChoice: ({ id, source, type, sourceX, sourceY, targetX, targetY, data, selected, }: {
|
|
43
|
+
id: string;
|
|
44
|
+
source: string;
|
|
45
|
+
type: string;
|
|
46
|
+
sourceX: number;
|
|
47
|
+
sourceY: number;
|
|
48
|
+
targetX: number;
|
|
49
|
+
targetY: number;
|
|
50
|
+
data?: import("@foresthubai/workflow-core/edge").EdgeData;
|
|
51
|
+
selected?: boolean;
|
|
52
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
53
|
+
agentDelegate: ({ id, source, type, sourceX, sourceY, targetX, targetY, data, selected, }: {
|
|
54
|
+
id: string;
|
|
55
|
+
source: string;
|
|
56
|
+
type: string;
|
|
57
|
+
sourceX: number;
|
|
58
|
+
sourceY: number;
|
|
59
|
+
targetX: number;
|
|
60
|
+
targetY: number;
|
|
61
|
+
data?: import("@foresthubai/workflow-core/edge").EdgeData;
|
|
62
|
+
selected?: boolean;
|
|
63
|
+
}) => import("react/jsx-runtime").JSX.Element;
|
|
64
|
+
};
|
|
65
|
+
//# sourceMappingURL=reactFlowRegistry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reactFlowRegistry.d.ts","sourceRoot":"","sources":["../../src/graph/reactFlowRegistry.ts"],"names":[],"mappings":"AAWA,eAAO,MAAM,SAAS;;;;;;CAMrB,CAAC;AAEF,eAAO,MAAM,SAAS;;;;;;;;;YAOq9B,CAAC;gBAAuB,CAAC;;;;;;;;;;YAAzB,CAAC;gBAAuB,CAAC;;;;;;;;;;YAAzB,CAAC;gBAAuB,CAAC;;;;;;;;;;YAAzB,CAAC;gBAAuB,CAAC;;;;;;;;;;YAAzB,CAAC;gBAAuB,CAAC;;CADngC,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
// ReactFlow node/edge type registries
|
|
2
|
+
// Maps ReactFlow type strings to the React components that render them.
|
|
3
|
+
// Shared between CanvasArea (editor) and VersionPreviewCanvas (read-only preview).
|
|
4
|
+
// Lives in graph/ because it references sibling components, but is only consumed
|
|
5
|
+
// by higher-level composing components — no graph/ component imports this file.
|
|
6
|
+
import { NodeCategory } from "@foresthubai/workflow-core/node";
|
|
7
|
+
import { CustomNode } from "./CustomNode";
|
|
8
|
+
import { FunctionCallNode } from "./FunctionCallNode";
|
|
9
|
+
import CustomEdge from "./CustomEdge";
|
|
10
|
+
export const nodeTypes = {
|
|
11
|
+
Standard: CustomNode,
|
|
12
|
+
FunctionCall: FunctionCallNode,
|
|
13
|
+
[NodeCategory.Trigger]: CustomNode,
|
|
14
|
+
[NodeCategory.Tool]: CustomNode,
|
|
15
|
+
[NodeCategory.AI]: CustomNode,
|
|
16
|
+
};
|
|
17
|
+
export const edgeTypes = {
|
|
18
|
+
control: CustomEdge,
|
|
19
|
+
tool: CustomEdge,
|
|
20
|
+
agentTask: CustomEdge,
|
|
21
|
+
agentChoice: CustomEdge,
|
|
22
|
+
agentDelegate: CustomEdge,
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=reactFlowRegistry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reactFlowRegistry.js","sourceRoot":"","sources":["../../src/graph/reactFlowRegistry.ts"],"names":[],"mappings":"AAAA,sCAAsC;AACtC,wEAAwE;AACxE,mFAAmF;AACnF,iFAAiF;AACjF,gFAAgF;AAEhF,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,UAAU,MAAM,cAAc,CAAC;AAEtC,MAAM,CAAC,MAAM,SAAS,GAAG;IACvB,QAAQ,EAAE,UAAU;IACpB,YAAY,EAAE,gBAAgB;IAC9B,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,UAAU;IAClC,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,UAAU;IAC/B,CAAC,YAAY,CAAC,EAAE,CAAC,EAAE,UAAU;CAC9B,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAG;IACvB,OAAO,EAAE,UAAU;IACnB,IAAI,EAAE,UAAU;IAChB,SAAS,EAAE,UAAU;IACrB,WAAW,EAAE,UAAU;IACvB,aAAa,EAAE,UAAU;CAC1B,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import type { ToastActionElement, ToastProps } from "../components/ui/toast";
|
|
3
|
+
type ToasterToast = ToastProps & {
|
|
4
|
+
id: string;
|
|
5
|
+
title?: React.ReactNode;
|
|
6
|
+
description?: React.ReactNode;
|
|
7
|
+
action?: ToastActionElement;
|
|
8
|
+
};
|
|
9
|
+
declare const actionTypes: {
|
|
10
|
+
readonly ADD_TOAST: "ADD_TOAST";
|
|
11
|
+
readonly UPDATE_TOAST: "UPDATE_TOAST";
|
|
12
|
+
readonly DISMISS_TOAST: "DISMISS_TOAST";
|
|
13
|
+
readonly REMOVE_TOAST: "REMOVE_TOAST";
|
|
14
|
+
};
|
|
15
|
+
type ActionType = typeof actionTypes;
|
|
16
|
+
type Action = {
|
|
17
|
+
type: ActionType["ADD_TOAST"];
|
|
18
|
+
toast: ToasterToast;
|
|
19
|
+
} | {
|
|
20
|
+
type: ActionType["UPDATE_TOAST"];
|
|
21
|
+
toast: Partial<ToasterToast> & {
|
|
22
|
+
id: string;
|
|
23
|
+
};
|
|
24
|
+
} | {
|
|
25
|
+
type: ActionType["DISMISS_TOAST"];
|
|
26
|
+
toastId?: ToasterToast["id"];
|
|
27
|
+
} | {
|
|
28
|
+
type: ActionType["REMOVE_TOAST"];
|
|
29
|
+
toastId?: ToasterToast["id"];
|
|
30
|
+
};
|
|
31
|
+
interface State {
|
|
32
|
+
toasts: ToasterToast[];
|
|
33
|
+
}
|
|
34
|
+
export declare const reducer: (state: State, action: Action) => State;
|
|
35
|
+
type Toast = Omit<ToasterToast, "id">;
|
|
36
|
+
declare function toast({ ...props }: Toast): {
|
|
37
|
+
id: string;
|
|
38
|
+
dismiss: () => void;
|
|
39
|
+
update: (next: ToasterToast) => void;
|
|
40
|
+
};
|
|
41
|
+
declare function useToast(): {
|
|
42
|
+
toast: typeof toast;
|
|
43
|
+
dismiss: (toastId?: string) => void;
|
|
44
|
+
toasts: ToasterToast[];
|
|
45
|
+
};
|
|
46
|
+
export { useToast, toast };
|
|
47
|
+
//# sourceMappingURL=use-toast.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-toast.d.ts","sourceRoot":"","sources":["../../src/hooks/use-toast.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,KAAK,EAAE,kBAAkB,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAK7E,KAAK,YAAY,GAAG,UAAU,GAAG;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB,WAAW,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC9B,MAAM,CAAC,EAAE,kBAAkB,CAAC;CAC7B,CAAC;AAEF,QAAA,MAAM,WAAW;;;;;CAKP,CAAC;AAQX,KAAK,UAAU,GAAG,OAAO,WAAW,CAAC;AAErC,KAAK,MAAM,GACP;IAAE,IAAI,EAAE,UAAU,CAAC,WAAW,CAAC,CAAC;IAAC,KAAK,EAAE,YAAY,CAAA;CAAE,GACtD;IAAE,IAAI,EAAE,UAAU,CAAC,cAAc,CAAC,CAAC;IAAC,KAAK,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,GACnF;IAAE,IAAI,EAAE,UAAU,CAAC,eAAe,CAAC,CAAC;IAAC,OAAO,CAAC,EAAE,YAAY,CAAC,IAAI,CAAC,CAAA;CAAE,GACnE;IAAE,IAAI,EAAE,UAAU,CAAC,cAAc,CAAC,CAAC;IAAC,OAAO,CAAC,EAAE,YAAY,CAAC,IAAI,CAAC,CAAA;CAAE,CAAC;AAEvE,UAAU,KAAK;IACb,MAAM,EAAE,YAAY,EAAE,CAAC;CACxB;AAaD,eAAO,MAAM,OAAO,GAAI,OAAO,KAAK,EAAE,QAAQ,MAAM,KAAG,KAyBtD,CAAC;AAUF,KAAK,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;AAEtC,iBAAS,KAAK,CAAC,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK;;;mBAEV,YAAY;EAenC;AAED,iBAAS,QAAQ;;wBAaO,MAAM;YAnFpB,YAAY,EAAE;EAqFvB;AAED,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC"}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
// Standard shadcn toast hook + dispatcher
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
const TOAST_LIMIT = 1;
|
|
4
|
+
const TOAST_REMOVE_DELAY = 1_000_000;
|
|
5
|
+
const actionTypes = {
|
|
6
|
+
ADD_TOAST: "ADD_TOAST",
|
|
7
|
+
UPDATE_TOAST: "UPDATE_TOAST",
|
|
8
|
+
DISMISS_TOAST: "DISMISS_TOAST",
|
|
9
|
+
REMOVE_TOAST: "REMOVE_TOAST",
|
|
10
|
+
};
|
|
11
|
+
let count = 0;
|
|
12
|
+
function genId() {
|
|
13
|
+
count = (count + 1) % Number.MAX_SAFE_INTEGER;
|
|
14
|
+
return count.toString();
|
|
15
|
+
}
|
|
16
|
+
const toastTimeouts = new Map();
|
|
17
|
+
function addToRemoveQueue(toastId) {
|
|
18
|
+
if (toastTimeouts.has(toastId))
|
|
19
|
+
return;
|
|
20
|
+
const timeout = setTimeout(() => {
|
|
21
|
+
toastTimeouts.delete(toastId);
|
|
22
|
+
dispatch({ type: "REMOVE_TOAST", toastId });
|
|
23
|
+
}, TOAST_REMOVE_DELAY);
|
|
24
|
+
toastTimeouts.set(toastId, timeout);
|
|
25
|
+
}
|
|
26
|
+
export const reducer = (state, action) => {
|
|
27
|
+
switch (action.type) {
|
|
28
|
+
case "ADD_TOAST":
|
|
29
|
+
return { ...state, toasts: [action.toast, ...state.toasts].slice(0, TOAST_LIMIT) };
|
|
30
|
+
case "UPDATE_TOAST":
|
|
31
|
+
return {
|
|
32
|
+
...state,
|
|
33
|
+
toasts: state.toasts.map((t) => (t.id === action.toast.id ? { ...t, ...action.toast } : t)),
|
|
34
|
+
};
|
|
35
|
+
case "DISMISS_TOAST": {
|
|
36
|
+
const { toastId } = action;
|
|
37
|
+
if (toastId) {
|
|
38
|
+
addToRemoveQueue(toastId);
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
state.toasts.forEach((t) => addToRemoveQueue(t.id));
|
|
42
|
+
}
|
|
43
|
+
return {
|
|
44
|
+
...state,
|
|
45
|
+
toasts: state.toasts.map((t) => (t.id === toastId || toastId === undefined ? { ...t, open: false } : t)),
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
case "REMOVE_TOAST":
|
|
49
|
+
if (action.toastId === undefined)
|
|
50
|
+
return { ...state, toasts: [] };
|
|
51
|
+
return { ...state, toasts: state.toasts.filter((t) => t.id !== action.toastId) };
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
const listeners = [];
|
|
55
|
+
let memoryState = { toasts: [] };
|
|
56
|
+
function dispatch(action) {
|
|
57
|
+
memoryState = reducer(memoryState, action);
|
|
58
|
+
listeners.forEach((listener) => listener(memoryState));
|
|
59
|
+
}
|
|
60
|
+
function toast({ ...props }) {
|
|
61
|
+
const id = genId();
|
|
62
|
+
const update = (next) => dispatch({ type: "UPDATE_TOAST", toast: { ...next, id } });
|
|
63
|
+
const dismiss = () => dispatch({ type: "DISMISS_TOAST", toastId: id });
|
|
64
|
+
dispatch({
|
|
65
|
+
type: "ADD_TOAST",
|
|
66
|
+
toast: {
|
|
67
|
+
...props,
|
|
68
|
+
id,
|
|
69
|
+
open: true,
|
|
70
|
+
onOpenChange: (open) => {
|
|
71
|
+
if (!open)
|
|
72
|
+
dismiss();
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
});
|
|
76
|
+
return { id, dismiss, update };
|
|
77
|
+
}
|
|
78
|
+
function useToast() {
|
|
79
|
+
const [state, setState] = React.useState(memoryState);
|
|
80
|
+
React.useEffect(() => {
|
|
81
|
+
listeners.push(setState);
|
|
82
|
+
return () => {
|
|
83
|
+
const index = listeners.indexOf(setState);
|
|
84
|
+
if (index > -1)
|
|
85
|
+
listeners.splice(index, 1);
|
|
86
|
+
};
|
|
87
|
+
}, []);
|
|
88
|
+
return {
|
|
89
|
+
...state,
|
|
90
|
+
toast,
|
|
91
|
+
dismiss: (toastId) => dispatch({ type: "DISMISS_TOAST", toastId }),
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
export { useToast, toast };
|
|
95
|
+
//# sourceMappingURL=use-toast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-toast.js","sourceRoot":"","sources":["../../src/hooks/use-toast.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export type { Variable as AvailableVariable } from "@foresthubai/workflow-core/variable";
|
|
2
|
+
/**
|
|
3
|
+
* Hook that provides access to all available variables for a specific canvas.
|
|
4
|
+
* Each canvas is self-contained — main and function canvases do not share scope.
|
|
5
|
+
*
|
|
6
|
+
* Returns both an array (for iteration/UI) and a record (for O(1) lookup).
|
|
7
|
+
*/
|
|
8
|
+
export declare const useAvailableVariables: (canvasId?: string) => {
|
|
9
|
+
list: import("@foresthubai/workflow-core/variable").Variable[];
|
|
10
|
+
lookup: Record<string, import("@foresthubai/workflow-core/variable").Variable>;
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=useAvailableVariables.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useAvailableVariables.d.ts","sourceRoot":"","sources":["../../src/hooks/useAvailableVariables.ts"],"names":[],"mappings":"AAKA,YAAY,EAAE,QAAQ,IAAI,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAEzF;;;;;GAKG;AACH,eAAO,MAAM,qBAAqB,GAAI,WAAU,MAAuB;;;CAMtE,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { useMemo } from "react";
|
|
2
|
+
import { getOrCreateCanvasStore, MAIN_CANVAS_ID } from "../stores/canvasStore";
|
|
3
|
+
import { computeAvailableVariables } from "@foresthubai/workflow-core/variable";
|
|
4
|
+
/**
|
|
5
|
+
* Hook that provides access to all available variables for a specific canvas.
|
|
6
|
+
* Each canvas is self-contained — main and function canvases do not share scope.
|
|
7
|
+
*
|
|
8
|
+
* Returns both an array (for iteration/UI) and a record (for O(1) lookup).
|
|
9
|
+
*/
|
|
10
|
+
export const useAvailableVariables = (canvasId = MAIN_CANVAS_ID) => {
|
|
11
|
+
const store = getOrCreateCanvasStore(canvasId);
|
|
12
|
+
const variables = store((s) => s.variables);
|
|
13
|
+
const edges = store((s) => s.edges);
|
|
14
|
+
return useMemo(() => computeAvailableVariables(variables, edges), [variables, edges]);
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=useAvailableVariables.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useAvailableVariables.js","sourceRoot":"","sources":["../../src/hooks/useAvailableVariables.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAAE,sBAAsB,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC/E,OAAO,EAAE,yBAAyB,EAAE,MAAM,qCAAqC,CAAC;AAKhF;;;;;GAKG;AACH,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,WAAmB,cAAc,EAAE,EAAE;IACzE,MAAM,KAAK,GAAG,sBAAsB,CAAC,QAAQ,CAAC,CAAC;IAC/C,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAC5C,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAEpC,OAAO,OAAO,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC;AACxF,CAAC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook that exposes all history functions from a canvas store.
|
|
3
|
+
* Each canvas has its own independent undo/redo history.
|
|
4
|
+
*/
|
|
5
|
+
export declare const useCanvasHistory: (canvasId?: string) => {
|
|
6
|
+
undo: () => void;
|
|
7
|
+
redo: () => void;
|
|
8
|
+
takeCheckpoint: () => void;
|
|
9
|
+
withCheckpoint: <R>(operation: () => R) => R;
|
|
10
|
+
clearHistory: () => void;
|
|
11
|
+
canUndo: () => boolean;
|
|
12
|
+
canRedo: () => boolean;
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=useCanvasHistory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useCanvasHistory.d.ts","sourceRoot":"","sources":["../../src/hooks/useCanvasHistory.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,eAAO,MAAM,gBAAgB,GAAI,WAAU,MAAuB;;;;;;;;CAejE,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { getOrCreateCanvasStore, MAIN_CANVAS_ID } from "../stores/canvasStore";
|
|
2
|
+
/**
|
|
3
|
+
* Hook that exposes all history functions from a canvas store.
|
|
4
|
+
* Each canvas has its own independent undo/redo history.
|
|
5
|
+
*/
|
|
6
|
+
export const useCanvasHistory = (canvasId = MAIN_CANVAS_ID) => {
|
|
7
|
+
const canvasStore = getOrCreateCanvasStore(canvasId);
|
|
8
|
+
return {
|
|
9
|
+
// History actions
|
|
10
|
+
undo: canvasStore.undo,
|
|
11
|
+
redo: canvasStore.redo,
|
|
12
|
+
takeCheckpoint: canvasStore.takeCheckpoint,
|
|
13
|
+
withCheckpoint: canvasStore.withCheckpoint,
|
|
14
|
+
clearHistory: canvasStore.clearHistory,
|
|
15
|
+
// History state checks
|
|
16
|
+
canUndo: canvasStore.canUndo,
|
|
17
|
+
canRedo: canvasStore.canRedo,
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=useCanvasHistory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useCanvasHistory.js","sourceRoot":"","sources":["../../src/hooks/useCanvasHistory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAE/E;;;GAGG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,WAAmB,cAAc,EAAE,EAAE;IACpE,MAAM,WAAW,GAAG,sBAAsB,CAAC,QAAQ,CAAC,CAAC;IAErD,OAAO;QACL,kBAAkB;QAClB,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,cAAc,EAAE,WAAW,CAAC,cAAc;QAC1C,cAAc,EAAE,WAAW,CAAC,cAAc;QAC1C,YAAY,EAAE,WAAW,CAAC,YAAY;QAEtC,uBAAuB;QACvB,OAAO,EAAE,WAAW,CAAC,OAAO;QAC5B,OAAO,EAAE,WAAW,CAAC,OAAO;KAC7B,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export interface CanvasTab {
|
|
2
|
+
id: string;
|
|
3
|
+
label: string;
|
|
4
|
+
}
|
|
5
|
+
/**
|
|
6
|
+
* Hook for managing canvas tabs UI.
|
|
7
|
+
* Tab switching directly updates the UI store's activeCanvasId.
|
|
8
|
+
*/
|
|
9
|
+
export declare const useCanvasTabs: () => {
|
|
10
|
+
tabs: CanvasTab[];
|
|
11
|
+
activeTabId: string;
|
|
12
|
+
setActiveTabId: (tabId: string) => void;
|
|
13
|
+
openTab: (id: string, label: string) => string;
|
|
14
|
+
closeTab: (tabId: string) => void;
|
|
15
|
+
removeTab: (tabId: string) => void;
|
|
16
|
+
renameTab: (tabId: string, newLabel: string) => void;
|
|
17
|
+
reorderTabs: (fromIndex: number, toIndex: number) => void;
|
|
18
|
+
resetToMain: () => void;
|
|
19
|
+
restoreTabState: (savedTabs: CanvasTab[], savedActiveId: string) => void;
|
|
20
|
+
getTabLabel: (tabId: string) => string;
|
|
21
|
+
isMainCanvas: boolean;
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=useCanvasTabs.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useCanvasTabs.d.ts","sourceRoot":"","sources":["../../src/hooks/useCanvasTabs.ts"],"names":[],"mappings":"AAKA,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;CACf;AAED;;;GAGG;AACH,eAAO,MAAM,aAAa;;;4BAwCd,MAAM;kBAYT,MAAM,SAAS,MAAM;sBAgBlB,MAAM;uBAkBN,MAAM;uBAesB,MAAM,YAAY,MAAM;6BAIlB,MAAM,WAAW,MAAM;;iCAmBrD,SAAS,EAAE,iBAAiB,MAAM;yBAStC,MAAM;;CAoBjB,CAAC"}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import { useState, useCallback, useEffect } from "react";
|
|
2
|
+
import { MAIN_CANVAS_ID } from "../stores/canvasStore";
|
|
3
|
+
import { useEditorStore } from "../stores/editorStore";
|
|
4
|
+
/**
|
|
5
|
+
* Hook for managing canvas tabs UI.
|
|
6
|
+
* Tab switching directly updates the UI store's activeCanvasId.
|
|
7
|
+
*/
|
|
8
|
+
export const useCanvasTabs = () => {
|
|
9
|
+
const [tabs, setTabs] = useState([{ id: MAIN_CANVAS_ID, label: "Main" }]);
|
|
10
|
+
// Get active canvas ID and setter from editor store
|
|
11
|
+
const activeCanvasId = useEditorStore((state) => state.activeCanvasId);
|
|
12
|
+
const setActiveCanvas = useEditorStore((state) => state.setActiveCanvas);
|
|
13
|
+
const selectFunction = useEditorStore((state) => state.selectFunction);
|
|
14
|
+
// Tabs are a projection of the function declarations: a deleted function drops its
|
|
15
|
+
// tab (falling back to Main if it was active), a renamed one relabels. Open/close
|
|
16
|
+
// of an existing function's tab is still explicit (openTab/closeTab) — this only
|
|
17
|
+
// reconciles against the source of truth so the strip can't show a stale function.
|
|
18
|
+
const functions = useEditorStore((state) => state.functions);
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
setTabs((prev) => {
|
|
21
|
+
let changed = false;
|
|
22
|
+
const next = prev.flatMap((t) => {
|
|
23
|
+
if (t.id === MAIN_CANVAS_ID)
|
|
24
|
+
return [t];
|
|
25
|
+
const fn = functions[t.id];
|
|
26
|
+
if (!fn) {
|
|
27
|
+
changed = true;
|
|
28
|
+
return [];
|
|
29
|
+
}
|
|
30
|
+
if (fn.name !== t.label) {
|
|
31
|
+
changed = true;
|
|
32
|
+
return [{ ...t, label: fn.name }];
|
|
33
|
+
}
|
|
34
|
+
return [t];
|
|
35
|
+
});
|
|
36
|
+
return changed ? next : prev;
|
|
37
|
+
});
|
|
38
|
+
if (activeCanvasId !== MAIN_CANVAS_ID && !functions[activeCanvasId]) {
|
|
39
|
+
setActiveCanvas(MAIN_CANVAS_ID);
|
|
40
|
+
}
|
|
41
|
+
}, [functions, activeCanvasId, setActiveCanvas]);
|
|
42
|
+
// Switch to a tab's canvas. A function tab focuses its declaration (selectFunction
|
|
43
|
+
// switches the canvas AND selects the function so its config panel opens) — matching
|
|
44
|
+
// the dropdown/sidebar open path; any other tab just switches the canvas.
|
|
45
|
+
const setActiveTabId = useCallback((tabId) => {
|
|
46
|
+
if (tabId !== MAIN_CANVAS_ID && functions[tabId]) {
|
|
47
|
+
selectFunction(tabId);
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
setActiveCanvas(tabId);
|
|
51
|
+
}
|
|
52
|
+
}, [functions, selectFunction, setActiveCanvas]);
|
|
53
|
+
// Open a tab for a function (add if not exists, switch to it)
|
|
54
|
+
const openTab = useCallback((id, label) => {
|
|
55
|
+
setTabs((prev) => {
|
|
56
|
+
const existing = prev.find((t) => t.id === id);
|
|
57
|
+
if (existing) {
|
|
58
|
+
return prev; // Already exists
|
|
59
|
+
}
|
|
60
|
+
return [...prev, { id, label }];
|
|
61
|
+
});
|
|
62
|
+
setActiveCanvas(id);
|
|
63
|
+
return id;
|
|
64
|
+
}, [setActiveCanvas]);
|
|
65
|
+
// Close a tab (just removes from visible tabs, does NOT delete canvas data)
|
|
66
|
+
const closeTab = useCallback((tabId) => {
|
|
67
|
+
// Cannot close main tab
|
|
68
|
+
if (tabId === MAIN_CANVAS_ID)
|
|
69
|
+
return;
|
|
70
|
+
setTabs((prev) => {
|
|
71
|
+
const filtered = prev.filter((t) => t.id !== tabId);
|
|
72
|
+
// If closing active tab, switch to main
|
|
73
|
+
if (tabId === activeCanvasId) {
|
|
74
|
+
setActiveCanvas(MAIN_CANVAS_ID);
|
|
75
|
+
}
|
|
76
|
+
return filtered;
|
|
77
|
+
});
|
|
78
|
+
}, [activeCanvasId, setActiveCanvas]);
|
|
79
|
+
// Remove a tab completely (called when function is deleted)
|
|
80
|
+
const removeTab = useCallback((tabId) => {
|
|
81
|
+
if (tabId === MAIN_CANVAS_ID)
|
|
82
|
+
return;
|
|
83
|
+
setTabs((prev) => {
|
|
84
|
+
const filtered = prev.filter((t) => t.id !== tabId);
|
|
85
|
+
// Switch to main canvas if removing active tab
|
|
86
|
+
if (tabId === activeCanvasId) {
|
|
87
|
+
setActiveCanvas(MAIN_CANVAS_ID);
|
|
88
|
+
}
|
|
89
|
+
return filtered;
|
|
90
|
+
});
|
|
91
|
+
}, [activeCanvasId, setActiveCanvas]);
|
|
92
|
+
const renameTab = useCallback((tabId, newLabel) => {
|
|
93
|
+
setTabs((prev) => prev.map((t) => (t.id === tabId ? { ...t, label: newLabel } : t)));
|
|
94
|
+
}, []);
|
|
95
|
+
const reorderTabs = useCallback((fromIndex, toIndex) => {
|
|
96
|
+
if (fromIndex === 0 || toIndex === 0)
|
|
97
|
+
return;
|
|
98
|
+
setTabs((prev) => {
|
|
99
|
+
const updated = [...prev];
|
|
100
|
+
const [moved] = updated.splice(fromIndex, 1);
|
|
101
|
+
if (!moved)
|
|
102
|
+
return prev;
|
|
103
|
+
updated.splice(toIndex, 0, moved);
|
|
104
|
+
return updated;
|
|
105
|
+
});
|
|
106
|
+
}, []);
|
|
107
|
+
// Reset to main canvas only (closes all function tabs)
|
|
108
|
+
const resetToMain = useCallback(() => {
|
|
109
|
+
setTabs([{ id: MAIN_CANVAS_ID, label: "Main" }]);
|
|
110
|
+
setActiveCanvas(MAIN_CANVAS_ID);
|
|
111
|
+
}, [setActiveCanvas]);
|
|
112
|
+
// Restore a previously saved tab state
|
|
113
|
+
const restoreTabState = useCallback((savedTabs, savedActiveId) => {
|
|
114
|
+
setTabs(savedTabs);
|
|
115
|
+
setActiveCanvas(savedActiveId);
|
|
116
|
+
}, [setActiveCanvas]);
|
|
117
|
+
// Get label for a tab
|
|
118
|
+
const getTabLabel = useCallback((tabId) => {
|
|
119
|
+
return tabs.find((t) => t.id === tabId)?.label || "Unknown";
|
|
120
|
+
}, [tabs]);
|
|
121
|
+
return {
|
|
122
|
+
tabs,
|
|
123
|
+
activeTabId: activeCanvasId,
|
|
124
|
+
setActiveTabId,
|
|
125
|
+
openTab,
|
|
126
|
+
closeTab,
|
|
127
|
+
removeTab,
|
|
128
|
+
renameTab,
|
|
129
|
+
reorderTabs,
|
|
130
|
+
resetToMain,
|
|
131
|
+
restoreTabState,
|
|
132
|
+
getTabLabel,
|
|
133
|
+
isMainCanvas: activeCanvasId === MAIN_CANVAS_ID,
|
|
134
|
+
};
|
|
135
|
+
};
|
|
136
|
+
//# sourceMappingURL=useCanvasTabs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useCanvasTabs.js","sourceRoot":"","sources":["../../src/hooks/useCanvasTabs.ts"],"names":[],"mappings":"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"}
|