mirror of
https://github.com/langgenius/dify.git
synced 2026-03-02 22:36:41 +08:00
Signed-off-by: yihong0618 <zouzou0208@gmail.com> Signed-off-by: -LAN- <laipz8200@outlook.com> Co-authored-by: kurokobo <kuro664@gmail.com> Co-authored-by: Hiroshi Fujita <fujita-h@users.noreply.github.com> Co-authored-by: NFish <douxc512@gmail.com> Co-authored-by: Gen Sato <52241300+halogen22@users.noreply.github.com> Co-authored-by: eux <euxuuu@gmail.com> Co-authored-by: huangzhuo1949 <167434202+huangzhuo1949@users.noreply.github.com> Co-authored-by: huangzhuo <huangzhuo1@xiaomi.com> Co-authored-by: lotsik <lotsik@mail.ru> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: Wu Tianwei <30284043+WTW0313@users.noreply.github.com> Co-authored-by: nite-knite <nkCoding@gmail.com> Co-authored-by: Jyong <76649700+JohnJyong@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: gakkiyomi <gakkiyomi@aliyun.com> Co-authored-by: CN-P5 <heibai2006@gmail.com> Co-authored-by: CN-P5 <heibai2006@qq.com> Co-authored-by: Chuehnone <1897025+chuehnone@users.noreply.github.com> Co-authored-by: yihong <zouzou0208@gmail.com> Co-authored-by: Kevin9703 <51311316+Kevin9703@users.noreply.github.com> Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: Boris Feld <lothiraldan@gmail.com> Co-authored-by: mbo <himabo@gmail.com> Co-authored-by: mabo <mabo@aeyes.ai> Co-authored-by: Warren Chen <warren.chen830@gmail.com> Co-authored-by: KVOJJJin <jzongcode@gmail.com> Co-authored-by: JzoNgKVO <27049666+JzoNgKVO@users.noreply.github.com> Co-authored-by: jiandanfeng <chenjh3@wangsu.com> Co-authored-by: zhu-an <70234959+xhdd123321@users.noreply.github.com> Co-authored-by: zhaoqingyu.1075 <zhaoqingyu.1075@bytedance.com> Co-authored-by: 海狸大師 <86974027+yenslife@users.noreply.github.com> Co-authored-by: Xu Song <xusong.vip@gmail.com> Co-authored-by: rayshaw001 <396301947@163.com> Co-authored-by: Ding Jiatong <dingjiatong@gmail.com> Co-authored-by: Bowen Liang <liangbowen@gf.com.cn> Co-authored-by: JasonVV <jasonwangiii@outlook.com> Co-authored-by: le0zh <newlight@qq.com> Co-authored-by: zhuxinliang <zhuxinliang@didiglobal.com> Co-authored-by: k-zaku <zaku99@outlook.jp> Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: luckylhb90 <luckylhb90@gmail.com> Co-authored-by: hobo.l <hobo.l@binance.com> Co-authored-by: jiangbo721 <365065261@qq.com> Co-authored-by: 刘江波 <jiangbo721@163.com> Co-authored-by: Shun Miyazawa <34241526+miya@users.noreply.github.com> Co-authored-by: EricPan <30651140+Egfly@users.noreply.github.com> Co-authored-by: crazywoola <427733928@qq.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: sino <sino2322@gmail.com> Co-authored-by: Jhvcc <37662342+Jhvcc@users.noreply.github.com> Co-authored-by: lowell <lowell.hu@zkteco.in>
80 lines
2.5 KiB
TypeScript
80 lines
2.5 KiB
TypeScript
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) => {
|
|
return <label className='text-text-secondary text-xs font-semibold leading-none'>{props.children}</label>
|
|
}
|
|
|
|
const FormField: FC<PropsWithChildren<{ label: ReactNode }>> = (props) => {
|
|
return <div className='space-y-2 flex-1'>
|
|
<TextLabel>{props.label}</TextLabel>
|
|
{props.children}
|
|
</div>
|
|
}
|
|
|
|
export const DelimiterInput: FC<InputProps & { tooltip?: string }> = (props) => {
|
|
const { t } = useTranslation()
|
|
return <FormField label={<div className='flex items-center mb-1'>
|
|
<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) => {
|
|
const maxValue = parseInt(globalThis.document?.body?.getAttribute('data-public-indexing-max-segmentation-tokens-length') || '4000', 10)
|
|
|
|
const { t } = useTranslation()
|
|
return <FormField label={<div className='system-sm-semibold mb-1'>
|
|
{t('datasetCreation.stepTwo.maxLength')}
|
|
</div>}>
|
|
<InputNumber
|
|
type="number"
|
|
className='h-9'
|
|
placeholder={`≤ ${maxValue}`}
|
|
max={maxValue}
|
|
min={1}
|
|
{...props}
|
|
/>
|
|
</FormField>
|
|
}
|
|
|
|
export const OverlapInput: FC<InputNumberProps> = (props) => {
|
|
const { t } = useTranslation()
|
|
return <FormField label={<div className='flex items-center mb-1'>
|
|
<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"
|
|
className='h-9'
|
|
placeholder={t('datasetCreation.stepTwo.overlap') || ''}
|
|
min={1}
|
|
{...props}
|
|
/>
|
|
</FormField>
|
|
}
|