Browse Source

添加代理树

main
mac 6 months ago
parent
commit
87b5f6ff12
  1. 4
      src/api/index.ts
  2. 53
      src/pages/chart/data.ts
  3. 84
      src/pages/chart/index.tsx
  4. 11
      src/route/routes.ts

4
src/api/index.ts

@ -86,5 +86,9 @@ export default {
set_openPrice(body: object) {
return $axios.post('/admin/updOpenPrice', body)
},
user_relation(data: object) {
return $axios.post('/admin/inviti', data)
}
}

53
src/pages/chart/data.ts

@ -0,0 +1,53 @@
import dagre from 'dagre';
const edgeType = 'smoothstep';
export const flattenTree = (tree) => {
let stack = [tree];
let nodes = [];
let edges = [];
while (stack.length > 0) {
let node = stack.pop();
nodes.push({ id: node.id, data: { ...node, label: `${node.name}` }, position: node.position });
if (node.children && node.children.length > 0) {
node.children.map(item => {
edges.push({ source: node.id, target: item.id, id: item.id, type: edgeType, animated: true });
stack.unshift(item);
});
};
};
return { nodes, edges };
};
export const getLayoutedElements = (nodes, edges, direction = 'TB') => {
const dagreGraph = new dagre.graphlib.Graph();
dagreGraph.setDefaultEdgeLabel(() => ({}));
const nodeWidth = 172;
const nodeHeight = 36;
const isHorizontal = direction === 'LR';
dagreGraph.setGraph({ rankdir: direction });
nodes.forEach((node: any) => {
dagreGraph.setNode(node.id, { width: nodeWidth, height: nodeHeight });
});
edges.forEach((edge: any) => {
dagreGraph.setEdge(edge.source, edge.target);
});
dagre.layout(dagreGraph);
nodes.forEach((node: any) => {
const nodeWithPosition = dagreGraph.node(node.id);
node.targetPosition = isHorizontal ? 'left' : 'top';
node.sourcePosition = isHorizontal ? 'right' : 'bottom';
node.position = {
x: nodeWithPosition.x - nodeWidth / 2,
y: nodeWithPosition.y - nodeHeight / 2,
};
return node;
});
return { nodes, edges };
};

84
src/pages/chart/index.tsx

@ -0,0 +1,84 @@
import React, { useCallback, FC, useEffect, useState, useRef } from 'react';
import ReactFlow, {
addEdge,
ConnectionLineType,
useNodesState,
useEdgesState,
Controls
} from 'react-flow-renderer';
import { getLayoutedElements, flattenTree } from './data';
import { Button, Form, Input, Modal, notification } from 'antd';
import api from '@/api';
const InviteChart: FC = () => {
const [nodes, setNodes, onNodesChange] = useNodesState([]);
const [edges, setEdges, onEdgesChange] = useEdgesState([]);
const [form] = Form.useForm()
const buttonRef = useRef(null)
// 获取节点
const getNodes = async (email?: string) => {
const res: any = await api.user_relation({ email: email || '' });
if (res.code === 0) {
let { nodes, edges } = flattenTree(res.data) // 处理节点及连接线
let { nodes: layoutedNodes, edges: layoutedEdges } = getLayoutedElements(nodes, edges)//计算节点位置
setNodes([...layoutedNodes])
setEdges([...layoutedEdges])
buttonRef.current.click()
};
};
const onFinish = (values) => {
form.resetFields()
getNodes(values.email)
}
const onLayout = useCallback(
(direction: any) => {
const { nodes: layoutedNodes, edges: layoutedEdges } = getLayoutedElements(
nodes,
edges,
direction
);
setNodes([...layoutedNodes]);
setEdges([...layoutedEdges]);
},
[nodes, edges]
);
useEffect(() => {
getNodes();
}, []);
return (
<div>
<Button onClick={() => onLayout('LR')} style={{ display: 'none' }} ref={buttonRef}>123123123</Button>
<Form layout='inline' form={form} onFinish={onFinish}>
<Form.Item name="email">
<Input placeholder='请输入邮箱' style={{ width: 300 }} />
</Form.Item>
<Form.Item>
<Button htmlType='submit' type='primary'></Button>
</Form.Item>
</Form>
<div style={{ width: '100%', height: window.innerHeight - 165 }}>
<ReactFlow
nodes={nodes}
edges={edges}
onNodesChange={onNodesChange}
onEdgesChange={onEdgesChange}
connectionLineType={ConnectionLineType.SmoothStep}
fitView
>
<Controls />
</ReactFlow>
</div>
</div>
);
};
export default InviteChart;

11
src/route/routes.ts

@ -12,6 +12,7 @@ import SystemWithdraw from "@/pages/system/withdraw"
import SystemNotify from "@/pages/system/notify"
import SystemReceive from "@/pages/system/receive"
import AccountReview from "@/pages/account-review"
import InviteChart from "@/pages/chart"
const routes = [
{
@ -170,7 +171,15 @@ const routes = [
},
]
},
{
path: '/chart',
name: '仪表盘',
exact: true,
key: 'chart',
icon: HomeOutlined,
component: InviteChart,
routes: []
},
]
Loading…
Cancel
Save