import G6 from '@antv/g6'; const data = { nodes: [ { id: 'a', data: { x: 200, y: 100, cluster: '1', }, }, { id: 'b', data: { x: 100, y: 200, cluster: '2', }, }, { id: 'c', data: { x: 300, y: 200, cluster: '3', }, }, ], edges: [ { id: 'a2b', source: 'a', target: 'b', }, { id: 'a2c', source: 'a', target: 'c', }, ], }; const container = document.getElementById('container'); const width = container.scrollWidth; const height = container.scrollHeight || 500; const graph = new G6.Graph({ container: 'container', width, height, modes: { default: ['click-select'] }, layout: { type: 'grid', }, theme: { type: 'spec', specification: { node: { dataTypeField: 'cluster', }, }, }, node: { labelShape: { text: { fields: ['id'], formatter: (model) => model.id, }, }, labelBackgroundShape: {}, animates: { buildIn: [ { fields: ['size', 'opacity'], shapeId: 'group', duration: 500, }, ], buildOut: [ { fields: ['opacity'], duration: 200, }, ], update: [ { fields: ['x', 'y'], }, { fields: ['opacity'], shapeId: 'haloShape', states: ['selected'], }, { fields: ['lineWidth', 'fill'], shapeId: 'keyShape', states: ['selected'], }, ], show: [ { fields: ['opacity'], shapeId: 'keyShape', duration: 300, }, ], hide: [ { fields: ['opacity'], shapeId: 'keyShape', duration: 300, }, { fields: ['opacity'], shapeId: 'labelShape', duration: 300, }, ], }, }, edge: { animates: { buildIn: [ { fields: ['opacity'], shapeId: 'keyShape', duration: 500, }, ], buildOut: [ { fields: ['opacity'], shapeId: 'keyShape', duration: 200, }, ], update: [ { fields: ['opacity'], shapeId: 'haloShape', states: ['selected'], }, { fields: ['lineWidth'], shapeId: 'keyShape', states: ['selected'], }, ], show: [ { fields: ['opacity'], shapeId: 'keyShape', duration: 300, }, ], hide: [ { fields: ['opacity'], shapeId: 'keyShape', duration: 300, }, ], }, }, data, }); const newNodes = []; const buildInOutActions = { 'Add Node(buildin)': () => { const node = graph.addData('node', { id: `node-${Math.random()}`, data: { cluster: Math.random(), }, }); graph.updateNodePosition([ { id: node.id, data: { x: Math.random() * 500, y: Math.random() * 500, }, }, ]); newNodes.push(node); }, 'Remove Node(buildout)': () => { if (!newNodes.length) return; graph.removeData('node', newNodes[0].id); newNodes.shift(); }, }; const updateActions = { 'Update Position(update)': () => { const positions = []; data.nodes.forEach((node) => { const { x, y } = node.data; positions.push({ id: node.id, data: { x: x + Math.random() * 50 - 25, y: y + Math.random() * 50 - 25, }, }); node.x += Math.random() * 50 - 25; node.y += Math.random() * 50 - 25; }); graph.updateNodePosition(positions); }, 'Update Node Color(update)': () => { graph.updateData( 'node', graph.getAllNodesData().map((node) => ({ id: node.id, data: { cluster: Math.random(), }, })), ); }, 'Select/Deselect Node(update)': () => { if (graph.getItemState('a', 'selected')) { graph.setItemState('a', 'selected', false); } else { graph.setItemState('a', 'selected', true); } }, 'Select/Deselect Edge(update)': () => { if (graph.getItemState('a2b', 'selected')) { graph.setItemState('a2b', 'selected', false); } else { graph.setItemState('a2b', 'selected', true); } }, }; const showHideActions = { 'Hide/Show Node(show/hide)': () => { if (graph.getItemVisible('a')) { graph.hideItem('a'); } else { graph.showItem('a'); graph.showItem('a2b'); graph.showItem('a2c'); } }, }; const viewPortActions = { 'Fit View': () => { graph.fitView({}, { duration: 500 }); }, 'Fit Center': () => { graph.fitCenter('render', { duration: 500 }); }, 'Zoom In': () => { const currentZoom = graph.getZoom(); graph.zoomTo(currentZoom * 1.1, undefined, { duration: 500 }); }, 'Zoom Out': () => { const currentZoom = graph.getZoom(); graph.zoomTo((currentZoom * 1) / 1.1, undefined, { duration: 500 }); }, Translate: () => { graph.translate({ dx: Math.random() * 200 - 100, dy: Math.random() * 200 - 100 }, { duration: 500 }); }, '1:1': () => { graph.zoomTo(1, undefined, { duration: 500 }); }, }; const actions = { 'animate.buildIn & animate.buildOut': buildInOutActions, 'animate.show & animate.hide': showHideActions, 'animate.update': updateActions, 'view port': viewPortActions, }; const controllerContainer = document.createElement('div'); controllerContainer.style.position = 'absolute'; container.appendChild(controllerContainer); Object.keys(actions).forEach((groupName, i) => { const btnContainer = document.createElement('div'); controllerContainer.appendChild(btnContainer); const tip = document.createElement('span'); tip.innerHTML = `👉 ${groupName}: `; btnContainer.appendChild(tip); Object.keys(actions[groupName]).forEach((name, i) => { const btn = document.createElement('a'); btn.innerHTML = name; btn.style.backgroundColor = 'rgba(255, 255, 255, 0.8)'; btn.style.padding = '4px'; btn.style.marginLeft = i > 0 ? '24px' : '8px'; btnContainer.appendChild(btn); btn.addEventListener('click', () => { actions[groupName][name](); }); }); }); window.graph = graph;