| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   memo, | 
					
						
							|  |  |  |   useCallback, | 
					
						
							| 
									
										
										
										
											2024-07-09 09:43:34 +08:00
										 |  |  |   useRef, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | } from 'react' | 
					
						
							|  |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							|  |  |  | import BlockIcon from '../block-icon' | 
					
						
							|  |  |  | import { BlockEnum } from '../types' | 
					
						
							|  |  |  | import type { ToolWithProvider } from '../types' | 
					
						
							| 
									
										
										
										
											2024-07-09 09:43:34 +08:00
										 |  |  | import IndexBar, { groupItems } from './index-bar' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import type { ToolDefaultValue } from './types' | 
					
						
							|  |  |  | import Tooltip from '@/app/components/base/tooltip' | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  | import Empty from '@/app/components/tools/add-tool-modal/empty' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { useGetLanguage } from '@/context/i18n' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type ToolsProps = { | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   showWorkflowEmpty: boolean | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   onSelect: (type: BlockEnum, tool?: ToolDefaultValue) => void | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   tools: ToolWithProvider[] | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | } | 
					
						
							|  |  |  | const Blocks = ({ | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   showWorkflowEmpty, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   onSelect, | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   tools, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | }: ToolsProps) => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  |   const language = useGetLanguage() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-09 09:43:34 +08:00
										 |  |  |   const { letters, groups: groupedTools } = groupItems(tools, tool => tool.label[language][0]) | 
					
						
							|  |  |  |   const toolRefs = useRef({}) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   const renderGroup = useCallback((toolWithProvider: ToolWithProvider) => { | 
					
						
							|  |  |  |     const list = toolWithProvider.tools | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return ( | 
					
						
							|  |  |  |       <div | 
					
						
							|  |  |  |         key={toolWithProvider.id} | 
					
						
							|  |  |  |         className='mb-1 last-of-type:mb-0' | 
					
						
							|  |  |  |       > | 
					
						
							|  |  |  |         <div className='flex items-start px-3 h-[22px] text-xs font-medium text-gray-500'> | 
					
						
							|  |  |  |           {toolWithProvider.label[language]} | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           list.map(tool => ( | 
					
						
							|  |  |  |             <Tooltip | 
					
						
							|  |  |  |               key={tool.name} | 
					
						
							|  |  |  |               position='right' | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |               popupClassName='!p-0 !px-3 !py-2.5 !w-[200px] !leading-[18px] !text-xs !text-gray-700 !border-[0.5px] !border-black/5 !rounded-xl !shadow-lg' | 
					
						
							|  |  |  |               popupContent={( | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                 <div> | 
					
						
							| 
									
										
										
										
											2024-05-09 17:18:51 +08:00
										 |  |  |                   <BlockIcon | 
					
						
							|  |  |  |                     size='md' | 
					
						
							|  |  |  |                     className='mb-2' | 
					
						
							|  |  |  |                     type={BlockEnum.Tool} | 
					
						
							|  |  |  |                     toolIcon={toolWithProvider.icon} | 
					
						
							|  |  |  |                   /> | 
					
						
							|  |  |  |                   <div className='mb-1 text-sm leading-5 text-gray-900'>{tool.label[language]}</div> | 
					
						
							|  |  |  |                   <div className='text-xs text-gray-700 leading-[18px]'>{tool.description[language]}</div> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                 </div> | 
					
						
							|  |  |  |               )} | 
					
						
							|  |  |  |             > | 
					
						
							|  |  |  |               <div | 
					
						
							|  |  |  |                 className='flex items-center px-3 w-full h-8 rounded-lg hover:bg-gray-50 cursor-pointer' | 
					
						
							|  |  |  |                 onClick={() => onSelect(BlockEnum.Tool, { | 
					
						
							|  |  |  |                   provider_id: toolWithProvider.id, | 
					
						
							|  |  |  |                   provider_type: toolWithProvider.type, | 
					
						
							|  |  |  |                   provider_name: toolWithProvider.name, | 
					
						
							|  |  |  |                   tool_name: tool.name, | 
					
						
							|  |  |  |                   tool_label: tool.label[language], | 
					
						
							|  |  |  |                   title: tool.label[language], | 
					
						
							|  |  |  |                 })} | 
					
						
							|  |  |  |               > | 
					
						
							|  |  |  |                 <BlockIcon | 
					
						
							| 
									
										
										
										
											2024-05-09 17:18:51 +08:00
										 |  |  |                   className='mr-2 shrink-0' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                   type={BlockEnum.Tool} | 
					
						
							|  |  |  |                   toolIcon={toolWithProvider.icon} | 
					
						
							|  |  |  |                 /> | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |                 <div className='text-sm text-gray-900 flex-1 min-w-0 truncate'>{tool.label[language]}</div> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |               </div> | 
					
						
							|  |  |  |             </Tooltip> | 
					
						
							|  |  |  |           )) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |   }, [onSelect, language]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-09 09:43:34 +08:00
										 |  |  |   const renderLetterGroup = (letter) => { | 
					
						
							|  |  |  |     const tools = groupedTools[letter] | 
					
						
							|  |  |  |     return ( | 
					
						
							|  |  |  |       <div | 
					
						
							|  |  |  |         key={letter} | 
					
						
							|  |  |  |         ref={el => (toolRefs.current[letter] = el)} | 
					
						
							|  |  |  |       > | 
					
						
							|  |  |  |         {tools.map(renderGroup)} | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   return ( | 
					
						
							| 
									
										
										
										
											2024-05-09 17:18:51 +08:00
										 |  |  |     <div className='p-1 max-w-[320px] max-h-[464px] overflow-y-auto'> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |       { | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |         !tools.length && !showWorkflowEmpty && ( | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |           <div className='flex items-center px-3 h-[22px] text-xs font-medium text-gray-500'>{t('workflow.tabs.noResult')}</div> | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |       {!tools.length && showWorkflowEmpty && ( | 
					
						
							|  |  |  |         <div className='py-10'> | 
					
						
							| 
									
										
										
										
											2024-07-09 09:43:34 +08:00
										 |  |  |           <Empty /> | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |         </div> | 
					
						
							|  |  |  |       )} | 
					
						
							| 
									
										
										
										
											2024-07-09 09:43:34 +08:00
										 |  |  |       {!!tools.length && letters.map(renderLetterGroup)} | 
					
						
							|  |  |  |       {tools.length > 10 && <IndexBar letters={letters} itemRefs={toolRefs} />} | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     </div> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default memo(Blocks) |