mirror of
https://github.com/langgenius/dify.git
synced 2026-05-13 00:33:37 +08:00
* test: adding some web tests (#27792) * feat: add validation to prevent saving empty opening statement in conversation opener modal (#27843) * fix(web): improve the consistency of the inputs-form UI (#27837) * fix(web): increase z-index of PortalToFollowElemContent (#27823) * fix: installation_id is missing when in tools page (#27849) * fix: avoid passing empty uniqueIdentifier to InstallFromMarketplace (#27802) Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> * test: create new test scripts and update some existing test scripts o… (#27850) * feat: change feedback to forum (#27862) * chore: translate i18n files and update type definitions (#27868) Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> * Fix/template transformer line number (#27867) Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> * bump vite to 6.4.1 (#27877) * Add WEAVIATE_GRPC_ENDPOINT as designed in weaviate migration guide (#27861) Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * Fix: correct DraftWorkflowApi.post response model (#27289) Signed-off-by: Yongtao Huang <yongtaoh2022@gmail.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> * fix Version 2.0.0-beta.2: Chat annotations Api Error #25506 (#27206) Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> * fix jina reader creadential migration command (#27883) * fix agent putout the output of workflow-tool twice (#26835) (#27087) * fix jina reader transform (#27922) * fix: prevent fetch version info in enterprise edition (#27923) * fix(api): fix `VariablePool.get` adding unexpected keys to variable_dictionary (#26767) Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * refactor: implement tenant self queue for rag tasks (#27559) Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: -LAN- <laipz8200@outlook.com> * fix: bump brotli to 1.2.0 resloved CVE-2025-6176 (#27950) Signed-off-by: kenwoodjw <blackxin55+@gmail.com> --------- Signed-off-by: Yongtao Huang <yongtaoh2022@gmail.com> Signed-off-by: kenwoodjw <blackxin55+@gmail.com> Co-authored-by: aka James4u <smart.jamesjin@gmail.com> Co-authored-by: Novice <novice12185727@gmail.com> Co-authored-by: yangzheli <43645580+yangzheli@users.noreply.github.com> Co-authored-by: Elliott <105957288+Elliott-byte@users.noreply.github.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: johnny0120 <johnny0120@users.noreply.github.com> Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: Gritty_dev <101377478+codomposer@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: wangjifeng <163279492+kk-wangjifeng@users.noreply.github.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Boris Polonsky <BorisPolonsky@users.noreply.github.com> Co-authored-by: Yongtao Huang <yongtaoh2022@gmail.com> Co-authored-by: Cursx <33718736+Cursx@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> Co-authored-by: Jyong <76649700+JohnJyong@users.noreply.github.com> Co-authored-by: red_sun <56100962+redSun64@users.noreply.github.com> Co-authored-by: NFish <douxc512@gmail.com> Co-authored-by: QuantumGhost <obelisk.reg+git@gmail.com> Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: hj24 <huangjian@dify.ai> Co-authored-by: kenwoodjw <blackxin55+@gmail.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('workflow.panel.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)
|