File size: 2,247 Bytes
1dd9186
cfaaa6c
1dd9186
cfaaa6c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1dd9186
cfaaa6c
 
1dd9186
cfaaa6c
1dd9186
cfaaa6c
 
1dd9186
cfaaa6c
1dd9186
cfaaa6c
1dd9186
cfaaa6c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import { memo } from 'react';
import NodeShell from '../components/NodeShell.jsx';
import { NodeDraftInput, NodeDraftTextarea } from '../components/NodeDraftField.jsx';
import { useWorkflow } from '../context/WorkflowContext.jsx';
import { getNodeAccent } from '../lib/nodeRegistry.js';

function ComponentFlowNode({ id, data, selected, type }) {
  const { getNodeHandles, patchNodeData, openComponent, saveComponentNode } = useWorkflow();
  const handles = getNodeHandles(type, data);
  const runtime = data.runtime || {};
  const subgraphNodes = (data.subgraph?.nodes || []).filter(
    (node) => !['system/component-input', 'system/component-output'].includes(node.type),
  );

  return (
    <NodeShell
      nodeId={id}
      title={data.title?.trim() || 'Компонент'}
      accent={getNodeAccent(type)}
      selected={selected}
      status={runtime.status}
      inputs={handles.inputs}
      outputs={handles.outputs}
    >
      <div className="field-stack">
        <NodeDraftInput
          className="nodrag node-input"
          type="text"
          value={data.title || ''}
          placeholder="Название компонента"
          onCommit={(value) => patchNodeData(id, { title: value })}
        />

        <NodeDraftTextarea
          className="nodrag nowheel node-textarea component-node__description"
          value={data.description || ''}
          placeholder="Короткое описание того, что происходит внутри"
          onCommit={(value) => patchNodeData(id, { description: value })}
        />

        <div className="component-node__meta">
          <span>Внутренних нод: {subgraphNodes.length}</span>
          <div className="button-row">
            <button type="button" className="nodrag node-button" onClick={() => saveComponentNode(id)}>
              Сохранить
            </button>
            <button type="button" className="nodrag node-button" onClick={() => openComponent(id)}>
              Открыть
            </button>
          </div>
        </div>

        {runtime.error ? <div className="node-error">{runtime.error}</div> : null}
      </div>
    </NodeShell>
  );
}

export default memo(ComponentFlowNode);