| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  | import type { FC, PropsWithChildren, ReactNode } from 'react' | 
					
						
							|  |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							|  |  |  | import type { InputProps } from '@/app/components/base/input' | 
					
						
							|  |  |  | import Input from '@/app/components/base/input' | 
					
						
							|  |  |  | import Tooltip from '@/app/components/base/tooltip' | 
					
						
							|  |  |  | import type { InputNumberProps } from '@/app/components/base/input-number' | 
					
						
							|  |  |  | import { InputNumber } from '@/app/components/base/input-number' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const TextLabel: FC<PropsWithChildren> = (props) => { | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |   return <label className='text-xs font-semibold leading-none text-text-secondary'>{props.children}</label> | 
					
						
							| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const FormField: FC<PropsWithChildren<{ label: ReactNode }>> = (props) => { | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |   return <div className='flex-1 space-y-2'> | 
					
						
							| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  |     <TextLabel>{props.label}</TextLabel> | 
					
						
							|  |  |  |     {props.children} | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const DelimiterInput: FC<InputProps & { tooltip?: string }> = (props) => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |   return <FormField label={<div className='mb-1 flex items-center'> | 
					
						
							| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  |     <span className='system-sm-semibold mr-0.5'>{t('datasetCreation.stepTwo.separator')}</span> | 
					
						
							|  |  |  |     <Tooltip | 
					
						
							|  |  |  |       popupContent={ | 
					
						
							|  |  |  |         <div className='max-w-[200px]'> | 
					
						
							|  |  |  |           {props.tooltip || t('datasetCreation.stepTwo.separatorTip')} | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     /> | 
					
						
							|  |  |  |   </div>}> | 
					
						
							|  |  |  |     <Input | 
					
						
							|  |  |  |       type="text" | 
					
						
							|  |  |  |       className='h-9' | 
					
						
							|  |  |  |       placeholder={t('datasetCreation.stepTwo.separatorPlaceholder')!} | 
					
						
							|  |  |  |       {...props} | 
					
						
							|  |  |  |     /> | 
					
						
							|  |  |  |   </FormField> | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const MaxLengthInput: FC<InputNumberProps> = (props) => { | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |   const maxValue = Number.parseInt(globalThis.document?.body?.getAttribute('data-public-indexing-max-segmentation-tokens-length') || '4000', 10) | 
					
						
							| 
									
										
										
										
											2025-01-22 10:43:40 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  |   return <FormField label={<div className='system-sm-semibold mb-1'> | 
					
						
							|  |  |  |     {t('datasetCreation.stepTwo.maxLength')} | 
					
						
							|  |  |  |   </div>}> | 
					
						
							|  |  |  |     <InputNumber | 
					
						
							|  |  |  |       type="number" | 
					
						
							| 
									
										
										
										
											2025-04-18 15:54:22 +08:00
										 |  |  |       size='large' | 
					
						
							| 
									
										
										
										
											2025-01-22 10:43:40 +08:00
										 |  |  |       placeholder={`≤ ${maxValue}`} | 
					
						
							|  |  |  |       max={maxValue} | 
					
						
							| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  |       min={1} | 
					
						
							|  |  |  |       {...props} | 
					
						
							|  |  |  |     /> | 
					
						
							|  |  |  |   </FormField> | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export const OverlapInput: FC<InputNumberProps> = (props) => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |   return <FormField label={<div className='mb-1 flex items-center'> | 
					
						
							| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  |     <span className='system-sm-semibold'>{t('datasetCreation.stepTwo.overlap')}</span> | 
					
						
							|  |  |  |     <Tooltip | 
					
						
							|  |  |  |       popupContent={ | 
					
						
							|  |  |  |         <div className='max-w-[200px]'> | 
					
						
							|  |  |  |           {t('datasetCreation.stepTwo.overlapTip')} | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     /> | 
					
						
							|  |  |  |   </div>}> | 
					
						
							|  |  |  |     <InputNumber | 
					
						
							|  |  |  |       type="number" | 
					
						
							| 
									
										
										
										
											2025-04-18 15:54:22 +08:00
										 |  |  |       size='large' | 
					
						
							| 
									
										
										
										
											2024-12-26 12:01:51 +08:00
										 |  |  |       placeholder={t('datasetCreation.stepTwo.overlap') || ''} | 
					
						
							|  |  |  |       min={1} | 
					
						
							|  |  |  |       {...props} | 
					
						
							|  |  |  |     /> | 
					
						
							|  |  |  |   </FormField> | 
					
						
							|  |  |  | } |