mirror of
https://github.com/langgenius/dify.git
synced 2026-04-15 09:57:03 +08:00
Signed-off-by: -LAN- <laipz8200@outlook.com> Signed-off-by: kenwoodjw <blackxin55+@gmail.com> Signed-off-by: Yongtao Huang <yongtaoh2022@gmail.com> Signed-off-by: yihong0618 <zouzou0208@gmail.com> Signed-off-by: zhanluxianshen <zhanluxianshen@163.com> Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: GuanMu <ballmanjq@gmail.com> Co-authored-by: Davide Delbianco <davide.delbianco@outlook.com> Co-authored-by: NeatGuyCoding <15627489+NeatGuyCoding@users.noreply.github.com> Co-authored-by: kenwoodjw <blackxin55+@gmail.com> Co-authored-by: Yongtao Huang <yongtaoh2022@gmail.com> Co-authored-by: Yongtao Huang <99629139+hyongtao-db@users.noreply.github.com> Co-authored-by: Qiang Lee <18018968632@163.com> Co-authored-by: 李强04 <liqiang04@gaotu.cn> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> Co-authored-by: Matri Qi <matrixdom@126.com> Co-authored-by: huayaoyue6 <huayaoyue@163.com> Co-authored-by: Bowen Liang <liangbowen@gf.com.cn> Co-authored-by: znn <jubinkumarsoni@gmail.com> Co-authored-by: crazywoola <427733928@qq.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: yihong <zouzou0208@gmail.com> Co-authored-by: Muke Wang <shaodwaaron@gmail.com> Co-authored-by: wangmuke <wangmuke@kingsware.cn> Co-authored-by: Wu Tianwei <30284043+WTW0313@users.noreply.github.com> Co-authored-by: quicksand <quicksandzn@gmail.com> Co-authored-by: 非法操作 <hjlarry@163.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: Eric Guo <eric.guocz@gmail.com> Co-authored-by: Zhedong Cen <cenzhedong2@126.com> Co-authored-by: jiangbo721 <jiangbo721@163.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: hjlarry <25834719+hjlarry@users.noreply.github.com> Co-authored-by: lxsummer <35754229+lxjustdoit@users.noreply.github.com> Co-authored-by: 湛露先生 <zhanluxianshen@163.com> Co-authored-by: Guangdong Liu <liugddx@gmail.com> Co-authored-by: QuantumGhost <obelisk.reg+git@gmail.com> Co-authored-by: Claude <noreply@anthropic.com> Co-authored-by: Yessenia-d <yessenia.contact@gmail.com> Co-authored-by: huangzhuo1949 <167434202+huangzhuo1949@users.noreply.github.com> Co-authored-by: huangzhuo <huangzhuo1@xiaomi.com> Co-authored-by: 17hz <0x149527@gmail.com> Co-authored-by: Amy <1530140574@qq.com> Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Nite Knite <nkCoding@gmail.com> Co-authored-by: Yeuoly <45712896+Yeuoly@users.noreply.github.com> Co-authored-by: Petrus Han <petrus.hanks@gmail.com> Co-authored-by: iamjoel <2120155+iamjoel@users.noreply.github.com> Co-authored-by: Kalo Chin <frog.beepers.0n@icloud.com> Co-authored-by: Ujjwal Maurya <ujjwalsbx@gmail.com> Co-authored-by: Maries <xh001x@hotmail.com>
143 lines
5.7 KiB
TypeScript
143 lines
5.7 KiB
TypeScript
import React, { memo, useCallback } from 'react'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { useEmbeddedChatbotContext } from '../context'
|
|
import Input from '@/app/components/base/input'
|
|
import Textarea from '@/app/components/base/textarea'
|
|
import { PortalSelect } from '@/app/components/base/select'
|
|
import { FileUploaderInAttachmentWrapper } from '@/app/components/base/file-uploader'
|
|
import { InputVarType } from '@/app/components/workflow/types'
|
|
import BoolInput from '@/app/components/workflow/nodes/_base/components/before-run-form/bool-input'
|
|
import { CodeLanguage } from '@/app/components/workflow/nodes/code/types'
|
|
import CodeEditor from '@/app/components/workflow/nodes/_base/components/editor/code-editor'
|
|
|
|
type Props = {
|
|
showTip?: boolean
|
|
}
|
|
|
|
const InputsFormContent = ({ showTip }: Props) => {
|
|
const { t } = useTranslation()
|
|
const {
|
|
appParams,
|
|
inputsForms,
|
|
currentConversationId,
|
|
currentConversationInputs,
|
|
setCurrentConversationInputs,
|
|
newConversationInputs,
|
|
newConversationInputsRef,
|
|
handleNewConversationInputsChange,
|
|
} = useEmbeddedChatbotContext()
|
|
const inputsFormValue = currentConversationId ? currentConversationInputs : newConversationInputs
|
|
|
|
const handleFormChange = useCallback((variable: string, value: any) => {
|
|
setCurrentConversationInputs({
|
|
...currentConversationInputs,
|
|
[variable]: value,
|
|
})
|
|
handleNewConversationInputsChange({
|
|
...newConversationInputsRef.current,
|
|
[variable]: value,
|
|
})
|
|
}, [newConversationInputsRef, handleNewConversationInputsChange, currentConversationInputs, setCurrentConversationInputs])
|
|
|
|
const visibleInputsForms = inputsForms.filter(form => form.hide !== true)
|
|
|
|
return (
|
|
<div className='space-y-4'>
|
|
{visibleInputsForms.map(form => (
|
|
<div key={form.variable} className='space-y-1'>
|
|
{form.type !== InputVarType.checkbox && (
|
|
<div className='flex h-6 items-center gap-1'>
|
|
<div className='system-md-semibold text-text-secondary'>{form.label}</div>
|
|
{!form.required && (
|
|
<div className='system-xs-regular text-text-tertiary'>{t('appDebug.variableTable.optional')}</div>
|
|
)}
|
|
</div>
|
|
)}
|
|
{form.type === InputVarType.textInput && (
|
|
<Input
|
|
value={inputsFormValue?.[form.variable] || ''}
|
|
onChange={e => handleFormChange(form.variable, e.target.value)}
|
|
placeholder={form.label}
|
|
/>
|
|
)}
|
|
{form.type === InputVarType.number && (
|
|
<Input
|
|
type='number'
|
|
value={inputsFormValue?.[form.variable] || ''}
|
|
onChange={e => handleFormChange(form.variable, e.target.value)}
|
|
placeholder={form.label}
|
|
/>
|
|
)}
|
|
{form.type === InputVarType.paragraph && (
|
|
<Textarea
|
|
value={inputsFormValue?.[form.variable] || ''}
|
|
onChange={e => handleFormChange(form.variable, e.target.value)}
|
|
placeholder={form.label}
|
|
/>
|
|
)}
|
|
{form.type === InputVarType.checkbox && (
|
|
<BoolInput
|
|
name={form.label}
|
|
value={inputsFormValue?.[form.variable]}
|
|
required={form.required}
|
|
onChange={value => handleFormChange(form.variable, value)}
|
|
/>
|
|
)}
|
|
{form.type === InputVarType.select && (
|
|
<PortalSelect
|
|
popupClassName='w-[200px]'
|
|
value={inputsFormValue?.[form.variable] ?? form.default ?? ''}
|
|
items={form.options.map((option: string) => ({ value: option, name: option }))}
|
|
onSelect={item => handleFormChange(form.variable, item.value as string)}
|
|
placeholder={form.label}
|
|
/>
|
|
)}
|
|
{form.type === InputVarType.singleFile && (
|
|
<FileUploaderInAttachmentWrapper
|
|
value={inputsFormValue?.[form.variable] ? [inputsFormValue?.[form.variable]] : []}
|
|
onChange={files => handleFormChange(form.variable, files[0])}
|
|
fileConfig={{
|
|
allowed_file_types: form.allowed_file_types,
|
|
allowed_file_extensions: form.allowed_file_extensions,
|
|
allowed_file_upload_methods: form.allowed_file_upload_methods,
|
|
number_limits: 1,
|
|
fileUploadConfig: (appParams as any).system_parameters,
|
|
}}
|
|
/>
|
|
)}
|
|
{form.type === InputVarType.multiFiles && (
|
|
<FileUploaderInAttachmentWrapper
|
|
value={inputsFormValue?.[form.variable] || []}
|
|
onChange={files => handleFormChange(form.variable, files)}
|
|
fileConfig={{
|
|
allowed_file_types: form.allowed_file_types,
|
|
allowed_file_extensions: form.allowed_file_extensions,
|
|
allowed_file_upload_methods: form.allowed_file_upload_methods,
|
|
number_limits: form.max_length,
|
|
fileUploadConfig: (appParams as any).system_parameters,
|
|
}}
|
|
/>
|
|
)}
|
|
{form.type === InputVarType.jsonObject && (
|
|
<CodeEditor
|
|
language={CodeLanguage.json}
|
|
value={inputsFormValue?.[form.variable] || ''}
|
|
onChange={v => handleFormChange(form.variable, v)}
|
|
noWrapper
|
|
className='bg h-[80px] overflow-y-auto rounded-[10px] bg-components-input-bg-normal p-1'
|
|
placeholder={
|
|
<div className='whitespace-pre'>{form.json_schema}</div>
|
|
}
|
|
/>
|
|
)}
|
|
</div>
|
|
))}
|
|
{showTip && (
|
|
<div className='system-xs-regular text-text-tertiary'>{t('share.chat.chatFormTip')}</div>
|
|
)}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default memo(InputsFormContent)
|