Skip to Content

Turbo Flow

React Flow UI 的每个部分都是可定制的。顾名思义,外观取自漂亮的 turbo.build 网站。你可以在 主题指南 中找到有关自定义样式的更多信息。(React Flow 使用 Turborepo,我们喜欢它 💜)

¥Every part of the React Flow UI is customizable. As the name implies the look is taken from the beautiful turbo.build website. You can find more information about custom styles in the theming guide. (React Flow uses Turborepo and we love it 💜)

import React, { useCallback } from 'react'; import { ReactFlow, Controls, useNodesState, useEdgesState, addEdge, type Node, type Edge, type OnConnect, } from '@xyflow/react'; import { FiFile } from 'react-icons/fi'; import '@xyflow/react/dist/base.css'; import TurboNode, { type TurboNodeData } from './TurboNode'; import TurboEdge from './TurboEdge'; import FunctionIcon from './FunctionIcon'; const initialNodes: Node<TurboNodeData>[] = [ { id: '1', position: { x: 0, y: 0 }, data: { icon: <FunctionIcon />, title: 'readFile', subtitle: 'api.ts' }, type: 'turbo', }, { id: '2', position: { x: 250, y: 0 }, data: { icon: <FunctionIcon />, title: 'bundle', subtitle: 'apiContents' }, type: 'turbo', }, { id: '3', position: { x: 0, y: 250 }, data: { icon: <FunctionIcon />, title: 'readFile', subtitle: 'sdk.ts' }, type: 'turbo', }, { id: '4', position: { x: 250, y: 250 }, data: { icon: <FunctionIcon />, title: 'bundle', subtitle: 'sdkContents' }, type: 'turbo', }, { id: '5', position: { x: 500, y: 125 }, data: { icon: <FunctionIcon />, title: 'concat', subtitle: 'api, sdk' }, type: 'turbo', }, { id: '6', position: { x: 750, y: 125 }, data: { icon: <FiFile />, title: 'fullBundle' }, type: 'turbo', }, ]; const initialEdges: Edge[] = [ { id: 'e1-2', source: '1', target: '2', }, { id: 'e3-4', source: '3', target: '4', }, { id: 'e2-5', source: '2', target: '5', }, { id: 'e4-5', source: '4', target: '5', }, { id: 'e5-6', source: '5', target: '6', }, ]; const nodeTypes = { turbo: TurboNode, }; const edgeTypes = { turbo: TurboEdge, }; const defaultEdgeOptions = { type: 'turbo', markerEnd: 'edge-circle', }; const Flow = () => { const [nodes, setNodes, onNodesChange] = useNodesState(initialNodes); const [edges, setEdges, onEdgesChange] = useEdgesState(initialEdges); const onConnect: OnConnect = useCallback( (params) => setEdges((els) => addEdge(params, els)), [], ); return ( <ReactFlow nodes={nodes} edges={edges} onNodesChange={onNodesChange} onEdgesChange={onEdgesChange} onConnect={onConnect} fitView nodeTypes={nodeTypes} edgeTypes={edgeTypes} defaultEdgeOptions={defaultEdgeOptions} > <Controls showInteractive={false} /> <svg> <defs> <linearGradient id="edge-gradient"> <stop offset="0%" stopColor="#ae53ba" /> <stop offset="100%" stopColor="#2a8af6" /> </linearGradient> <marker id="edge-circle" viewBox="-5 -5 10 10" refX="0" refY="0" markerUnits="strokeWidth" markerWidth="10" markerHeight="10" orient="auto" > <circle stroke="#2a8af6" strokeOpacity="0.75" r="2" cx="0" cy="0" /> </marker> </defs> </svg> </ReactFlow> ); }; export default Flow;