Files
dvcp_v2_webapp/packages/extra/AppWorkflowManage/AiWorkflow.vue
2022-08-10 17:41:42 +08:00

101 lines
7.0 KiB
Vue

<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", "https://cdn.jsdelivr.net/npm/@logicflow/extension/lib/BpmnElement.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"
].flat()
}
return Promise.all(libs.map(e => load(e)))
},
initFlow(count = 0) {
const {LogicFlow, Menu, DndPanel, BpmnElement} = window
let plugins = [BpmnElement, this.readonly ? [] : [Menu, DndPanel]].flat()
if (!!LogicFlow && this.$refs.lfIns && plugins.reduce((r, e) => r && !!e, true)) {
this.flow = new LogicFlow({container: this.$refs.lfIns, plugins})
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>