mirror of
https://gitee.com/ccnetcore/Yi
synced 2026-04-03 23:56:37 +08:00
feat:新增pure-admin前端
This commit is contained in:
240
Yi.Pure.Vue3/src/views/flow-chart/dataTurbo.json
Normal file
240
Yi.Pure.Vue3/src/views/flow-chart/dataTurbo.json
Normal file
@@ -0,0 +1,240 @@
|
||||
{
|
||||
"flowElementList": [
|
||||
{
|
||||
"incoming": [],
|
||||
"outgoing": ["Flow_33inf2k"],
|
||||
"dockers": [],
|
||||
"type": 2,
|
||||
"properties": {
|
||||
"a": "efrwe",
|
||||
"b": "wewe",
|
||||
"name": "开始",
|
||||
"x": 280,
|
||||
"y": 200,
|
||||
"text": {
|
||||
"x": 280,
|
||||
"y": 200,
|
||||
"value": "开始"
|
||||
},
|
||||
"logicFlowType": "bpmn:startEvent"
|
||||
},
|
||||
"key": "Event_1d42u4p"
|
||||
},
|
||||
{
|
||||
"incoming": ["Flow_379e0o9"],
|
||||
"outgoing": [],
|
||||
"dockers": [],
|
||||
"type": 3,
|
||||
"properties": {
|
||||
"a": "efrwe",
|
||||
"b": "wewe",
|
||||
"name": "结束",
|
||||
"x": 920,
|
||||
"y": 200,
|
||||
"text": {
|
||||
"x": 920,
|
||||
"y": 200,
|
||||
"value": "结束"
|
||||
},
|
||||
"logicFlowType": "bpmn:endEvent"
|
||||
},
|
||||
"key": "Event_08p8i6q"
|
||||
},
|
||||
{
|
||||
"incoming": ["Flow_0pfouf0"],
|
||||
"outgoing": ["Flow_3918lhh"],
|
||||
"dockers": [],
|
||||
"type": 6,
|
||||
"properties": {
|
||||
"a": "efrwe",
|
||||
"b": "wewe",
|
||||
"name": "网关",
|
||||
"x": 580,
|
||||
"y": 200,
|
||||
"text": {
|
||||
"x": 580,
|
||||
"y": 200,
|
||||
"value": "网关"
|
||||
},
|
||||
"logicFlowType": "bpmn:exclusiveGateway"
|
||||
},
|
||||
"key": "Gateway_1fngqgj"
|
||||
},
|
||||
{
|
||||
"incoming": ["Flow_33inf2k"],
|
||||
"outgoing": ["Flow_0pfouf0"],
|
||||
"dockers": [],
|
||||
"type": 4,
|
||||
"properties": {
|
||||
"a": "efrwe",
|
||||
"b": "wewe",
|
||||
"name": "用户",
|
||||
"x": 420,
|
||||
"y": 200,
|
||||
"text": {
|
||||
"x": 420,
|
||||
"y": 200,
|
||||
"value": "用户"
|
||||
},
|
||||
"logicFlowType": "bpmn:userTask"
|
||||
},
|
||||
"key": "Activity_2mgtaia"
|
||||
},
|
||||
{
|
||||
"incoming": ["Flow_3918lhh"],
|
||||
"outgoing": ["Flow_379e0o9"],
|
||||
"dockers": [],
|
||||
"type": 5,
|
||||
"properties": {
|
||||
"a": "efrwe",
|
||||
"b": "wewe",
|
||||
"name": "服务",
|
||||
"x": 760,
|
||||
"y": 200,
|
||||
"text": {
|
||||
"x": 760,
|
||||
"y": 200,
|
||||
"value": "服务"
|
||||
},
|
||||
"logicFlowType": "bpmn:serviceTask"
|
||||
},
|
||||
"key": "Activity_1sp8qc8"
|
||||
},
|
||||
{
|
||||
"incoming": ["Event_1d42u4p"],
|
||||
"outgoing": ["Activity_2mgtaia"],
|
||||
"type": 1,
|
||||
"dockers": [],
|
||||
"properties": {
|
||||
"name": "边",
|
||||
"text": {
|
||||
"x": 331,
|
||||
"y": 200,
|
||||
"value": "边"
|
||||
},
|
||||
"startPoint": {
|
||||
"x": 298,
|
||||
"y": 200
|
||||
},
|
||||
"endPoint": {
|
||||
"x": 370,
|
||||
"y": 200
|
||||
},
|
||||
"pointsList": [
|
||||
{
|
||||
"x": 298,
|
||||
"y": 200
|
||||
},
|
||||
{
|
||||
"x": 370,
|
||||
"y": 200
|
||||
}
|
||||
],
|
||||
"logicFlowType": "bpmn:sequenceFlow"
|
||||
},
|
||||
"key": "Flow_33inf2k"
|
||||
},
|
||||
{
|
||||
"incoming": ["Activity_2mgtaia"],
|
||||
"outgoing": ["Gateway_1fngqgj"],
|
||||
"type": 1,
|
||||
"dockers": [],
|
||||
"properties": {
|
||||
"name": "边2",
|
||||
"text": {
|
||||
"x": 507,
|
||||
"y": 200,
|
||||
"value": "边2"
|
||||
},
|
||||
"startPoint": {
|
||||
"x": 470,
|
||||
"y": 200
|
||||
},
|
||||
"endPoint": {
|
||||
"x": 555,
|
||||
"y": 200
|
||||
},
|
||||
"pointsList": [
|
||||
{
|
||||
"x": 470,
|
||||
"y": 200
|
||||
},
|
||||
{
|
||||
"x": 555,
|
||||
"y": 200
|
||||
}
|
||||
],
|
||||
"logicFlowType": "bpmn:sequenceFlow"
|
||||
},
|
||||
"key": "Flow_0pfouf0"
|
||||
},
|
||||
{
|
||||
"incoming": ["Gateway_1fngqgj"],
|
||||
"outgoing": ["Activity_1sp8qc8"],
|
||||
"type": 1,
|
||||
"dockers": [],
|
||||
"properties": {
|
||||
"name": "边3",
|
||||
"text": {
|
||||
"x": 664,
|
||||
"y": 200,
|
||||
"value": "边3"
|
||||
},
|
||||
"startPoint": {
|
||||
"x": 605,
|
||||
"y": 200
|
||||
},
|
||||
"endPoint": {
|
||||
"x": 710,
|
||||
"y": 200
|
||||
},
|
||||
"pointsList": [
|
||||
{
|
||||
"x": 605,
|
||||
"y": 200
|
||||
},
|
||||
{
|
||||
"x": 710,
|
||||
"y": 200
|
||||
}
|
||||
],
|
||||
"logicFlowType": "bpmn:sequenceFlow"
|
||||
},
|
||||
"key": "Flow_3918lhh"
|
||||
},
|
||||
{
|
||||
"incoming": ["Activity_1sp8qc8"],
|
||||
"outgoing": ["Event_08p8i6q"],
|
||||
"type": 1,
|
||||
"dockers": [],
|
||||
"properties": {
|
||||
"name": "边4",
|
||||
"text": {
|
||||
"x": 871,
|
||||
"y": 200,
|
||||
"value": "边4"
|
||||
},
|
||||
"startPoint": {
|
||||
"x": 810,
|
||||
"y": 200
|
||||
},
|
||||
"endPoint": {
|
||||
"x": 902,
|
||||
"y": 200
|
||||
},
|
||||
"pointsList": [
|
||||
{
|
||||
"x": 810,
|
||||
"y": 200
|
||||
},
|
||||
{
|
||||
"x": 902,
|
||||
"y": 200
|
||||
}
|
||||
],
|
||||
"logicFlowType": "bpmn:sequenceFlow"
|
||||
},
|
||||
"key": "Flow_379e0o9"
|
||||
}
|
||||
]
|
||||
}
|
||||
168
Yi.Pure.Vue3/src/views/flow-chart/index.vue
Normal file
168
Yi.Pure.Vue3/src/views/flow-chart/index.vue
Normal file
@@ -0,0 +1,168 @@
|
||||
<script setup lang="ts">
|
||||
import demoData from "./dataTurbo.json";
|
||||
import "@logicflow/core/dist/style/index.css";
|
||||
import "@logicflow/extension/lib/style/index.css";
|
||||
|
||||
import LogicFlow from "@logicflow/core";
|
||||
import { ref, unref, onMounted } from "vue";
|
||||
import { BpmnNode } from "@/components/ReFlowChart/src/config";
|
||||
import { Snapshot, BpmnElement, Menu } from "@logicflow/extension";
|
||||
import { Control, NodePanel, DataDialog } from "@/components/ReFlowChart";
|
||||
import { toLogicflowData } from "@/components/ReFlowChart/src/adpterForTurbo";
|
||||
|
||||
defineOptions({
|
||||
name: "FlowChart"
|
||||
});
|
||||
|
||||
const lf = ref(null);
|
||||
const graphData = ref(null);
|
||||
const dataVisible = ref<boolean>(false);
|
||||
const config = ref({
|
||||
grid: true,
|
||||
background: {
|
||||
color: "#f7f9ff"
|
||||
},
|
||||
keyboard: {
|
||||
enabled: true
|
||||
}
|
||||
});
|
||||
const nodeList = BpmnNode;
|
||||
|
||||
function initLf() {
|
||||
// 画布配置
|
||||
LogicFlow.use(Snapshot);
|
||||
// 使用bpmn插件,引入bpmn元素,这些元素可以在turbo中转换后使用
|
||||
LogicFlow.use(BpmnElement);
|
||||
// 启动右键菜单
|
||||
LogicFlow.use(Menu);
|
||||
const domLf = new LogicFlow({
|
||||
...unref(config),
|
||||
container: document.querySelector("#turbo")
|
||||
});
|
||||
lf.value = domLf;
|
||||
// 设置边类型bpmn:sequenceFlow为默认类型
|
||||
unref(lf).setDefaultEdgeType("bpmn:sequenceFlow");
|
||||
onRender();
|
||||
}
|
||||
|
||||
function onRender() {
|
||||
// Turbo数据转换为LogicFlow内部识别的数据结构
|
||||
const lFData = toLogicflowData(demoData);
|
||||
lf.value.render(lFData);
|
||||
}
|
||||
|
||||
function catData() {
|
||||
graphData.value = unref(lf).getGraphData();
|
||||
dataVisible.value = true;
|
||||
}
|
||||
|
||||
onMounted(() => {
|
||||
initLf();
|
||||
});
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<el-card shadow="never">
|
||||
<template #header>
|
||||
<div class="card-header">
|
||||
<span class="font-medium">
|
||||
流程图组件,采用开源的
|
||||
<el-link
|
||||
href="https://site.logic-flow.cn/docs/#/zh/guide/start"
|
||||
target="_blank"
|
||||
style="margin: 0 4px 5px; font-size: 16px"
|
||||
>
|
||||
LogicFlow
|
||||
</el-link>
|
||||
</span>
|
||||
</div>
|
||||
<el-link
|
||||
class="mt-2"
|
||||
href="https://github.com/pure-admin/vue-pure-admin/blob/main/src/views/flow-chart"
|
||||
target="_blank"
|
||||
>
|
||||
代码位置 src/views/flow-chart
|
||||
</el-link>
|
||||
</template>
|
||||
<div class="logic-flow-view">
|
||||
<!-- 辅助工具栏 -->
|
||||
<Control
|
||||
v-if="lf"
|
||||
class="demo-control"
|
||||
:lf="lf"
|
||||
:catTurboData="false"
|
||||
@catData="catData"
|
||||
/>
|
||||
<!-- 节点面板 -->
|
||||
<NodePanel v-if="lf" :lf="lf" :nodeList="nodeList" />
|
||||
<!-- 画布 -->
|
||||
<div id="turbo" />
|
||||
<!-- 数据查看面板 -->
|
||||
<el-dialog
|
||||
v-model="dataVisible"
|
||||
class="flow-dialog"
|
||||
title="数据"
|
||||
width="50%"
|
||||
>
|
||||
<el-scrollbar>
|
||||
<DataDialog :graphData="graphData" />
|
||||
</el-scrollbar>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</el-card>
|
||||
</template>
|
||||
|
||||
<style scoped>
|
||||
#turbo {
|
||||
width: 100%;
|
||||
height: 65vh;
|
||||
}
|
||||
|
||||
.logic-flow-view {
|
||||
position: relative;
|
||||
margin: 10px;
|
||||
}
|
||||
|
||||
.demo-title {
|
||||
margin: 20px;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.demo-control {
|
||||
position: absolute;
|
||||
top: 10px;
|
||||
right: 20px;
|
||||
z-index: 2;
|
||||
}
|
||||
|
||||
.time-plus {
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.add-panel {
|
||||
position: absolute;
|
||||
z-index: 11;
|
||||
padding: 10px 5px;
|
||||
background-color: white;
|
||||
}
|
||||
|
||||
.el-drawer__body {
|
||||
z-index: 3;
|
||||
height: 80%;
|
||||
margin-top: -30px;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
:deep(.flow-dialog) {
|
||||
position: relative;
|
||||
top: 5vh;
|
||||
left: 0;
|
||||
margin: 0 auto;
|
||||
transform: none;
|
||||
}
|
||||
|
||||
:deep(.flow-dialog) .el-dialog__body {
|
||||
height: 85vh;
|
||||
overflow: auto;
|
||||
}
|
||||
</style>
|
||||
Reference in New Issue
Block a user