condition-value.tsx 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. import {
  2. memo,
  3. useMemo,
  4. } from 'react'
  5. import { useTranslation } from 'react-i18next'
  6. import { ComparisonOperator } from '../types'
  7. import {
  8. comparisonOperatorNotRequireValue,
  9. isComparisonOperatorNeedTranslate,
  10. } from '../utils'
  11. import { FILE_TYPE_OPTIONS, TRANSFER_METHOD } from './../default'
  12. import { Variable02 } from '@/app/components/base/icons/src/vender/solid/development'
  13. import { BubbleX, Env } from '@/app/components/base/icons/src/vender/line/others'
  14. import cn from '@/utils/classnames'
  15. import { isConversationVar, isENV, isSystemVar } from '@/app/components/workflow/nodes/_base/components/variable/utils'
  16. type ConditionValueProps = {
  17. variableSelector: string[]
  18. labelName?: string
  19. operator: ComparisonOperator
  20. value: string | string[]
  21. }
  22. const ConditionValue = ({
  23. variableSelector,
  24. labelName,
  25. operator,
  26. value,
  27. }: ConditionValueProps) => {
  28. const { t } = useTranslation()
  29. const variableName = labelName || (isSystemVar(variableSelector) ? variableSelector.slice(0).join('.') : variableSelector.slice(1).join('.'))
  30. const operatorName = isComparisonOperatorNeedTranslate(operator) ? t(`workflow.nodes.ifElse.comparisonOperator.${operator}`) : operator
  31. const notHasValue = comparisonOperatorNotRequireValue(operator)
  32. const isEnvVar = isENV(variableSelector)
  33. const isChatVar = isConversationVar(variableSelector)
  34. const formatValue = useMemo(() => {
  35. if (notHasValue)
  36. return ''
  37. if (Array.isArray(value)) // transfer method
  38. return value[0]
  39. return value.replace(/{{#([^#]*)#}}/g, (a, b) => {
  40. const arr: string[] = b.split('.')
  41. if (isSystemVar(arr))
  42. return `{{${b}}}`
  43. return `{{${arr.slice(1).join('.')}}}`
  44. })
  45. }, [notHasValue, value])
  46. const isSelect = operator === ComparisonOperator.in || operator === ComparisonOperator.notIn
  47. const selectName = useMemo(() => {
  48. if (isSelect) {
  49. const name = [...FILE_TYPE_OPTIONS, ...TRANSFER_METHOD].filter(item => item.value === (Array.isArray(value) ? value[0] : value))[0]
  50. return name
  51. ? t(`workflow.nodes.ifElse.optionName.${name.i18nKey}`).replace(/{{#([^#]*)#}}/g, (a, b) => {
  52. const arr: string[] = b.split('.')
  53. if (isSystemVar(arr))
  54. return `{{${b}}}`
  55. return `{{${arr.slice(1).join('.')}}}`
  56. })
  57. : ''
  58. }
  59. return ''
  60. }, [isSelect, t, value])
  61. return (
  62. <div className='flex items-center px-1 h-6 rounded-md bg-workflow-block-parma-bg'>
  63. {!isEnvVar && !isChatVar && <Variable02 className='shrink-0 mr-1 w-3.5 h-3.5 text-text-accent' />}
  64. {isEnvVar && <Env className='shrink-0 mr-1 w-3.5 h-3.5 text-util-colors-violet-violet-600' />}
  65. {isChatVar && <BubbleX className='w-3.5 h-3.5 text-util-colors-teal-teal-700' />}
  66. <div
  67. className={cn(
  68. 'shrink-0 truncate text-xs font-medium text-text-accent',
  69. !notHasValue && 'max-w-[70px]',
  70. )}
  71. title={variableName}
  72. >
  73. {variableName}
  74. </div>
  75. <div
  76. className='shrink-0 mx-1 text-xs font-medium text-text-primary'
  77. title={operatorName}
  78. >
  79. {operatorName}
  80. </div>
  81. {
  82. !notHasValue && (
  83. <div className='truncate text-xs text-text-secondary' title={formatValue}>{isSelect ? selectName : formatValue}</div>
  84. )
  85. }
  86. </div>
  87. )
  88. }
  89. export default memo(ConditionValue)