2025-07-14 11:17:42 +08:00

85 lines
1.6 KiB
TypeScript

import {
useMemo,
useState,
} from 'react'
import { useTranslation } from 'react-i18next'
import {
TabsEnum,
ToolTypeEnum,
} from './types'
export const useTabs = (noBlocks?: boolean, noSources?: boolean) => {
const { t } = useTranslation()
const tabs = useMemo(() => {
return [
...(
noBlocks
? []
: [
{
key: TabsEnum.Blocks,
name: t('workflow.tabs.blocks'),
},
]
),
...(
noSources
? []
: [
{
key: TabsEnum.Sources,
name: t('workflow.tabs.sources'),
},
]
),
{
key: TabsEnum.Tools,
name: t('workflow.tabs.tools'),
},
]
}, [t, noBlocks, noSources])
const initialTab = useMemo(() => {
if (noBlocks)
return noSources ? TabsEnum.Tools : TabsEnum.Sources
return TabsEnum.Blocks
}, [noBlocks, noSources])
const [activeTab, setActiveTab] = useState(initialTab)
return {
tabs,
activeTab,
setActiveTab,
}
}
export const useToolTabs = (isHideMCPTools?: boolean) => {
const { t } = useTranslation()
const tabs = [
{
key: ToolTypeEnum.All,
name: t('workflow.tabs.allTool'),
},
{
key: ToolTypeEnum.BuiltIn,
name: t('workflow.tabs.plugin'),
},
{
key: ToolTypeEnum.Custom,
name: t('workflow.tabs.customTool'),
},
{
key: ToolTypeEnum.Workflow,
name: t('workflow.tabs.workflowTool'),
},
]
if (!isHideMCPTools) {
tabs.push({
key: ToolTypeEnum.MCP,
name: 'MCP',
})
}
return tabs
}