refactor: refactor data source handling and add form for document processing
parent
c155afac29
commit
9934eac15c
@ -0,0 +1,41 @@
|
|||||||
|
import { useAppForm } from '@/app/components/base/form'
|
||||||
|
import BaseField from '@/app/components/base/form/form-scenarios/base/field'
|
||||||
|
import type { RAGPipelineVariables } from '@/models/pipeline'
|
||||||
|
import { useConfigurations, useInitialData } from '../../panel/test-run/data-source/website-crawl/base/options/hooks'
|
||||||
|
|
||||||
|
type FormProps = {
|
||||||
|
variables: RAGPipelineVariables
|
||||||
|
}
|
||||||
|
|
||||||
|
const Form = ({
|
||||||
|
variables,
|
||||||
|
}: FormProps) => {
|
||||||
|
const initialData = useInitialData(variables)
|
||||||
|
const configurations = useConfigurations(variables)
|
||||||
|
|
||||||
|
const form = useAppForm({
|
||||||
|
defaultValues: initialData,
|
||||||
|
})
|
||||||
|
|
||||||
|
return (
|
||||||
|
<form
|
||||||
|
className='w-full'
|
||||||
|
onSubmit={(e) => {
|
||||||
|
e.preventDefault()
|
||||||
|
e.stopPropagation()
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
<div className='flex flex-col gap-y-3 px-4 py-3'>
|
||||||
|
{configurations.map((config, index) => {
|
||||||
|
const FieldComponent = BaseField({
|
||||||
|
initialData,
|
||||||
|
config,
|
||||||
|
})
|
||||||
|
return <FieldComponent key={index} form={form} />
|
||||||
|
})}
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default Form
|
||||||
@ -0,0 +1,31 @@
|
|||||||
|
import React from 'react'
|
||||||
|
import { useTranslation } from 'react-i18next'
|
||||||
|
import { useStore } from '@/app/components/workflow/store'
|
||||||
|
import { useDraftPipelineProcessingParams } from '@/service/use-pipeline'
|
||||||
|
import Form from './form'
|
||||||
|
|
||||||
|
type ProcessDocumentsProps = {
|
||||||
|
dataSourceNodeId: string
|
||||||
|
}
|
||||||
|
|
||||||
|
const ProcessDocuments = ({
|
||||||
|
dataSourceNodeId,
|
||||||
|
}: ProcessDocumentsProps) => {
|
||||||
|
const { t } = useTranslation()
|
||||||
|
const pipelineId = useStore(state => state.pipelineId)
|
||||||
|
const { data: paramsConfig } = useDraftPipelineProcessingParams({
|
||||||
|
pipeline_id: pipelineId!,
|
||||||
|
node_id: dataSourceNodeId,
|
||||||
|
})
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div className='flex flex-col'>
|
||||||
|
<div className='system-sm-semibold-uppercase px-4 pt-2 text-text-secondary'>
|
||||||
|
{t('datasetPipeline.inputFieldPanel.preview.stepTwoTitle')}
|
||||||
|
</div>
|
||||||
|
<Form variables={paramsConfig?.variables || []} />
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default React.memo(ProcessDocuments)
|
||||||
Loading…
Reference in New Issue