| 
							
							
							
						 |  |  | @@ -1,116 +0,0 @@ | 
		
	
		
			
				|  |  |  |  | <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: '', | 
		
	
		
			
				|  |  |  |  |       }], | 
		
	
		
			
				|  |  |  |  |     currentNode: v => v.config?.nodes?.find(e => !!e.isSelected), | 
		
	
		
			
				|  |  |  |  |     currentModel: v => v.flow.getNodeModelById(v.currentNode.id) | 
		
	
		
			
				|  |  |  |  |   }, | 
		
	
		
			
				|  |  |  |  |   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, isSilentMode: this.readonly, | 
		
	
		
			
				|  |  |  |  |           style: { | 
		
	
		
			
				|  |  |  |  |             outline: { | 
		
	
		
			
				|  |  |  |  |               fill: 'transparent', | 
		
	
		
			
				|  |  |  |  |               stroke: '#949494', | 
		
	
		
			
				|  |  |  |  |               strokeDasharray: '3,3', | 
		
	
		
			
				|  |  |  |  |               hover: { | 
		
	
		
			
				|  |  |  |  |                 stroke: '#949494', | 
		
	
		
			
				|  |  |  |  |               }, | 
		
	
		
			
				|  |  |  |  |             }, | 
		
	
		
			
				|  |  |  |  |           } | 
		
	
		
			
				|  |  |  |  |         }) | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |         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 { | 
		
	
		
			
				|  |  |  |  |   min-height: 404px; | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  | </style> |