| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  | 'use client' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import type { MouseEventHandler } from 'react' | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  | import { useCallback, useRef, useState } from 'react' | 
					
						
							| 
									
										
										
										
											2024-06-20 11:05:08 +08:00
										 |  |  | import { RiCloseLine } from '@remixicon/react' | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							| 
									
										
										
										
											2024-07-09 15:05:40 +08:00
										 |  |  | import cn from '@/utils/classnames' | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  | import Button from '@/app/components/base/button' | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  | import Input from '@/app/components/base/input' | 
					
						
							|  |  |  | import Textarea from '@/app/components/base/textarea' | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  | import Modal from '@/app/components/base/modal' | 
					
						
							|  |  |  | import type { DataSet } from '@/models/datasets' | 
					
						
							|  |  |  | import { updateDatasetSetting } from '@/service/datasets' | 
					
						
							| 
									
										
										
										
											2025-04-06 17:56:08 +08:00
										 |  |  | import { noop } from 'lodash-es' | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  | import AppIcon from '../../base/app-icon' | 
					
						
							|  |  |  | import type { AppIconSelection } from '../../base/app-icon-picker' | 
					
						
							|  |  |  | import AppIconPicker from '../../base/app-icon-picker' | 
					
						
							|  |  |  | import Toast from '../../base/toast' | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-18 16:21:53 +08:00
										 |  |  | type RenameDatasetModalProps = { | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |   show: boolean | 
					
						
							|  |  |  |   dataset: DataSet | 
					
						
							|  |  |  |   onSuccess?: () => void | 
					
						
							|  |  |  |   onClose: () => void | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const RenameDatasetModal = ({ show, dataset, onSuccess, onClose }: RenameDatasetModalProps) => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  |   const [loading, setLoading] = useState(false) | 
					
						
							|  |  |  |   const [name, setName] = useState<string>(dataset.name) | 
					
						
							|  |  |  |   const [description, setDescription] = useState<string>(dataset.description) | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |   const [externalKnowledgeId] = useState<string>(dataset.external_knowledge_info.external_knowledge_id) | 
					
						
							|  |  |  |   const [externalKnowledgeApiId] = useState<string>(dataset.external_knowledge_info.external_knowledge_api_id) | 
					
						
							|  |  |  |   const [appIcon, setAppIcon] = useState<AppIconSelection>( | 
					
						
							|  |  |  |     dataset.icon_info?.icon_type === 'image' | 
					
						
							|  |  |  |       ? { type: 'image' as const, url: dataset.icon_info?.icon_url || '', fileId: dataset.icon_info?.icon || '' } | 
					
						
							|  |  |  |       : { type: 'emoji' as const, icon: dataset.icon_info?.icon || '', background: dataset.icon_info?.icon_background || '' }, | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  |   const [showAppIconPicker, setShowAppIconPicker] = useState(false) | 
					
						
							|  |  |  |   const previousAppIcon = useRef<AppIconSelection>( | 
					
						
							|  |  |  |     dataset.icon_info?.icon_type === 'image' | 
					
						
							|  |  |  |       ? { type: 'image' as const, url: dataset.icon_info?.icon_url || '', fileId: dataset.icon_info?.icon || '' } | 
					
						
							|  |  |  |       : { type: 'emoji' as const, icon: dataset.icon_info?.icon || '', background: dataset.icon_info?.icon_background || '' }, | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const handleOpenAppIconPicker = useCallback(() => { | 
					
						
							|  |  |  |     setShowAppIconPicker(true) | 
					
						
							|  |  |  |     previousAppIcon.current = appIcon | 
					
						
							|  |  |  |   }, [appIcon]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const handleSelectAppIcon = useCallback((icon: AppIconSelection) => { | 
					
						
							|  |  |  |     setAppIcon(icon) | 
					
						
							|  |  |  |     setShowAppIconPicker(false) | 
					
						
							|  |  |  |   }, []) | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |   const handleCloseAppIconPicker = useCallback(() => { | 
					
						
							|  |  |  |     setAppIcon(previousAppIcon.current) | 
					
						
							|  |  |  |     setShowAppIconPicker(false) | 
					
						
							|  |  |  |   }, []) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const onConfirm: MouseEventHandler = useCallback(async () => { | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |     if (!name.trim()) { | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |       Toast.notify({ type: 'error', message: t('datasetSettings.form.nameError') }) | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |       return | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     try { | 
					
						
							|  |  |  |       setLoading(true) | 
					
						
							| 
									
										
										
										
											2024-09-30 15:38:43 +08:00
										 |  |  |       const body: Partial<DataSet> & { external_knowledge_id?: string; external_knowledge_api_id?: string } = { | 
					
						
							|  |  |  |         name, | 
					
						
							|  |  |  |         description, | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |         icon_info: { | 
					
						
							|  |  |  |           icon: appIcon.type === 'image' ? appIcon.fileId : appIcon.icon, | 
					
						
							|  |  |  |           icon_type: appIcon.type, | 
					
						
							|  |  |  |           icon_background: appIcon.type === 'image' ? undefined : appIcon.background, | 
					
						
							|  |  |  |           icon_url: appIcon.type === 'image' ? appIcon.url : undefined, | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-09-30 15:38:43 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |       if (externalKnowledgeId && externalKnowledgeApiId) { | 
					
						
							|  |  |  |         body.external_knowledge_id = externalKnowledgeId | 
					
						
							|  |  |  |         body.external_knowledge_api_id = externalKnowledgeApiId | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |       await updateDatasetSetting({ | 
					
						
							|  |  |  |         datasetId: dataset.id, | 
					
						
							| 
									
										
										
										
											2024-09-30 15:38:43 +08:00
										 |  |  |         body, | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |       }) | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |       Toast.notify({ type: 'success', message: t('common.actionMsg.modifiedSuccessfully') }) | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |       if (onSuccess) | 
					
						
							|  |  |  |         onSuccess() | 
					
						
							|  |  |  |       onClose() | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-04-14 11:27:14 +08:00
										 |  |  |     catch { | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |       Toast.notify({ type: 'error', message: t('common.actionMsg.modifiedUnsuccessfully') }) | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |     finally { | 
					
						
							|  |  |  |       setLoading(false) | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |   }, [appIcon, description, dataset.id, externalKnowledgeApiId, externalKnowledgeId, name, onClose, onSuccess, t]) | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <Modal | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |       className='w-[520px] max-w-[520px] rounded-xl px-8 py-6' | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |       isShow={show} | 
					
						
							| 
									
										
										
										
											2025-04-06 17:56:08 +08:00
										 |  |  |       onClose={noop} | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |     > | 
					
						
							| 
									
										
										
										
											2025-03-18 16:21:53 +08:00
										 |  |  |       <div className='relative pb-2 text-xl font-medium leading-[30px] text-text-primary'>{t('datasetSettings.title')}</div> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |       <div className='absolute right-4 top-4 cursor-pointer p-2' onClick={onClose}> | 
					
						
							|  |  |  |         <RiCloseLine className='h-4 w-4 text-text-tertiary' /> | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |       </div> | 
					
						
							|  |  |  |       <div> | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |         <div className={cn('flex flex-col py-4')}> | 
					
						
							| 
									
										
										
										
											2025-03-18 16:21:53 +08:00
										 |  |  |           <div className='shrink-0 py-2 text-sm font-medium leading-[20px] text-text-primary'> | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |             {t('datasetSettings.form.name')} | 
					
						
							|  |  |  |           </div> | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |           <div className='flex items-center gap-x-2'> | 
					
						
							|  |  |  |             <AppIcon | 
					
						
							|  |  |  |               size='medium' | 
					
						
							|  |  |  |               onClick={handleOpenAppIconPicker} | 
					
						
							|  |  |  |               className='cursor-pointer' | 
					
						
							|  |  |  |               iconType={appIcon.type} | 
					
						
							|  |  |  |               icon={appIcon.type === 'image' ? appIcon.fileId : appIcon.icon} | 
					
						
							|  |  |  |               background={appIcon.type === 'image' ? undefined : appIcon.background} | 
					
						
							|  |  |  |               imageUrl={appIcon.type === 'image' ? appIcon.url : undefined} | 
					
						
							|  |  |  |               showEditIcon | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |             <Input | 
					
						
							|  |  |  |               value={name} | 
					
						
							|  |  |  |               onChange={e => setName(e.target.value)} | 
					
						
							|  |  |  |               className='h-9 grow' | 
					
						
							|  |  |  |               placeholder={t('datasetSettings.form.namePlaceholder') || ''} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           </div> | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |         <div className={cn('flex flex-col py-4')}> | 
					
						
							| 
									
										
										
										
											2025-03-18 16:21:53 +08:00
										 |  |  |           <div className='shrink-0 py-2 text-sm font-medium leading-[20px] text-text-primary'> | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |             {t('datasetSettings.form.desc')} | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |           <div className='w-full'> | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |             <Textarea | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |               value={description} | 
					
						
							|  |  |  |               onChange={e => setDescription(e.target.value)} | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |               className='resize-none' | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |               placeholder={t('datasetSettings.form.descPlaceholder') || ''} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |       <div className='flex justify-end pt-6'> | 
					
						
							| 
									
										
										
										
											2024-06-21 14:17:45 +08:00
										 |  |  |         <Button className='mr-2' onClick={onClose}>{t('common.operation.cancel')}</Button> | 
					
						
							|  |  |  |         <Button disabled={loading} variant="primary" onClick={onConfirm}>{t('common.operation.save')}</Button> | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2025-05-06 16:58:37 +08:00
										 |  |  |       {showAppIconPicker && ( | 
					
						
							|  |  |  |         <AppIconPicker | 
					
						
							|  |  |  |           onSelect={handleSelectAppIcon} | 
					
						
							|  |  |  |           onClose={handleCloseAppIconPicker} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       )} | 
					
						
							| 
									
										
										
										
											2024-04-24 15:02:29 +08:00
										 |  |  |     </Modal> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default RenameDatasetModal |