feat: if node valid

This commit is contained in:
Joel 2024-03-19 17:33:49 +08:00
parent e4fdf1730e
commit d49834ee56
1 changed files with 14 additions and 7 deletions

View File

@ -2,6 +2,8 @@ import { BlockEnum, type NodeDefault } from '../../types'
import { type IfElseNodeType, LogicalOperator } from './types'
import { ALL_CHAT_AVAILABLE_BLOCKS, ALL_COMPLETION_AVAILABLE_BLOCKS } from '@/app/components/workflow/constants'
const i18nPrefix = 'workflow.errorMsg'
const nodeDefault: NodeDefault<IfElseNodeType> = {
defaultValue: {
_targetBranches: [
@ -27,15 +29,20 @@ const nodeDefault: NodeDefault<IfElseNodeType> = {
const nodes = isChatMode ? ALL_CHAT_AVAILABLE_BLOCKS : ALL_COMPLETION_AVAILABLE_BLOCKS
return nodes.filter(type => type !== BlockEnum.VariableAssigner)
},
checkValid(payload: IfElseNodeType) {
let isValid = true
checkValid(payload: IfElseNodeType, t: any) {
let errorMessages = ''
if (payload.type) {
isValid = true
errorMessages = ''
}
const { conditions } = payload
if (!conditions || conditions.length === 0)
errorMessages = t(`${i18nPrefix}.fieldRequired`, { field: 'IF' })
conditions.forEach((condition) => {
if (!errorMessages && (!condition.variable_selector || condition.variable_selector.length === 0))
errorMessages = t(`${i18nPrefix}.fieldRequired`, { field: t(`${i18nPrefix}.fields.variable`) })
if (!errorMessages && !condition.value)
errorMessages = t(`${i18nPrefix}.fieldRequired`, { field: t(`${i18nPrefix}.fields.variableValue`) })
})
return {
isValid,
isValid: !errorMessages,
errorMessage: errorMessages,
}
},