Skip to content

logicFlow使用

logicFlow是一款比较好用的前端工作流框架(推荐使用)
This page demonstrates some of the built-in markdown extensions provided by VitePress.

安装

md
```vue
  "dependencies": {
  "@logicflow/core": "^1.2.26",
  "@logicflow/engine": "^0.0.12",
  "@logicflow/extension": "^1.2.26",
}
```

##例子

md
```html
<template>
    <div class="main">
        <div id="view"></div>
        <div class="attr" v-if="showAttr == true">
            <div>
                属性
            </div>
            <div>审批人:张三</div>
        </div>
    </div>
</template>
<script src="./js/home.js"></script>
<style scoped>
    .main {
        height: 100%;
    }

    #view {
        height: 100%;
        width: 100%;
        border: 1px solid;
    }

    .attr{
        position: fixed;
        left: 50%;
        bottom: 30px;
        background-color: blue;
        color: white;
    }
</style>
```
md
```js
import LogicFlow from '@logicflow/core';
import "@logicflow/core/dist/style/index.css";
import {
    Control,
    Menu,
    DndPanel,
    BpmnElement,
    BpmnAdapter,
    BpmnXmlAdapter,
    SelectionSelect,
    lfXml2Json,
    lfJson2Xml
} from '@logicflow/extension';
import '@logicflow/extension/lib/style/index.css';
import {
    GatewayNodeFactory
} from '@logicflow/extension'

import jsonData from './data.js'
export default{
    data(){
        return {
            showAttr: false,
            selObj: null
        }
    },
    mounted(){
        this.init();
    },
    methods:{
        init(){
            const complexIcon = 'm 23,13 0,7.116788321167883 -5.018248175182482,-5.018248175182482 -3.102189781021898,3.102189781021898 5.018248175182482,5.018248175182482 -7.116788321167883,0 0,4.37956204379562 7.116788321167883,0  -5.018248175182482,5.018248175182482 l 3.102189781021898,3.102189781021898 5.018248175182482,-5.018248175182482 0,7.116788321167883 4.37956204379562,0 0,-7.116788321167883 5.018248175182482,5.018248175182482 3.102189781021898,-3.102189781021898 -5.018248175182482,-5.018248175182482 7.116788321167883,0 0,-4.37956204379562 -7.116788321167883,0 5.018248175182482,-5.018248175182482 -3.102189781021898,-3.102189781021898 -5.018248175182482,5.018248175182482 0,-7.116788321167883 -4.37956204379562,0 z'
            const parallelGateway = GatewayNodeFactory('bpmn:parallelGateway', complexIcon)
            const lf = new LogicFlow({
                container: document.getElementById("view"),
                grid: true,
                plugins: [Control, Menu, DndPanel, SelectionSelect,BpmnElement]
            });
            lf.register(parallelGateway)
            lf.extension.dndPanel.setPatternItems([{
                    label: '选区',
                    icon: '',
                    callback: () => {
                        lf.extension.selectionSelect.openSelectionSelect();
                        lf.once('selection:selected', () => {
                            lf.extension.selectionSelect.closeSelectionSelect();
                        });
                    }
                },
                {
                    type: 'bpmn:startEvent',
                    text: '开始',
                    label: '开始节点',
                    icon: '',
                },
                {
                    type: 'bpmn:userTask',
                    label: '用户任务',
                    icon: '',
                    className: 'important-node'
                },
                {
                    type: 'bpmn:serviceTask',
                    label: '系统任务',
                    icon: '',
                    className: 'import_icon'
                },
                {
                    type: 'bpmn:exclusiveGateway',
                    label: '排他网关',
                    icon: '',
                }, {
                    type: 'bpmn:parallelGateway',
                    label: '并行网关',
                    icon: '',
                },
                {
                    type: 'bpmn:endEvent',
                    text: '结束',
                    label: '结束节点',
                    icon: '',
                },{
                    type: 'circle',
                    text: '导出',
                    label: '导出',
                    icon: '',
                    callback:() =>{
                        console.log(lf.getGraphData());
                    }
                }
            ]);
            lf.on("node:click,edge:click", (data) => {
                this.selObj = data;
                this.showAttr = true;
            });
            lf.on("blank:click", (data) => {
                this.showAttr = false;
            });
            console.log(jsonData.data);
            lf.render(jsonData.data);
            document.addEventListener("keydown",function(e){
                if(e.keyCode == 46){
                    lf.deleteNode(selObj.data.id)
                    lf.deleteEdge(selObj.data.id)
                }
            })
        }
    }
}
```

More

Check out the documentation for the full list of markdown extensions.