wwf
2025-05-20 938c3e5a587ce950a94964ea509b9e7f8834dfae
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
import {
  memo,
  useMemo,
} from 'react'
import { useTranslation } from 'react-i18next'
import cn from '@/utils/classnames'
import { VarBlockIcon } from '@/app/components/workflow/block-icon'
import { Line3 } from '@/app/components/base/icons/src/public/common'
import { Variable02 } from '@/app/components/base/icons/src/vender/solid/development'
import { BubbleX, Env } from '@/app/components/base/icons/src/vender/line/others'
import Badge from '@/app/components/base/badge'
import type { Node } from '@/app/components/workflow/types'
 
type NodeVariableItemProps = {
  isEnv: boolean
  isChatVar: boolean
  node: Node
  varName: string
  writeMode?: string
  showBorder?: boolean
  className?: string
  isException?: boolean
}
 
const i18nPrefix = 'workflow.nodes.assigner'
 
const NodeVariableItem = ({
  isEnv,
  isChatVar,
  node,
  varName,
  writeMode,
  showBorder,
  className,
  isException,
}: NodeVariableItemProps) => {
  const { t } = useTranslation()
 
  const VariableIcon = useMemo(() => {
    if (isEnv) {
      return (
        <Env className='h-3.5 w-3.5 shrink-0 text-util-colors-violet-violet-600' />
      )
    }
 
    if (isChatVar) {
      return (
        <BubbleX className='h-3.5 w-3.5 shrink-0 text-util-colors-teal-teal-700' />
      )
    }
 
    return (
      <Variable02
        className={cn(
          'h-3.5 w-3.5 shrink-0 text-text-accent',
          isException && 'text-text-warning',
        )}
      />
    )
  }, [isEnv, isChatVar, isException])
 
  const VariableName = useMemo(() => {
    return (
      <div
        className={cn(
          'system-xs-medium ml-0.5 shrink truncate text-text-accent',
          isEnv && 'text-text-primary',
          isException && 'text-text-warning',
          isChatVar && 'text-util-colors-teal-teal-700',
        )}
        title={varName}
      >
        {varName}
      </div>
    )
  }, [isEnv, isChatVar, varName, isException])
  return (
    <div className={cn(
      'relative flex items-center gap-1 self-stretch rounded-md bg-workflow-block-parma-bg p-[3px] pl-[5px]',
      showBorder && '!bg-state-base-hover',
      className,
    )}>
      <div className='flex w-0 grow items-center'>
        {
          node && (
            <>
              <div className='shrink-0 p-[1px]'>
                <VarBlockIcon
                  className='!text-text-primary'
                  type={node.data.type}
                />
              </div>
              <div
                className='mx-0.5 shrink-[1000] truncate text-xs font-medium text-text-secondary'
                title={node?.data.title}
              >
                {node?.data.title}
              </div>
              <Line3 className='mr-0.5 shrink-0'></Line3>
            </>
          )
        }
        {VariableIcon}
        {VariableName}
      </div>
      {writeMode && <Badge className='shrink-0' text={t(`${i18nPrefix}.operations.${writeMode}`)} />}
    </div>
  )
}
 
export default memo(NodeVariableItem)