123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- import {
- memo,
- useMemo,
- } from 'react'
- import { useTranslation } from 'react-i18next'
- import { useNodes } from 'reactflow'
- import { ComparisonOperator } from '../types'
- import {
- comparisonOperatorNotRequireValue,
- isComparisonOperatorNeedTranslate,
- } from '../utils'
- import { FILE_TYPE_OPTIONS, TRANSFER_METHOD } from '../../constants'
- import { Variable02 } from '@/app/components/base/icons/src/vender/solid/development'
- import { BubbleX, Env } from '@/app/components/base/icons/src/vender/line/others'
- import cn from '@/utils/classnames'
- import { isConversationVar, isENV, isSystemVar } from '@/app/components/workflow/nodes/_base/components/variable/utils'
- import { isExceptionVariable } from '@/app/components/workflow/utils'
- import type {
- CommonNodeType,
- Node,
- } from '@/app/components/workflow/types'
- type ConditionValueProps = {
- variableSelector: string[]
- labelName?: string
- operator: ComparisonOperator
- value: string | string[]
- }
- const ConditionValue = ({
- variableSelector,
- labelName,
- operator,
- value,
- }: ConditionValueProps) => {
- const { t } = useTranslation()
- const nodes = useNodes()
- const variableName = labelName || (isSystemVar(variableSelector) ? variableSelector.slice(0).join('.') : variableSelector.slice(1).join('.'))
- const operatorName = isComparisonOperatorNeedTranslate(operator) ? t(`workflow.nodes.ifElse.comparisonOperator.${operator}`) : operator
- const notHasValue = comparisonOperatorNotRequireValue(operator)
- const isEnvVar = isENV(variableSelector)
- const isChatVar = isConversationVar(variableSelector)
- const node: Node<CommonNodeType> | undefined = nodes.find(n => n.id === variableSelector[0]) as Node<CommonNodeType>
- const isException = isExceptionVariable(variableName, node?.data.type)
- const formatValue = useMemo(() => {
- if (notHasValue)
- return ''
- if (Array.isArray(value)) // transfer method
- return value[0]
- return value.replace(/{{#([^#]*)#}}/g, (a, b) => {
- const arr: string[] = b.split('.')
- if (isSystemVar(arr))
- return `{{${b}}}`
- return `{{${arr.slice(1).join('.')}}}`
- })
- }, [notHasValue, value])
- const isSelect = operator === ComparisonOperator.in || operator === ComparisonOperator.notIn
- const selectName = useMemo(() => {
- if (isSelect) {
- const name = [...FILE_TYPE_OPTIONS, ...TRANSFER_METHOD].filter(item => item.value === (Array.isArray(value) ? value[0] : value))[0]
- return name
- ? t(`workflow.nodes.ifElse.optionName.${name.i18nKey}`).replace(/{{#([^#]*)#}}/g, (a, b) => {
- const arr: string[] = b.split('.')
- if (isSystemVar(arr))
- return `{{${b}}}`
- return `{{${arr.slice(1).join('.')}}}`
- })
- : ''
- }
- return ''
- }, [isSelect, t, value])
- return (
- <div className='flex h-6 items-center rounded-md bg-workflow-block-parma-bg px-1'>
- {!isEnvVar && !isChatVar && <Variable02 className={cn('mr-1 h-3.5 w-3.5 shrink-0 text-text-accent', isException && 'text-text-warning')} />}
- {isEnvVar && <Env className='mr-1 h-3.5 w-3.5 shrink-0 text-util-colors-violet-violet-600' />}
- {isChatVar && <BubbleX className='h-3.5 w-3.5 shrink-0 text-util-colors-teal-teal-700' />}
- <div
- className={cn(
- 'ml-0.5 shrink-[2] truncate text-xs font-medium text-text-accent',
- !notHasValue && 'max-w-[70px]',
- isException && 'text-text-warning',
- )}
- title={variableName}
- >
- {variableName}
- </div>
- <div
- className='mx-1 shrink-0 text-xs font-medium text-text-primary'
- title={operatorName}
- >
- {operatorName}
- </div>
- {
- !notHasValue && (
- <div className='shrink-[3] truncate text-xs text-text-secondary' title={formatValue}>{isSelect ? selectName : formatValue}</div>
- )
- }
- </div>
- )
- }
- export default memo(ConditionValue)
|