diff --git a/web/app/components/workflow/nodes/variable-assigner/default.ts b/web/app/components/workflow/nodes/variable-assigner/default.ts index 15793b0952..7291f331c7 100644 --- a/web/app/components/workflow/nodes/variable-assigner/default.ts +++ b/web/app/components/workflow/nodes/variable-assigner/default.ts @@ -3,6 +3,8 @@ import { BlockEnum } from '../../types' import type { VariableAssignerNodeType } from './types' import { ALL_CHAT_AVAILABLE_BLOCKS, ALL_COMPLETION_AVAILABLE_BLOCKS } from '@/app/components/workflow/constants' +const i18nPrefix = 'workflow' + const nodeDefault: NodeDefault = { defaultValue: { output_type: VarType.string, @@ -18,15 +20,20 @@ const nodeDefault: NodeDefault = { const nodes = isChatMode ? ALL_CHAT_AVAILABLE_BLOCKS : ALL_COMPLETION_AVAILABLE_BLOCKS return nodes }, - checkValid(payload: VariableAssignerNodeType) { - let isValid = true + checkValid(payload: VariableAssignerNodeType, t: any) { let errorMessages = '' - if (payload.type) { - isValid = true - errorMessages = '' + const { variables } = payload + if (!variables || variables.length === 0) + errorMessages = t(`${i18nPrefix}.errorMsg.fieldRequired`, { field: t(`${i18nPrefix}.nodes.variableAssigner.title`) }) + if (!errorMessages) { + variables.forEach((variable) => { + if (!variable || variable.length === 0) + errorMessages = t(`${i18nPrefix}.errorMsg.fieldRequired`, { field: t(`${i18nPrefix}.errorMsg.fields.variableValue`) }) + }) } + return { - isValid, + isValid: !errorMessages, errorMessage: errorMessages, } },