工作流配置完成
This commit is contained in:
		
							
								
								
									
										103
									
								
								packages/extra/AppWorkflowManage/AiWorkflow.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								packages/extra/AppWorkflowManage/AiWorkflow.vue
									
									
									
									
									
										Normal 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> | ||||
		Reference in New Issue
	
	Block a user