mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-26 16:39:19 +00:00 
			
		
		
		
	 7709d9df20
			
		
	
	
		7709d9df20
		
			
		
	
	
	
	
		
			
			Co-authored-by: NFish <douxc512@gmail.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: twwu <twwu@dify.ai> Co-authored-by: jZonG <jzongcode@gmail.com>
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import type { FC } from 'react'
 | |
| import { memo } from 'react'
 | |
| import { useAllBuiltInTools, useAllCustomTools, useAllWorkflowTools } from '@/service/use-tools'
 | |
| import type { BlockEnum } from '../types'
 | |
| import { useTabs } from './hooks'
 | |
| import type { ToolDefaultValue } from './types'
 | |
| import { TabsEnum } from './types'
 | |
| import Blocks from './blocks'
 | |
| import AllTools from './all-tools'
 | |
| import cn from '@/utils/classnames'
 | |
| 
 | |
| export type TabsProps = {
 | |
|   activeTab: TabsEnum
 | |
|   onActiveTabChange: (activeTab: TabsEnum) => void
 | |
|   searchText: string
 | |
|   tags: string[]
 | |
|   onSelect: (type: BlockEnum, tool?: ToolDefaultValue) => void
 | |
|   availableBlocksTypes?: BlockEnum[]
 | |
|   noBlocks?: boolean
 | |
| }
 | |
| const Tabs: FC<TabsProps> = ({
 | |
|   activeTab,
 | |
|   onActiveTabChange,
 | |
|   tags,
 | |
|   searchText,
 | |
|   onSelect,
 | |
|   availableBlocksTypes,
 | |
|   noBlocks,
 | |
| }) => {
 | |
|   const tabs = useTabs()
 | |
|   const { data: buildInTools } = useAllBuiltInTools()
 | |
|   const { data: customTools } = useAllCustomTools()
 | |
|   const { data: workflowTools } = useAllWorkflowTools()
 | |
| 
 | |
|   return (
 | |
|     <div onClick={e => e.stopPropagation()}>
 | |
|       {
 | |
|         !noBlocks && (
 | |
|           <div className='flex items-center border-b-[0.5px] border-divider-subtle px-3'>
 | |
|             {
 | |
|               tabs.map(tab => (
 | |
|                 <div
 | |
|                   key={tab.key}
 | |
|                   className={cn(
 | |
|                     'system-sm-medium relative mr-4 cursor-pointer pb-2 pt-1',
 | |
|                     activeTab === tab.key
 | |
|                       ? 'text-text-primary after:absolute after:bottom-0 after:left-0 after:h-0.5 after:w-full after:bg-util-colors-blue-brand-blue-brand-600'
 | |
|                       : 'text-text-tertiary',
 | |
|                   )}
 | |
|                   onClick={() => onActiveTabChange(tab.key)}
 | |
|                 >
 | |
|                   {tab.name}
 | |
|                 </div>
 | |
|               ))
 | |
|             }
 | |
|           </div>
 | |
|         )
 | |
|       }
 | |
|       {
 | |
|         activeTab === TabsEnum.Blocks && !noBlocks && (
 | |
|           <Blocks
 | |
|             searchText={searchText}
 | |
|             onSelect={onSelect}
 | |
|             availableBlocksTypes={availableBlocksTypes}
 | |
|           />
 | |
|         )
 | |
|       }
 | |
|       {
 | |
|         activeTab === TabsEnum.Tools && (
 | |
|           <AllTools
 | |
|             className='w-[315px]'
 | |
|             searchText={searchText}
 | |
|             onSelect={onSelect}
 | |
|             tags={tags}
 | |
|             buildInTools={buildInTools || []}
 | |
|             customTools={customTools || []}
 | |
|             workflowTools={workflowTools || []}
 | |
|           />
 | |
|         )
 | |
|       }
 | |
|     </div>
 | |
|   )
 | |
| }
 | |
| 
 | |
| export default memo(Tabs)
 |