工作流配置完成

This commit is contained in:
aixianling
2022-08-10 16:58:52 +08:00
parent fbb9271966
commit c5b2b233b2
4 changed files with 319 additions and 0 deletions

View File

@@ -0,0 +1,103 @@
<template>
<section class="AiWorkflow">
<div ref="lfIns" :style="{height}"/>
</section>
</template>
<script>
export default {
name: "AiWorkflow",
model: {
prop: "config",
event: "change"
},
props: {
config: Object,
height: {default: '400px'},
readonly: Boolean
},
computed: {
dndPanel: () => [
{
type: 'bpmn:startEvent',
text: '开始',
label: '开始',
icon: '',
},
{
type: 'bpmn:userTask',
label: '流程节点',
icon: '',
className: 'important-node'
},
{
type: 'bpmn:exclusiveGateway',
label: '条件判断',
icon: '',
},
{
type: 'bpmn:endEvent',
text: '结束',
label: '结束',
icon: '',
}]
},
data() {
return {
flow: null,
configWatch: null
}
},
methods: {
loadLib() {
this.$injectCss("https://cdn.cunwuyun.cn/logicflow/index.css")
const load = url => new Promise(resolve => this.$injectLib(url, () => resolve()))
let libs = ["https://cdn.cunwuyun.cn/logicflow/logic-flow.js"]
if (!this.readonly) {
this.$injectCss("https://cdn.jsdelivr.net/npm/@logicflow/extension/lib/style/index.css")
libs = [
libs,
"https://cdn.jsdelivr.net/npm/@logicflow/extension/lib/Menu.js",
"https://cdn.jsdelivr.net/npm/@logicflow/extension/lib/DndPanel.js",
"https://cdn.jsdelivr.net/npm/@logicflow/extension/lib/BpmnElement.js"
].flat()
}
return Promise.all(libs.map(e => load(e)))
},
initFlow(count = 0) {
const {LogicFlow, Menu, DndPanel, BpmnElement} = window
if (!!LogicFlow && this.$refs.lfIns && !!Menu && !!DndPanel) {
this.flow = new LogicFlow({
container: this.$refs.lfIns,
plugins: [Menu, DndPanel, BpmnElement]
})
this.flow.extension.dndPanel.setPatternItems(this.dndPanel)
this.initValue()
this.flow.on('history:change', evt => {
this.configWatch?.()
const conf = this.$copy(evt.data?.undos || null).pop()
this.$emit("change", conf)
})
} else if (count < 10) {
setTimeout(() => this.initFlow(++count), 200)
} else console.error("logicFlow加载失败!")
},
initValue() {
this.configWatch = this.$watch('config', v => {
if (v?.nodes?.length > 0) {
this.flow?.render(v || {})
this.configWatch?.()
}
}, {immediate: true, deep: true})
}
},
mounted() {
this.$nextTick(() => this.loadLib().then(() => this.initFlow()))
}
}
</script>
<style lang="scss" scoped>
.AiWorkflow {
}
</style>

View File

@@ -0,0 +1,36 @@
<template>
<section class="AppWorkflowManage">
<component :is="currentPage" v-bind="$props"/>
</section>
</template>
<script>
import List from "./list";
import Add from "./add";
export default {
name: "AppWorkflowManage",
components: {Add, List},
label: "工作流管理",
props: {
instance: Function,
dict: Object,
permissions: Function
},
computed: {
currentPage() {
let {hash} = this.$route
return hash == "#add" ? Add : List
}
},
created() {
this.dict.load('yesOrNo')
}
}
</script>
<style lang="scss" scoped>
.AppWorkflowManage {
height: 100%;
}
</style>

View File

@@ -0,0 +1,98 @@
<template>
<section class="add">
<ai-detail>
<ai-title slot="title" :title="pageTitle" isShowBottomBorder/>
<template #content>
<el-form ref="AddForm" :model="form" size="small" label-width="120px" :rules="rules">
<ai-card title="基础设置">
<template #content>
<el-row type="flex">
<el-form-item label="流程名称" prop="name" class="fill">
<el-input v-model="form.name" placeholder="请输入流程名称" clearable/>
</el-form-item>
<el-form-item label="对应应用" prop="app" class="fill">
<el-input v-model="form.app" placeholder="请输入对应应用" clearable/>
</el-form-item>
</el-row>
</template>
</ai-card>
<ai-card title="流程设计">
<template #content>
<ai-workflow v-model="form.config"/>
</template>
</ai-card>
</el-form>
</template>
<template #footer>
<el-button @click="back">取消</el-button>
<el-button type="primary" @click="submit">提交</el-button>
</template>
</ai-detail>
</section>
</template>
<script>
import AiWorkflow from "./AiWorkflow";
export default {
name: "add",
components: {AiWorkflow},
props: {
instance: Function,
dict: Object,
permissions: Function
},
computed: {
isEdit: v => !!v.$route.query.id,
pageTitle: v => v.isEdit ? "编辑工作流管理" : "新增工作流管理"
},
data() {
return {
form: {},
rules: {
name: {required: true, message: "请输入"}, app: {required: true, message: "请输入"},
},
}
},
methods: {
getDetail() {
let {id} = this.$route.query
id && this.instance.post("/app/appworkflowmanage/queryDetailById", null, {
params: {id}
}).then(res => {
if (res?.data) {
const {config} = res.data
this.form = res.data
this.form.config = JSON.parse(config || null)
}
})
},
back() {
this.$router.push({})
},
submit() {
this.$refs.AddForm.validate(v => {
if (v) {
let {config} = this.form
config = JSON.stringify(config)
this.instance.post("/app/appworkflowmanage/addOrUpdate", {...this.form, config}).then(res => {
if (res?.code == 0) {
this.$message.success("提交成功!")
this.back()
}
})
}
})
},
},
created() {
this.getDetail()
}
}
</script>
<style lang="scss" scoped>
.add {
height: 100%;
}
</style>

View File

@@ -0,0 +1,82 @@
<template>
<section class="list">
<ai-list>
<ai-title slot="title" title="工作流管理" isShowBottomBorder/>
<template #content>
<ai-search-bar>
<template #left>
<el-button type="primary" icon="iconfont iconAdd" @click="handleAdd()">添加</el-button>
</template>
<template #right>
<el-input size="small" placeholder="搜索" v-model="search.name" clearable
@change="page.current=1,getTableData()"/>
</template>
</ai-search-bar>
<ai-table :tableData="tableData" :total="page.total" :current.sync="page.current" :size.sync="page.size"
@getList="getTableData" :col-configs="colConfigs" :dict="dict">
<el-table-column slot="options" label="操作" fixed="right" align="center" width="300">
<template slot-scope="{row}">
<el-button type="text" @click="handleAdd(row.id)">编辑</el-button><el-button type="text" @click="handleDelete(row.id)">删除</el-button>
</template>
</el-table-column>
</ai-table>
</template>
</ai-list>
</section>
</template>
<script>
export default {
name: "list",
props: {
instance: Function,
dict: Object,
permissions: Function
},
data() {
return {
search: {name: ""},
page: {current: 1, size: 10, total: 0},
tableData: [],
colConfigs: [{"prop":"name","label":"流程名称","isTable":true,"isDetail":true},{"prop":"app","label":"对应应用","isTable":true,"isDetail":true}],
}
},
methods: {
getTableData() {
this.instance.post("/app/appworkflowmanage/list", null, {
params: {...this.page, ...this.search}
}).then(res => {
if (res?.data) {
this.tableData = res.data.records
this.page.total = res.data.total
}
})
},
handleAdd(id) {
this.$router.push({hash: "#add", query: {id}})
},
handleDelete(ids) {
this.$confirm("是否要删除?").then(() => {
this.instance.post("/app/appworkflowmanage/delete", null, {
params: {ids}
}).then(res => {
if (res?.code == 0) {
this.$message.success("删除成功")
this.getTableData()
}
})
}).catch(() => 0)
}
},
created() {
this.getTableData()
}
}
</script>
<style lang="scss" scoped>
.list {
height: 100%;
}
</style>