Files
AutoMetabuilder/frontend/autometabuilder/hooks/useTabNavigation.ts
copilot-swe-agent[bot] 6e9ff896e7 Phase 9: Implement atomic hooks-based workflow canvas components
- Created custom hooks: useWorkflowGraph, useWorkflowPlugins, usePluginSearch, useTabNavigation
- Decomposed canvas logic into: useCanvasNodes, useCanvasEdges, useCanvasDragDrop
- Built atomic node components: NodeHeader, NodeBody, NodePorts
- Created canvas UI components: CanvasInfoPanel, CanvasHintPanel
- Split builder into: LoadingState, ErrorState, WorkflowBuilderHeader, WorkflowBuilderTabs, WorkflowBuilderContent
- Added React Flow for n8n-style visual canvas with drag-and-drop
- All components now under 100 LOC following PROMPT.md guidelines

Co-authored-by: johndoe6345789 <224850594+johndoe6345789@users.noreply.github.com>
2026-01-10 12:25:36 +00:00

12 lines
322 B
TypeScript

import { useState, useCallback } from "react";
export function useTabNavigation(initialTab = 0) {
const [selectedTab, setSelectedTab] = useState(initialTab);
const handleTabChange = useCallback((_: unknown, newValue: number) => {
setSelectedTab(newValue);
}, []);
return { selectedTab, handleTabChange };
}