File size: 1,462 Bytes
4138aee
 
 
 
0a9da14
 
4138aee
0a9da14
4138aee
 
 
a83cbb2
 
4138aee
 
 
 
a83cbb2
0a9da14
 
 
 
 
 
 
 
 
 
 
 
4138aee
 
0a9da14
 
 
 
 
 
 
 
 
 
 
 
 
 
a83cbb2
0a9da14
 
4138aee
 
 
 
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
import { Flex } from 'antd';
import { Operator, operatorMap } from '../../constant';
import OperatorIcon from '../../operator-icon';
import NodeDropdown from './dropdown';

import { useTranslate } from '@/hooks/common-hooks';
import styles from './index.less';
import { NextNodePopover } from './popover';

interface IProps {
  id: string;
  label: string;
  name: string;
  gap?: number;
  className?: string;
}

export function RunStatus({ id, name }: Omit<IProps, 'label'>) {
  const { t } = useTranslate('flow');
  return (
    <section className="flex justify-end items-center pb-1 ">
      <NextNodePopover nodeId={id} name={name}>
        <span className="text-blue-600 cursor-pointer text-[10px]">
          {t('operationResults')}
        </span>
      </NextNodePopover>
    </section>
  );
}

const NodeHeader = ({ label, id, name, gap = 4, className }: IProps) => {
  return (
    <section className="haha">
      {label !== Operator.Answer && <RunStatus id={id} name={name}></RunStatus>}
      <Flex
        flex={1}
        align="center"
        justify={'space-between'}
        gap={gap}
        className={className}
      >
        <OperatorIcon
          name={label as Operator}
          color={operatorMap[label as Operator].color}
        ></OperatorIcon>
        <span className={styles.nodeTitle}>{name}</span>
        <NodeDropdown id={id} label={label}></NodeDropdown>
      </Flex>
    </section>
  );
};

export default NodeHeader;