mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-24 23:48:40 +00:00 
			
		
		
		
	
		
			
	
	
		
			71 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			71 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
|   | 'use client' | ||
|  | import { useRef } from 'react' | ||
|  | import cn from 'classnames' | ||
|  | import { useTranslation } from 'react-i18next' | ||
|  | import { useContext } from 'use-context-selector' | ||
|  | import { useMount } from 'ahooks' | ||
|  | 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') | ||
|  |     console.log(doc.documentElement) | ||
|  |     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 |