import { Dom, Graph, Node } from '@antv/x6' import { conveyor, direction, one_track, pallet, rgv, stacker, storage, two_track } from './images' import { basicPorts, customPorts } from './ports' export const SRM = Graph.registerNode('SRM', { inherit: 'image', width: 40, height: 40, attrs: { image: { 'xlink:href': stacker, height: 40, x: 0, y: 0, preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' }, imagePallet: { 'xlink:href': pallet, height: 40, width: 40, class: 'hide-pallet', preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' }, body: { // stroke: '#5F95FF', stroke: '#FF0000', strokeWidth: 3, fill: 'rgba(95,149,255,0.0001)', // fill: 'rgba(255,0,0,1)', height: 0, width: 0, class: 'flash-shrink-animation-close' }, textCode: { class: 'animate-text1', text: '', fontSize: 8, fill: '#000000', stroke: '#000000', strokeWidth: 1, x: 0, y: -5 } // text: { // stroke: '#FF0000', // strokeWidth: 1, // class: 'animate-text1', // text: '堆垛机', // fontSize: 12, // fill: '#FF0000', // fillOpacity: 0.8, // background: { // fill: '#FFFF00', // } // } }, markup: [ { tagName: 'image', selector: 'image' }, { tagName: 'image', selector: 'imagePallet' }, { tagName: 'rect', selector: 'body' }, { tagName: 'text', selector: 'textCode' } ] }) export const RGV = Graph.registerNode('RGV', { inherit: 'image', width: 40, height: 40, attrs: { image: { 'xlink:href': rgv, height: 40, x: 0, y: 0, preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' }, imagePallet: { 'xlink:href': pallet, height: 40, width: 40, class: 'hide-pallet', preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' }, body: { stroke: '#FF0000', strokeWidth: 3, fill: 'rgba(95,149,255,0.0001)', height: 0, width: 0, class: 'flash-shrink-animation-close' }, textCode: { class: 'animate-text1', text: '', fontSize: 8, fill: '#000000', stroke: '#000000', strokeWidth: 1, x: 5, y: 20 } }, markup: [ { tagName: 'image', selector: 'image' }, { tagName: 'image', selector: 'imagePallet' }, { tagName: 'rect', selector: 'body' }, { tagName: 'text', selector: 'textCode' } ] }) export const Station = Graph.registerNode('Station', { inherit: 'image', width: 60, height: 60, attrs: { image: { 'xlink:href': conveyor, height: 60, x: 0, y: 0, preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' }, imagePallet: { 'xlink:href': pallet, height: 40, width: 40, class: 'hide-pallet', preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' }, body: { stroke: '#FF0000', strokeWidth: 3, fill: 'rgba(95,149,255,0.0001)', height: 0, width: 0, class: 'flash-shrink-animation-close' }, text: { class: 'animate-text1', fontSize: 12, // fill: '#5F95FF', // fill: '#0000FF', fill: '#5F95FF' }, textCode: { class: 'animate-text1', text: '', fontSize: 8, fill: '#000000', stroke: '#000000', strokeWidth: 1, x: 15, y: 20 } }, markup: [ { tagName: 'image', selector: 'image' }, { tagName: 'image', selector: 'imagePallet' }, { tagName: 'rect', selector: 'body' }, { tagName: 'rect', selector: 'textBackground' }, { tagName: 'text', selector: 'text' }, { tagName: 'text', selector: 'textCode' } ] }) export const Station_D = Graph.registerNode('Station-D', { inherit: 'image', width: 60, height: 60, attrs: { image: { 'xlink:href': direction, height: 60, x: 0, y: 0, preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' }, imagePallet: { 'xlink:href': pallet, height: 40, width: 40, class: 'hide-pallet', preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' }, body: { stroke: '#FF0000', strokeWidth: 3, fill: 'rgba(95,149,255,0.0001)', height: 0, width: 0, class: 'flash-shrink-animation-close' }, text: { class: 'animate-text1', text: '', fontSize: 12, // fill: '#5F95FF', // fill: '#0000FF', fill: '#5F95FF' }, textCode: { class: 'animate-text1', text: '', fontSize: 8, fill: '#000000', stroke: '#000000', strokeWidth: 1, x: 2, y: 20 } }, markup: [ { tagName: 'image', selector: 'image' }, { tagName: 'image', selector: 'imagePallet' }, { tagName: 'rect', selector: 'body' }, { tagName: 'text', selector: 'text' }, { tagName: 'text', selector: 'textCode' } ] }) export const Storage = Graph.registerNode('Storage', { inherit: 'image', width: 60, height: 60, attrs: { image: { 'xlink:href': storage, height: 60, x: 0, y: 0, preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' }, body: { stroke: '#5F95FF', strokeWidth: 1, fill: 'rgba(95,149,255,0.05)', height: 30, width: 30 }, text: { class: 'animate-text1', text: '1', fontSize: 12, fill: '#5F95FF' // fill: '#0000FF', } }, markup: [ { tagName: 'image', selector: 'image' }, { tagName: 'rect', selector: 'body' }, { tagName: 'text', selector: 'text' } ] }) export const OneTrack = Graph.registerNode('OneTrack', { inherit: 'image', width: 40, height: 40, attrs: { image: { 'xlink:href': one_track, height: 40, x: 0, y: 0, preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' } }, markup: [ { tagName: 'image', selector: 'image' } ] }) export const TwoTrack = Graph.registerNode('TwoTrack', { inherit: 'image', width: 40, height: 40, attrs: { image: { 'xlink:href': two_track, height: 40, x: 0, y: 0, preserveAspectRatio: 'none', 'vector-effect': 'non-scaling-stroke' } }, markup: [ { tagName: 'image', selector: 'image' } ] }) // 基础节点 export const FlowChartRect = Graph.registerNode('flow-chart-rect', { inherit: 'rect', width: 80, height: 42, attrs: { body: { stroke: '#5F95FF', strokeWidth: 1, fill: '#ffffff' }, fo: { refWidth: '100%', refHeight: '100%' }, foBody: { xmlns: Dom.ns.xhtml, style: { width: '100%', height: '100%', display: 'flex', justifyContent: 'center', alignItems: 'center' } }, 'edit-text': { contenteditable: 'true', class: 'x6-edit-text', style: { width: '100%', textAlign: 'center', fontSize: 12, color: 'rgba(0,0,0,0.85)' } }, text: { fontSize: 12, fill: '#080808' } }, markup: [ { tagName: 'rect', selector: 'body' }, { tagName: 'text', selector: 'text' } // 不让双击编辑文本 // { // tagName: 'foreignObject', // selector: 'fo', // children: [ // { // ns: Dom.ns.xhtml, // tagName: 'body', // selector: 'foBody', // children: [ // { // tagName: 'div', // selector: 'edit-text' // } // ] // } // ] // } ], ports: { ...basicPorts } }) // 组合节点 export const FlowChartImageRect = Graph.registerNode('flow-chart-image-rect', { inherit: 'rect', width: 200, height: 60, attrs: { body: { stroke: '#5F95FF', strokeWidth: 1, fill: 'rgba(95,149,255,0.05)' }, image: { 'xlink:href': 'https://gw.alipayobjects.com/zos/antfincdn/FLrTNDvlna/antv.png', width: 16, height: 16, x: 12, y: 12 }, title: { text: 'Node', refX: 40, refY: 14, fill: 'rgba(0,0,0,0.85)', fontSize: 12, 'text-anchor': 'start' }, text: { text: 'this is content text', refX: 40, refY: 38, fontSize: 12, fill: 'rgba(0,0,0,0.6)', 'text-anchor': 'start' } }, markup: [ { tagName: 'rect', selector: 'body' }, { tagName: 'image', selector: 'image' }, { tagName: 'text', selector: 'title' }, { tagName: 'text', selector: 'text' } ], ports: { ...basicPorts } }) export const FlowChartTitleRect = Graph.registerNode('flow-chart-title-rect', { inherit: 'rect', width: 200, height: 68, attrs: { body: { stroke: '#5F95FF', strokeWidth: 1, fill: 'rgba(95,149,255,0.05)' }, head: { refWidth: '100%', stroke: 'transparent', height: 28, fill: 'rgb(95,149,255)' }, image: { 'xlink:href': '', height: 16, x: 6, y: 6 }, title: { text: 'Node', refX: 30, refY: 9, fill: '#ffffff', fontSize: 12, 'text-anchor': 'start' }, text: { text: 'this is content text', refX: 8, refY: 45, fontSize: 12, fill: 'rgba(0,0,0,0.6)', 'text-anchor': 'start' } }, markup: [ { tagName: 'rect', selector: 'body' }, { tagName: 'rect', selector: 'head' }, { tagName: 'image', selector: 'image' }, { tagName: 'text', selector: 'title' }, { tagName: 'text', selector: 'text' } ], ports: { ...basicPorts } }) export const FlowChartAnimateText = Graph.registerNode( 'flow-chart-animate-text', { inherit: 'rect', width: 200, height: 60, attrs: { body: { stroke: '#5F95FF', strokeWidth: 1, fill: 'rgba(95,149,255,0.05)' }, text1: { class: 'animate-text1', text: '|||||||||||||', fontSize: 50, fill: '#5F95FF' } // text2: { // class: 'animate-text2', // text: 'AntV X6', // fontSize: 32 // } }, markup: [ { tagName: 'rect', selector: 'body' }, { tagName: 'text', selector: 'text1' } // { // tagName: 'text', // selector: 'text2' // } ] } ) // 自定义 系统设计图 export const FlowChartImageRectCustom = Graph.registerNode( 'flow-chart-image-rect-custom', { inherit: 'rect', width: 80, height: 80, markup: [ { tagName: 'rect', selector: 'body' }, { tagName: 'image' }, { tagName: 'text', selector: 'label' } ], attrs: { body: { // 节点线的颜色 stroke: 'transparent', // 背景填充色 fill: 'transparent' }, // 自定义图片 image: { width: 60, height: 60, refX: 0, refY: 0 }, label: { refX: 3, refY: 2, textAnchor: 'left', textVerticalAnchor: 'top', fontSize: 12, fill: 'black' }, 'edit-text': { contenteditable: 'true', class: 'x6-edit-text', style: { width: '100%', textAlign: 'center', fontSize: 12, color: 'rgba(0,0,0,0.85)' } }, text: { fontSize: 12, fill: '#080808' } }, ports: { ...customPorts } } ) // 节点组 export class NodeGroup extends Node { collapsed = true; postprocess() { this.toggleCollapse(true) } isCollapsed() { return this.collapsed } toggleCollapse(collapsed) { const target = collapsed == null ? !this.collapsed : collapsed if (target) { this.attr('buttonSign', { d: 'M 1 5 9 5 M 5 1 5 9' }) this.resize(200, 40) } else { this.attr('buttonSign', { d: 'M 2 5 8 5' }) this.resize(240, 240) } this.collapsed = target } } NodeGroup.config({ shape: 'rect', markup: [ { tagName: 'rect', selector: 'body' }, { tagName: 'image', selector: 'image' }, { tagName: 'text', selector: 'text' }, { tagName: 'g', selector: 'buttonGroup', children: [ { tagName: 'rect', selector: 'button', attrs: { 'pointer-events': 'visiblePainted' } }, { tagName: 'path', selector: 'buttonSign', attrs: { fill: 'none', 'pointer-events': 'none' } } ] } ], attrs: { body: { refWidth: '100%', refHeight: '100%', strokeWidth: 1, fill: 'rgba(95,149,255,0.05)', stroke: '#5F95FF' }, image: { 'xlink:href': 'https://gw.alipayobjects.com/mdn/rms_0b51a4/afts/img/A*X4e0TrDsEiIAAAAAAAAAAAAAARQnAQ', width: 16, height: 16, x: 8, y: 12 }, text: { fontSize: 12, fill: 'rgba(0,0,0,0.85)', refX: 30, refY: 15 }, buttonGroup: { refX: '100%', refX2: -25, refY: 13 }, button: { height: 14, width: 16, rx: 2, ry: 2, fill: '#f5f5f5', stroke: '#ccc', cursor: 'pointer', event: 'node:collapse' }, buttonSign: { refX: 3, refY: 2, stroke: '#808080' } } }) Graph.registerNode('groupNode', NodeGroup)