g6/stories/Shape/component/quadratic.tsx

79 lines
1.4 KiB
TypeScript
Raw Normal View History

import React, { useEffect } from 'react';
import G6 from '../../../src';
import { IGraph } from '../../../src/interface/graph';
let graph: IGraph = null;
const data = {
nodes: [
{
2020-04-21 12:28:22 +08:00
id: '1',
name: 'name1',
x: 100,
2020-04-21 12:28:22 +08:00
y: 110,
},
{
2020-04-21 12:28:22 +08:00
id: '2',
name: 'name2',
x: 400,
y: 110,
},
{
2020-04-21 12:28:22 +08:00
id: '3',
name: 'name3',
x: 210,
2020-04-21 12:28:22 +08:00
y: 400,
},
],
edges: [
{
2020-04-21 12:28:22 +08:00
source: '1',
target: '2',
type: 'quadratic',
curveOffset: -150,
curvePosition: 0.5
},
{
2020-04-21 12:28:22 +08:00
source: '1',
target: '3',
},
2020-04-21 12:28:22 +08:00
],
};
const Quadratic = () => {
const container = React.useRef();
useEffect(() => {
if (!graph) {
const graph = new G6.Graph({
container: container.current as string | HTMLElement,
width: 1000,
height: 800,
// layout: {
// type: "dagre",
// rankdir: "TB",
// align: "UL",
// nodesep: 25,
// ranksep: 50,
// controlPoints: true
// },
defaultEdge: {
type: 'cubic-horizontal',
// curveOffset: [-50, 50],
// curvePosition: [9 / 10, 1 / 10]
// curveOffset: 100,
2020-04-21 12:28:22 +08:00
curvePosition: 0.9,
},
modes: {
2020-04-21 12:28:22 +08:00
default: ['drag-node'],
},
});
graph.data(data);
graph.render();
}
});
return <div ref={container}></div>;
};
export default Quadratic;