g6/packages/site/examples/net/dagreFlow/demo/dagreCombo.js
2023-08-31 22:16:30 +08:00

280 lines
4.7 KiB
JavaScript

import { Graph, Extensions, extend } from '@antv/g6';
const ExtGraph = extend(Graph, {
layouts: {
dagre: Extensions.DagreLayout,
},
});
const data = {
nodes: [
{
id: '0',
data: {
label: '0',
},
},
{
id: '1',
data: {
label: '1',
},
},
{
id: '2',
data: {
label: '2',
},
},
{
id: '3',
data: {
label: '3',
},
},
{
id: '4',
data: {
label: '4',
parentId: 'A',
},
},
{
id: '5',
data: {
label: '5',
parentId: 'B',
},
},
{
id: '6',
data: {
label: '6',
parentId: 'A',
},
},
{
id: '7',
data: {
label: '7',
parentId: 'C',
},
},
{
id: '8',
data: {
label: '8',
parentId: 'C',
},
},
{
id: '9',
data: {
label: '9',
parentId: 'A',
},
},
{
id: '10',
data: {
label: '10',
parentId: 'B',
},
},
{
id: '11',
data: {
label: '11',
parentId: 'B',
},
},
],
edges: [
{
id: 'edge-102',
source: '0',
target: '1',
},
{
id: 'edge-161',
source: '0',
target: '2',
},
{
id: 'edge-237',
source: '1',
target: '4',
},
{
id: 'edge-253',
source: '0',
target: '3',
},
{
id: 'edge-133',
source: '3',
target: '4',
},
{
id: 'edge-320',
source: '2',
target: '5',
},
{
id: 'edge-355',
source: '1',
target: '6',
},
{
id: 'edge-823',
source: '1',
target: '7',
},
{
id: 'edge-665',
source: '3',
target: '8',
},
{
id: 'edge-884',
source: '3',
target: '9',
},
{
id: 'edge-536',
source: '5',
target: '10',
},
{
id: 'edge-401',
source: '5',
target: '11',
},
],
combos: [
{
id: 'A',
data: {
text: 'combo A',
},
},
{
id: 'B',
data: {
label: 'combo B',
},
},
{
id: 'C',
data: {
label: 'combo C',
},
},
],
};
let sortByCombo = false;
const descriptionDiv = document.createElement('a');
descriptionDiv.style.position = 'absolute';
descriptionDiv.style.zIndex = 10;
descriptionDiv.innerHTML = '👉 Enable sortByCombo';
descriptionDiv.style.fontSize = '20px';
descriptionDiv.style.border = '1px dashed rgba(34, 126, 255, 0.5)';
descriptionDiv.style.padding = '2px 8px';
const container = document.getElementById('container');
container.appendChild(descriptionDiv);
descriptionDiv.addEventListener('click', (e) => {
sortByCombo = !sortByCombo;
descriptionDiv.innerHTML = sortByCombo ? 'Disable sortByCombo' : 'Enable sortByCombo';
graph.layout({
type: 'dagre',
sortByCombo,
});
});
const width = container.scrollWidth;
const height = (container.scrollHeight || 500) - 30;
const graph = new ExtGraph({
container: 'container',
width,
height: height - 50,
autoFit: 'center',
modes: {
default: ['drag-combo', 'drag-node', 'drag-canvas', 'zoom-canvas', 'collapse-expand-combo'],
},
layout: {
type: 'dagre',
ranksep: 50,
nodesep: 30,
},
theme: {
type: 'spec',
base: 'light',
specification: {
node: {
dataTypeField: 'parentId',
},
},
},
node: (model) => {
const { id, data } = model;
return {
id,
data: {
...data,
type: 'rect-node',
lodStrategy: {},
keyShape: {
width: 60,
height: 30,
radius: 8,
},
labelShape: {
position: 'center',
text: id,
},
anchorPoints: [
[0.5, 0],
[0.5, 1],
],
},
};
},
combo: (model) => {
const { id, data } = model;
return {
id,
data: {
...data,
type: 'rect-combo',
keyShape: {
opacity: 0.8,
padding: [20, 20, 20, 20],
radius: 8,
},
labelShape: {
text: `Combo ${id}`,
offsetY: 8,
},
labelBackgroundShape: {},
animates: {
update: [
{
fields: ['width', 'height', 'x', 'y'],
shapeId: 'keyShape',
},
],
},
},
};
},
data,
});
if (typeof window !== 'undefined')
window.onresize = () => {
if (!graph || graph.destroyed) return;
if (!container || !container.scrollWidth || !container.scrollHeight) return;
graph.setSize([container.scrollWidth, container.scrollHeight - 30]);
};