Merge branch 'feat/plugins' of https://github.com/langgenius/dify into feat/plugins
This commit is contained in:
commit
f9ce6b6a6e
@ -1,4 +1,5 @@
|
|||||||
import type { FC } from 'react'
|
import type { FC } from 'react'
|
||||||
|
import { useMemo } from 'react'
|
||||||
import type { NodePanelProps } from '../../types'
|
import type { NodePanelProps } from '../../types'
|
||||||
import type { AgentNodeType } from './types'
|
import type { AgentNodeType } from './types'
|
||||||
import Field from '../_base/components/field'
|
import Field from '../_base/components/field'
|
||||||
@ -8,6 +9,11 @@ import { useTranslation } from 'react-i18next'
|
|||||||
import OutputVars, { VarItem } from '../_base/components/output-vars'
|
import OutputVars, { VarItem } from '../_base/components/output-vars'
|
||||||
import type { StrategyParamItem } from '@/app/components/plugins/types'
|
import type { StrategyParamItem } from '@/app/components/plugins/types'
|
||||||
import type { CredentialFormSchema } from '@/app/components/header/account-setting/model-provider-page/declarations'
|
import type { CredentialFormSchema } from '@/app/components/header/account-setting/model-provider-page/declarations'
|
||||||
|
import BeforeRunForm from '@/app/components/workflow/nodes/_base/components/before-run-form'
|
||||||
|
import ResultPanel from '@/app/components/workflow/run/result-panel'
|
||||||
|
import formatTracing from '@/app/components/workflow/run/utils/format-log'
|
||||||
|
import { useLogs } from '@/app/components/workflow/run/hooks'
|
||||||
|
import type { Props as FormProps } from '@/app/components/workflow/nodes/_base/components/before-run-form/form'
|
||||||
|
|
||||||
const i18nPrefix = 'workflow.nodes.agent'
|
const i18nPrefix = 'workflow.nodes.agent'
|
||||||
|
|
||||||
@ -20,8 +26,47 @@ export function strategyParamToCredientialForm(param: StrategyParamItem): Creden
|
|||||||
}
|
}
|
||||||
|
|
||||||
const AgentPanel: FC<NodePanelProps<AgentNodeType>> = (props) => {
|
const AgentPanel: FC<NodePanelProps<AgentNodeType>> = (props) => {
|
||||||
const { inputs, setInputs, currentStrategy, formData, onFormChange } = useConfig(props.id, props.data)
|
const {
|
||||||
|
inputs,
|
||||||
|
setInputs,
|
||||||
|
currentStrategy,
|
||||||
|
formData,
|
||||||
|
onFormChange,
|
||||||
|
|
||||||
|
isShowSingleRun,
|
||||||
|
hideSingleRun,
|
||||||
|
runningStatus,
|
||||||
|
handleRun,
|
||||||
|
handleStop,
|
||||||
|
runResult,
|
||||||
|
runInputData,
|
||||||
|
setRunInputData,
|
||||||
|
varInputs,
|
||||||
|
} = useConfig(props.id, props.data)
|
||||||
const { t } = useTranslation()
|
const { t } = useTranslation()
|
||||||
|
const nodeInfo = useMemo(() => {
|
||||||
|
if (!runResult)
|
||||||
|
return
|
||||||
|
return formatTracing([runResult], t)[0]
|
||||||
|
}, [runResult, t])
|
||||||
|
const logsParams = useLogs()
|
||||||
|
const singleRunForms = (() => {
|
||||||
|
const forms: FormProps[] = []
|
||||||
|
|
||||||
|
if (varInputs.length > 0) {
|
||||||
|
forms.push(
|
||||||
|
{
|
||||||
|
label: t(`${i18nPrefix}.singleRun.variable`)!,
|
||||||
|
inputs: varInputs,
|
||||||
|
values: runInputData,
|
||||||
|
onChange: setRunInputData,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
return forms
|
||||||
|
})()
|
||||||
|
|
||||||
return <div className='my-2'>
|
return <div className='my-2'>
|
||||||
<Field title={t('workflow.nodes.agent.strategy.label')} className='px-4' >
|
<Field title={t('workflow.nodes.agent.strategy.label')} className='px-4' >
|
||||||
<AgentStrategy
|
<AgentStrategy
|
||||||
@ -72,6 +117,21 @@ const AgentPanel: FC<NodePanelProps<AgentNodeType>> = (props) => {
|
|||||||
))}
|
))}
|
||||||
</OutputVars>
|
</OutputVars>
|
||||||
</div>
|
</div>
|
||||||
|
{
|
||||||
|
isShowSingleRun && (
|
||||||
|
<BeforeRunForm
|
||||||
|
nodeName={inputs.title}
|
||||||
|
nodeType={inputs.type}
|
||||||
|
onHide={hideSingleRun}
|
||||||
|
forms={singleRunForms}
|
||||||
|
runningStatus={runningStatus}
|
||||||
|
onRun={handleRun}
|
||||||
|
onStop={handleStop}
|
||||||
|
{...logsParams}
|
||||||
|
result={<ResultPanel {...runResult} nodeInfo={nodeInfo} showSteps={false} {...logsParams} />}
|
||||||
|
/>
|
||||||
|
)
|
||||||
|
}
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,26 +21,6 @@ const useConfig = (id: string, payload: AgentNodeType) => {
|
|||||||
inputs.agent_strategy_provider_name || '',
|
inputs.agent_strategy_provider_name || '',
|
||||||
)
|
)
|
||||||
|
|
||||||
// single run
|
|
||||||
const agentInputKey = `${id}.input_selector`
|
|
||||||
const {
|
|
||||||
isShowSingleRun,
|
|
||||||
showSingleRun,
|
|
||||||
hideSingleRun,
|
|
||||||
toVarInputs,
|
|
||||||
runningStatus,
|
|
||||||
handleRun,
|
|
||||||
handleStop,
|
|
||||||
runInputData,
|
|
||||||
setRunInputData,
|
|
||||||
runResult,
|
|
||||||
} = useOneStepRun<AgentNodeType>({
|
|
||||||
id,
|
|
||||||
data: inputs,
|
|
||||||
defaultRunInputData: {
|
|
||||||
[agentInputKey]: [''],
|
|
||||||
},
|
|
||||||
})
|
|
||||||
const currentStrategy = strategyProvider.data?.declaration.strategies.find(
|
const currentStrategy = strategyProvider.data?.declaration.strategies.find(
|
||||||
str => str.identity.name === inputs.agent_strategy_name,
|
str => str.identity.name === inputs.agent_strategy_name,
|
||||||
)
|
)
|
||||||
@ -70,6 +50,36 @@ const useConfig = (id: string, payload: AgentNodeType) => {
|
|||||||
agent_parameters: res,
|
agent_parameters: res,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// single run
|
||||||
|
const {
|
||||||
|
isShowSingleRun,
|
||||||
|
showSingleRun,
|
||||||
|
hideSingleRun,
|
||||||
|
toVarInputs,
|
||||||
|
runningStatus,
|
||||||
|
handleRun,
|
||||||
|
handleStop,
|
||||||
|
runInputData,
|
||||||
|
setRunInputData,
|
||||||
|
runResult,
|
||||||
|
getInputVars,
|
||||||
|
} = useOneStepRun<AgentNodeType>({
|
||||||
|
id,
|
||||||
|
data: inputs,
|
||||||
|
defaultRunInputData: {},
|
||||||
|
})
|
||||||
|
const allVarStrArr = (() => {
|
||||||
|
const arr = ['']
|
||||||
|
|
||||||
|
return arr
|
||||||
|
})()
|
||||||
|
const varInputs = (() => {
|
||||||
|
const vars = getInputVars(allVarStrArr)
|
||||||
|
|
||||||
|
return vars
|
||||||
|
})()
|
||||||
|
|
||||||
return {
|
return {
|
||||||
readOnly,
|
readOnly,
|
||||||
inputs,
|
inputs,
|
||||||
@ -92,7 +102,7 @@ const useConfig = (id: string, payload: AgentNodeType) => {
|
|||||||
runInputData,
|
runInputData,
|
||||||
setRunInputData,
|
setRunInputData,
|
||||||
runResult,
|
runResult,
|
||||||
agentInputKey,
|
varInputs,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -78,10 +78,10 @@ const NodePanel: FC<Props> = ({
|
|||||||
setCollapseState(!nodeInfo.expand)
|
setCollapseState(!nodeInfo.expand)
|
||||||
}, [nodeInfo.expand, setCollapseState])
|
}, [nodeInfo.expand, setCollapseState])
|
||||||
|
|
||||||
const isIterationNode = nodeInfo.node_type === BlockEnum.Iteration
|
const isIterationNode = nodeInfo.node_type === BlockEnum.Iteration && nodeInfo.details?.length
|
||||||
const isRetryNode = hasRetryNode(nodeInfo.node_type) && nodeInfo.retryDetail
|
const isRetryNode = hasRetryNode(nodeInfo.node_type) && nodeInfo.retryDetail?.length
|
||||||
const isAgentNode = nodeInfo.node_type === BlockEnum.Agent
|
const isAgentNode = nodeInfo.node_type === BlockEnum.Agent && nodeInfo.agentLog?.length
|
||||||
const isToolNode = nodeInfo.node_type === BlockEnum.Tool
|
const isToolNode = nodeInfo.node_type === BlockEnum.Tool && nodeInfo.agentLog?.length
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className={cn('px-2 py-1', className)}>
|
<div className={cn('px-2 py-1', className)}>
|
||||||
|
@ -57,10 +57,10 @@ const ResultPanel: FC<ResultPanelProps> = ({
|
|||||||
handleShowAgentOrToolLog,
|
handleShowAgentOrToolLog,
|
||||||
}) => {
|
}) => {
|
||||||
const { t } = useTranslation()
|
const { t } = useTranslation()
|
||||||
const isIterationNode = nodeInfo?.node_type === BlockEnum.Iteration
|
const isIterationNode = nodeInfo?.node_type === BlockEnum.Iteration && nodeInfo?.details?.length
|
||||||
const isRetryNode = hasRetryNode(nodeInfo?.node_type) && nodeInfo?.retryDetail
|
const isRetryNode = hasRetryNode(nodeInfo?.node_type) && nodeInfo?.retryDetail?.length
|
||||||
const isAgentNode = nodeInfo?.node_type === BlockEnum.Agent
|
const isAgentNode = nodeInfo?.node_type === BlockEnum.Agent && nodeInfo?.agentLog?.length
|
||||||
const isToolNode = nodeInfo?.node_type === BlockEnum.Tool
|
const isToolNode = nodeInfo?.node_type === BlockEnum.Tool && nodeInfo?.agentLog?.length
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className='bg-components-panel-bg py-2'>
|
<div className='bg-components-panel-bg py-2'>
|
||||||
|
Loading…
Reference in New Issue
Block a user