react-flow-chart-editor

1.0.1 • Public • Published

安装

npm install -S react-flow-chart-editor

方法使用

import FlowEditor from 'react-flow-chart-editor';
 
class DataSourceManagement extends Component {
    constructor(props) {
        super(props)
        this.state = {
            data: {},
            flowItemPanelData: []
        }
    }
 
    handelSave = (resp) => {
        //生成json
        console.log(resp)
    }
 
    render() {
        return (    
            <div className="management-content">
                <FlowEditor flowItemPanelData={this.state.flowItemPanelData} save={this.handelSave} />
            </div>
        )
    }
}
 

页面效果

base64str

初始数据设置

import FlowEditor from 'react-flow-chart-editor';
 
const data =  { "nodes": [{ "type": "node", "size": "72*72", "shape": "flow-circle", "color": "#FA8C16", "label": "开始", "x": 192.84375, "y": 64, "id": "769fdc42", "index": 0 }, { "type": "node", "size": "80*48", "shape": "flow-rect", "color": "#1890FF", "label": "开始", "x": 192.84375, "y": 173.5, "id": "598189cb", "index": 1 }, { "type": "node", "size": "80*72", "shape": "flow-rhombus", "color": "#13C2C2", "label": "判断条件", "x": 193.34375, "y": 282.5, "id": "cc3ef546", "index": 4 }, { "type": "node", "size": "80*48", "shape": "flow-capsule", "color": "#722ED1", "label": "结果1", "x": 193.671875, "y": 389.8, "id": "6f4ece05", "index": 5 }, { "type": "node", "size": "80*72", "shape": "flow-rhombus", "color": "#13C2C2", "label": "判断条件2", "x": 395.671875, "y": 288, "id": "14806120", "index": 7 }, { "type": "node", "size": "80*48", "shape": "flow-rect", "color": "#1890FF", "label": "结果2", "x": 396.171875, "y": 380.2, "id": "977ef7a8", "index": 10 }], "edges": [{ "source": "769fdc42", "sourceAnchor": 2, "target": "598189cb", "targetAnchor": 0, "id": "95f5b5e6", "index": 2 }, { "source": "598189cb", "sourceAnchor": 2, "target": "cc3ef546", "targetAnchor": 0, "id": "6299a1c8", "index": 3 }, { "source": "cc3ef546", "sourceAnchor": 2, "target": "6f4ece05", "targetAnchor": 0, "id": "06d5f767", "label": "", "shape": "flow-smooth", "index": 6 }, { "source": "cc3ef546", "sourceAnchor": 1, "target": "14806120", "targetAnchor": 3, "id": "feab2dd0", "label": "", "shape": "flow-polyline", "index": 8 }, { "source": "14806120", "sourceAnchor": 2, "target": "977ef7a8", "targetAnchor": 0, "id": "1057e78e", "label": "", "shape": "flow-smooth", "index": 9 }, { "source": "14806120", "sourceAnchor": 0, "target": "598189cb", "targetAnchor": 1, "id": "0201aa50", "label": "条件不成立", "shape": "flow-polyline", "index": 11 }] }
 
class DataSourceManagement extends Component {
    constructor(props) {
        super(props)
        this.state = {
            data, // 数据样式为保存之后的数据格式
            flowItemPanelData: []
        }
    }
 
    handelSave = (resp) => {
        //生成json
        console.log(resp)
    }
 
    render() {
        return (    
            <div className="management-content">
                <FlowEditor data={this.state.data} flowItemPanelData={this.state.flowItemPanelData} save={this.handelSave} />
            </div>
        )
    }
}
 

设置左边功能栏

const flowItemPanelData = [
    {
        type: 'node',
        size: '72*72',
        shape: 'flow-circle',
        model: {
            color: '#FA8C16', //色值
            label: '开始' // 描述
        },
        src: ''
    },
    {
        type: 'node',
        size: '80*48',
        shape: 'flow-rect', 
        model: {
            color: '#1890FF',
            label: 'Normal'
        },
        src: ''
    },
    {
        type: 'node',
        size: '80*72',
        shape: 'flow-rhombus',
        model: {
            color: '#13C2C2', 
            label: '判断条件'
        },
        src: ''
    }
]
 
class DataSourceManagement extends Component {
    constructor(props) {
        super(props)
        this.state = {
            data:{}, // 数据样式为保存之后的数据格式
            flowItemPanelData
        }
    }
 
    handelSave = (resp) => {
        //生成json
        console.log(resp)
    }
 
    render() {
        return (    
            <div className="management-content">
                <FlowEditor data={this.state.data} flowItemPanelData={this.state.flowItemPanelData} save={this.handelSave} />
            </div>
        )
    }
}
 

效果图片

效果图片

Package Sidebar

Install

npm i react-flow-chart-editor

Weekly Downloads

0

Version

1.0.1

License

ISC

Unpacked Size

42 kB

Total Files

3

Last publish

Collaborators

  • albanjin