mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-20 13:38:53 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			70 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| 'use client'
 | |
| import { useRef } from 'react'
 | |
| import { useTranslation } from 'react-i18next'
 | |
| import { useContext } from 'use-context-selector'
 | |
| import { useMount } from 'ahooks'
 | |
| import cn from '@/utils/classnames'
 | |
| import { Apps02 } from '@/app/components/base/icons/src/vender/line/others'
 | |
| import I18n from '@/context/i18n'
 | |
| import { getLanguage } from '@/i18n/language'
 | |
| import { useStore as useLabelStore } from '@/app/components/tools/labels/store'
 | |
| import { fetchLabelList } from '@/service/tools'
 | |
| 
 | |
| type Props = {
 | |
|   value: string
 | |
|   onSelect: (type: string) => void
 | |
| }
 | |
| 
 | |
| const Icon = ({ svgString, active }: { svgString: string; active: boolean }) => {
 | |
|   const svgRef = useRef<SVGSVGElement | null>(null)
 | |
|   const SVGParsor = (svg: string) => {
 | |
|     if (!svg)
 | |
|       return null
 | |
|     const parser = new DOMParser()
 | |
|     const doc = parser.parseFromString(svg, 'image/svg+xml')
 | |
|     return doc.documentElement
 | |
|   }
 | |
|   useMount(() => {
 | |
|     const svgElement = SVGParsor(svgString)
 | |
|     if (svgRef.current && svgElement)
 | |
|       svgRef.current.appendChild(svgElement)
 | |
|   })
 | |
|   return <svg className={cn('w-4 h-4 text-gray-700', active && '!text-primary-600')} ref={svgRef} />
 | |
| }
 | |
| 
 | |
| const Category = ({
 | |
|   value,
 | |
|   onSelect,
 | |
| }: Props) => {
 | |
|   const { t } = useTranslation()
 | |
|   const { locale } = useContext(I18n)
 | |
|   const language = getLanguage(locale)
 | |
|   const labelList = useLabelStore(s => s.labelList)
 | |
|   const setLabelList = useLabelStore(s => s.setLabelList)
 | |
| 
 | |
|   useMount(() => {
 | |
|     fetchLabelList().then((res) => {
 | |
|       setLabelList(res)
 | |
|     })
 | |
|   })
 | |
| 
 | |
|   return (
 | |
|     <div className='mb-3'>
 | |
|       <div className='px-3 py-0.5 text-gray-500 text-xs leading-[18px] font-medium'>{t('tools.addToolModal.category').toLocaleUpperCase()}</div>
 | |
|       <div className={cn('mb-0.5 p-1 pl-3 flex items-center cursor-pointer text-gray-700 text-sm leading-5 rounded-lg hover:bg-white', value === '' && '!bg-white !text-primary-600 font-medium')} onClick={() => onSelect('')}>
 | |
|         <Apps02 className='shrink-0 w-4 h-4 mr-2' />
 | |
|         {t('tools.type.all')}
 | |
|       </div>
 | |
|       {labelList.map(label => (
 | |
|         <div key={label.name} title={label.label[language]} className={cn('mb-0.5 p-1 pl-3 flex items-center cursor-pointer text-gray-700 text-sm leading-5 rounded-lg hover:bg-white truncate overflow-hidden', value === label.name && '!bg-white !text-primary-600 font-medium')} onClick={() => onSelect(label.name)}>
 | |
|           <div className='shrink-0 w-4 h-4 mr-2'>
 | |
|             <Icon active={value === label.name} svgString={label.icon} />
 | |
|           </div>
 | |
|           {label.label[language]}
 | |
|         </div>
 | |
|       ))}
 | |
|     </div>
 | |
|   )
 | |
| }
 | |
| export default Category
 | 
