1 |
- {"remainingRequest":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!E:\\boman-framwork\\ruoyi-ui\\src\\components\\FlowChartComponent\\index.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\boman-framwork\\ruoyi-ui\\src\\components\\FlowChartComponent\\index.vue","mtime":1619607677256},{"path":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\boman-framwork\\ruoyi-ui\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

// import '../__utils__/go'
// import FlowDesinger from '../__utils__/flow-desinger';
import startNodeInfo from '@/components/startNodeInfo'
import endNodeInfo from '@/components/endNodeInfo'
import linkInfo from '@/components/linkInfo'
import ProcessNodeConfig from '@/components/ProcessNodeConfig'
import DynamicProcessNodeConfig from '@/components/DynamicProcessNodeConfig'
import ServiceNodeConfig from '@/components/ServiceNodeConfig'
// import FlowDisplay from '../__utils__/flow-display';
export default {
  components:{
    startNodeInfo, endNodeInfo, linkInfo, ProcessNodeConfig, DynamicProcessNodeConfig, ServiceNodeConfig
  },
  props:{
    editable:{  //是否可编辑
      type:Boolean,
      default:true
    },
    fresh:{
      type:Boolean,
      default:false
    },
    currentSteps:{
      type:Number,
      default:null
    },
    noFreshFlag:{
      type:Boolean,
      default:false
    },
    readOnly:{
      type:Boolean,
      default:false
    },
    data:{
      type:Object,
      default () {
        return {
            }
      }
    }
  },
  data () {
    return {
      myDesigner:null,  //画布实例
      drawerObject:{
        show:false
      },
      nodeMsg:{},  //存放节点数据
      pathMsg:{},  //存放路径数据
      rejectedNodes:[],  //驳回节点
      assignedNodes: [],  //指派节点
    }
  },
  activated () {
    if(!this.noFreshFlag){
      this.init()
    }
  },
  deactivated () { //keep-alive 组件停用时调用
    if(this.currentSteps === 1 && this.myDesigner){
      this.data.guiStyle = JSON.parse(this.myDesigner.getFlowData())
    }
  },
  methods:{
    init () {
        if(!Array.isArray(this.data.nodeMsg)){
            let nodeMsg = []
            Object.keys(this.data.nodeMsg).map(item => {
              nodeMsg.push(this.data.nodeMsg[item])
              return item
            })

            this.data.nodeMsg = nodeMsg

            let pathMsg = []
            Object.keys(this.data.pathMsg).map(item => {
              pathMsg.push(this.data.pathMsg[item])
              return item
            })
            this.data.pathMsg = pathMsg
        }

        this.dataProcessing()
        if(this.currentSteps === 1){
          // 流程图设计器
          if(!this.myDesigner){
            // this.myDesigner= new FlowDesinger('goChart',{
            //   showEditNode:this.showEditNode,  //节点双击编辑
            //   SelectionDeleted:this.SelectionDeleted,  //删除事件
            //   LinkDrawn:this.LinkDrawn,  //线的生成
            //   externalobjectsdropped:this.externalobjectsdropped,  //节点生成
            //   LinkRelinked: this.LinkRelinked  //连线修改
            // });

          }

          this.initToolbar = this.myDesigner.initToolbar('paletteDiv',this.data.moduleType)
          this.myDesigner.displayFlow(JSON.parse(JSON.stringify(this.data.guiStyle)));// 在设计面板中显示流程图
          this.data.myDisplay = this.myDesigner.diagram
        }else{
          if(this.myDisplay){
            this.myDisplay.loadFlow(JSON.parse(JSON.stringify(this.data.guiStyle)))
          }else{
            this.myDisplay = new FlowDisplay('showChart',{
              showEditNode:this.showEditNode,  //节点双击编辑
            });
            this.myDisplay.loadFlow(JSON.parse(JSON.stringify(this.data.guiStyle)))
          }

          // this.data.myDisplay = this.myDisplay.diagram

        }


    },
    compare (property) {
      return function(a,b) {
        var value1 = a[property];
        var value2 = b[property];
        return value1 - value2
      }
    },
    dataProcessing () {  //处理后端返回节点数据和路径数据
      if(this.data.nodeMsg){

        this.data.nodeMsg.forEach(item => {
          this.nodeMsg[item.key] = item
          if(item.type === 2){  //结束节点对数据排序,区分执行程序还是抄送人
            this.nodeMsg[item.key].actionConfig.sort(this.compare('handleType'))
          }
        })
        this.data.nodeMsg = this.nodeMsg
      }

      if(this.data.pathMsg){
        this.data.pathMsg.forEach(item => {
          this.pathMsg[item.key] = item
        })
        this.data.pathMsg = this.pathMsg
      }

      this.data.removePath = []
      this.data.removeNode = []

    },
    showEditNode (node) {  //双击编辑

      // node.findNodesOutOf()
      if(node.data.type === 1){
        let defaultObj = {
          conditionType: 0,
          ruleList: [],
          priority: null,
          defaultPriority: null,
          modifyId: null,
          id:null,
          triggerBt:[],
          visibleBt:[]
        }
        if(!node.data.id){
          this.nodeMsg[node.data.key] = Object.assign(defaultObj,this.nodeMsg[node.data.key])
        }

        this.drawerObject = {
          show: true,
          component: 'startNodeInfo',
          configData: this.nodeMsg[node.data.key],
          title:'开始节点配置'
        }
      }
      if(node.data.type === 2){
        let defaultObj = {
          id:null,
          manualConfig:null,
          actionConfig:[]
        }
        if(!node.data.id){
          this.nodeMsg[node.data.key] = Object.assign(defaultObj,this.nodeMsg[node.data.key])
        }
        this.drawerObject = {
          show: true,
          component: 'endNodeInfo',
          configData: this.nodeMsg[node.data.key],
          title:'结束节点配置'
        }
      }

      // 审批节点和操作节点用同一个配置界面，根据参数控制展示项
      if(node.data.category === "Approval" || node.data.category === "Operation"){
        this.rejectedNodes = []
        this.assignedNodes = []
        this.findNodesInto(node)
        this.findNodesOutOf(node)
        // 默认节点配置
        let defaultObj = {
          actServiceS:[],
          actionConfig:[],
          approvelList:[],
          backId:null,
          id:null,
          manualConfig:0,
          modifiableField:[],
          moduleId:null,
          name:'中间节点',
          nodeType:0,
          ruleList:[],
          inevitable: 1,  //节点必经
          approveCondition: 0,  //审批条件
          assignBack: 0,  //驳回操作
          whetherBack: 0, //可为驳回节点
          nodeCancle: 0,  //作废操作
          assignNext: 1, //指派流转节点
          assignNode: 1,  //节点是否是必需指派
          assignApprover: 1,  //是否动态指派操作人
          visibleBt:[],  //可见按钮
          nodeBack: 0,  //驳回按钮开关
          nodeAgree: 0, //同意按钮

        }

        if(this.data.moduleType === 0){
          defaultObj = {
            actServiceS:[],
            actionConfig:[],
            approvelList:[],
            backId:null,
            id:null,
            manualConfig:0,
            modifiableField:'',
            modifiableFieldName:'',
            moduleId:null,
            name:'审批节点',
            nodeType:0,
            ruleList:[]
          }
        }

        if(!node.data.id){
          this.nodeMsg[node.data.key] = Object.assign(defaultObj,this.nodeMsg[node.data.key])
        }
        this.drawerObject = {
          show: true,
          component: this.data.moduleType === 0?'ProcessNodeConfig':'DynamicProcessNodeConfig',
          configData: this.nodeMsg[node.data.key],
          node: node,
          title:node.data.category === "Approval"?'审批节点配置':'操作节点'
        }
      }

      // 服务节点
      if(node.data.category === 'Service'){
        let defaultObj = {
          id:null,
          actionConfig:[{
            "id":null,	    //新增不传，修改传
            "handleValue":null,	    //具体的关于请求状态，url之类的json
            "handleType":null,	//51：rest服务实现，52：消息系统
            "extraMsg":null	//相关参数
          }]
        }
        if(!node.data.id){
          this.nodeMsg[node.data.key] = Object.assign(defaultObj,this.nodeMsg[node.data.key])
        }
        this.drawerObject = {
          show: true,
          component: 'ServiceNodeConfig',
          configData: this.nodeMsg[node.data.key],
          title:'服务节点配置'
        }
      }

      if(node.data.from !== undefined){
        if(this.nodeMsg[node.data.from].category === 'Service' && this.data.moduleType === 1){
          return
        }
        // 默认连线配置
        let defaultObj = {
          endNode:null,
          moduleId:null,
          name:null,
          ruleList:[],
          sources:null,
          startNode:null,
          status:null
        }
        if(!node.data.moduleId){
          this.pathMsg[node.data.key] = Object.assign(defaultObj,this.pathMsg[node.data.key])
        }

        let tableConfig = [{
            ID: this.nodeMsg[node.data.from].nodeFormId,
            value: this.nodeMsg[node.data.from].nodeForm
          }]

        if(this.nodeMsg[node.data.from].category === 'Start'){
          tableConfig = [{
            ID: this.nodeMsg[node.data.from].businessType,
            value: this.nodeMsg[node.data.from].businessTypeName
          }]
        }

        this.drawerObject = {
          show: true,
          component: 'linkInfo',
          configData: this.pathMsg[node.data.key],
          TABLE_ID: this.data.moduleType === 1?tableConfig:this.data.businessType,
          title:'连接线配置'
        }
      }
    },
    findNodesInto (node) {  //查找父节点
      let parents = node.findNodesInto()

      if(parents.count > 0){
        node.findNodesInto().map(item => {
          this.rejectedNodes.push({
            value:item.data.key,
            label:item.data.text
          })
          this.findNodesInto(item)
        })
      }else{
        return
      }
    },
    findNodesOutOf (node) {  //查找子节点
      let childrens = node.findNodesOutOf()

      if(childrens.count > 0){
        node.findNodesOutOf().map(item => {
          if(item.data.key != -2){
            this.assignedNodes.push({
              value:item.data.key,
              label:item.data.text
            })
            this.findNodesOutOf(item)
          }

        })
      }else{
        return
      }
    },
    SelectionDeleted (node) {  //删除节点或者线

      if(node.fromPort !== undefined){  //线的删除
        delete this.pathMsg[node.key]
        if(node.id){  //已保存的线
          this.data.removePath.push(node.id)
        }
      }else{  //节点删除
        delete this.nodeMsg[node.key]
        if(node.id){
          this.data.removeNode.push({
            id:node.id,
            type:node.type
          })
        }
      }
    },
    LinkDrawn (node) {  //连线生成
      if(!this.judgeLoop()){
        this.$Modal.fcWarning({
          title:'警告',
          content:'流程图中存在回路，请重新设置!!',
          mask:true
        })

        this.data.guiStyle = JSON.parse(this.myDesigner.getFlowData())
        let linkDataArray = this.data.guiStyle.linkDataArray
        linkDataArray = linkDataArray.filter(item => {
          return item.key !== node.key
        })

        this.data.guiStyle.linkDataArray = linkDataArray
        this.init()
        // reject()
        return
      }else{
        this.pathMsg[node.key] = node
        this.pathMsg[node.key].ruleList = []
      }

    },
    LinkRelinked (node) {  //连线修改
      this.pathMsg[node.key].from = node.from
      this.pathMsg[node.key].to = node.to
      this.pathMsg[node.key].fromPort = node.fromPort
      this.pathMsg[node.key].toPort = node.toPort
    },
    judgeLoop () {  //判断是否存在闭环  true为没有闭环  false有闭环
        // 获取所有的节点
        let data = JSON.parse(this.myDesigner.getFlowData())
        const edges = data.linkDataArray?data.linkDataArray:JSON.parse(data).linkDataArray;
        const nodes = [];
        const list = {}; // 邻接表
        const queue = []; // 入度为0的节点集合
        const indegree = {};
        edges.forEach(e => {
            const { from, to } = e;
            if (!nodes.includes(from)) {
                nodes.push(from);
            }
            if (!nodes.includes(to)) {
                nodes.push(to);
            }
            addEdge(from, to);
        });
        const V = nodes.length;

        nodes.forEach(node => {
            if (!indegree[node]) indegree[node] = 0;
            if (!list[node]) list[node] = [];
        });

        function addEdge(source, target) {
            if (!list[source]) list[source] = [];
            if (!indegree[target]) indegree[target] = 0;
            list[source].push(target);
            indegree[target] += 1;
        }
        function sort() {
            Object.keys(indegree).forEach(id => {
                if (indegree[id] === 0) {
                    queue.push(id);
                }
            });
            let count = 0;
            while (queue.length) {
                ++count;
                const currentNode = queue.pop();
                const nodeTargets = list[currentNode];
                for (let i = 0; i < nodeTargets.length; i++) {
                    const target = nodeTargets[i];
                    indegree[target] -= 1;
                    if (indegree[target] === 0) {
                        queue.push(target);
                    }
                }
            }
            // false 没有输出全部顶点，有向图中有回路
            return !(count < V);
        }

        return sort();
    },
    externalobjectsdropped (node) {  //节点生成

      if(node.category === 'Service' || node.category === 'Subprocesses'){
        this.nodeMsg[node.key] = node
        this.nodeMsg[node.key].name = node.text
        return
      }
      this.nodeMsg[node.key] = node
      this.nodeMsg[node.key].ruleList = []
      this.nodeMsg[node.key].actServiceS =[
        {
          status:1,
          handleValue:null,
          handleType:11
        },
        {
          status:1,
          handleValue:null,
          handleType:20
        }
      ]
      this.nodeMsg[node.key].actionConfig =[]
      this.nodeMsg[node.key].approvelList = []
      this.nodeMsg[node.key].approverStyle = 0
      this.nodeMsg[node.key].name = node.text
    },
    closeDrawer () {  //关闭策划块
      this.drawerObject = {
        show: false
      }
    }
  }
}
"},{"version":3,"sources":["index.vue"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"index.vue","sourceRoot":"src/components/FlowChartComponent","sourcesContent":["<template>\r\n <div class=\"FlowChartComponent\">\r\n <!-- <Alert show-icon closable v-if=\"currentSteps === 1\">双击空白区域即可直接新增一个中间节点,双击节点可编辑</Alert> -->\r\n <div class=\"chartContent\">\r\n <div id=\"paletteDiv\"></div>\r\n <div id=\"goChart\" v-show=\"currentSteps === 1\">\r\n </div>\r\n <div id=\"showChart\" v-show=\"currentSteps === 2\">\r\n </div>\r\n </div>\r\n\r\n <!-- 全局侧滑模块 -->\r\n <Drawer\r\n v-model=\"drawerObject.show\"\r\n transfer\r\n :title=\"drawerObject.title\"\r\n :width=\"472\"\r\n :mask-closable=\"false\"\r\n :closable=\"false\"\r\n scrollable\r\n >\r\n <components\r\n v-if=\"drawerObject.show\"\r\n :configData=\"drawerObject.configData\"\r\n :data=\"drawerObject.configData\"\r\n :is=\"drawerObject.component\"\r\n :TABLE_ID=\"drawerObject.TABLE_ID\"\r\n :node=\"drawerObject.node\"\r\n :status=\"drawerObject.status\"\r\n :rejectedNodes=\"rejectedNodes\"\r\n :assignedNodes=\"assignedNodes\"\r\n :readOnly=\"readOnly\"\r\n :moduleType=\"data.moduleType\"\r\n @closeDrawer=\"closeDrawer\"\r\n >\r\n </components>\r\n </Drawer>\r\n </div>\r\n</template>\r\n<script>\r\n// import '../__utils__/go'\r\n// import FlowDesinger from '../__utils__/flow-desinger';\r\nimport startNodeInfo from '@/components/startNodeInfo'\r\nimport endNodeInfo from '@/components/endNodeInfo'\r\nimport linkInfo from '@/components/linkInfo'\r\nimport ProcessNodeConfig from '@/components/ProcessNodeConfig'\r\nimport DynamicProcessNodeConfig from '@/components/DynamicProcessNodeConfig'\r\nimport ServiceNodeConfig from '@/components/ServiceNodeConfig'\r\n// import FlowDisplay from '../__utils__/flow-display';\r\nexport default {\r\n components:{\r\n startNodeInfo, endNodeInfo, linkInfo, ProcessNodeConfig, DynamicProcessNodeConfig, ServiceNodeConfig\r\n },\r\n props:{\r\n editable:{ //是否可编辑\r\n type:Boolean,\r\n default:true\r\n },\r\n fresh:{\r\n type:Boolean,\r\n default:false\r\n },\r\n currentSteps:{\r\n type:Number,\r\n default:null\r\n },\r\n noFreshFlag:{\r\n type:Boolean,\r\n default:false\r\n },\r\n readOnly:{\r\n type:Boolean,\r\n default:false\r\n },\r\n data:{\r\n type:Object,\r\n default () {\r\n return {\r\n }\r\n }\r\n }\r\n },\r\n data () {\r\n return {\r\n myDesigner:null, //画布实例\r\n drawerObject:{\r\n show:false\r\n },\r\n nodeMsg:{}, //存放节点数据\r\n pathMsg:{}, //存放路径数据\r\n rejectedNodes:[], //驳回节点\r\n assignedNodes: [], //指派节点\r\n }\r\n },\r\n activated () {\r\n if(!this.noFreshFlag){\r\n this.init()\r\n }\r\n },\r\n deactivated () { //keep-alive 组件停用时调用\r\n if(this.currentSteps === 1 && this.myDesigner){\r\n this.data.guiStyle = JSON.parse(this.myDesigner.getFlowData())\r\n }\r\n },\r\n methods:{\r\n init () {\r\n if(!Array.isArray(this.data.nodeMsg)){\r\n let nodeMsg = []\r\n Object.keys(this.data.nodeMsg).map(item => {\r\n nodeMsg.push(this.data.nodeMsg[item])\r\n return item\r\n })\r\n\r\n this.data.nodeMsg = nodeMsg\r\n\r\n let pathMsg = []\r\n Object.keys(this.data.pathMsg).map(item => {\r\n pathMsg.push(this.data.pathMsg[item])\r\n return item\r\n })\r\n this.data.pathMsg = pathMsg\r\n }\r\n\r\n this.dataProcessing()\r\n if(this.currentSteps === 1){\r\n // 流程图设计器\r\n if(!this.myDesigner){\r\n // this.myDesigner= new FlowDesinger('goChart',{\r\n // showEditNode:this.showEditNode, //节点双击编辑\r\n // SelectionDeleted:this.SelectionDeleted, //删除事件\r\n // LinkDrawn:this.LinkDrawn, //线的生成\r\n // externalobjectsdropped:this.externalobjectsdropped, //节点生成\r\n // LinkRelinked: this.LinkRelinked //连线修改\r\n // });\r\n\r\n }\r\n\r\n this.initToolbar = this.myDesigner.initToolbar('paletteDiv',this.data.moduleType)\r\n this.myDesigner.displayFlow(JSON.parse(JSON.stringify(this.data.guiStyle)));// 在设计面板中显示流程图\r\n this.data.myDisplay = this.myDesigner.diagram\r\n }else{\r\n if(this.myDisplay){\r\n this.myDisplay.loadFlow(JSON.parse(JSON.stringify(this.data.guiStyle)))\r\n }else{\r\n this.myDisplay = new FlowDisplay('showChart',{\r\n showEditNode:this.showEditNode, //节点双击编辑\r\n });\r\n this.myDisplay.loadFlow(JSON.parse(JSON.stringify(this.data.guiStyle)))\r\n }\r\n\r\n // this.data.myDisplay = this.myDisplay.diagram\r\n\r\n }\r\n\r\n\r\n },\r\n compare (property) {\r\n return function(a,b) {\r\n var value1 = a[property];\r\n var value2 = b[property];\r\n return value1 - value2\r\n }\r\n },\r\n dataProcessing () { //处理后端返回节点数据和路径数据\r\n if(this.data.nodeMsg){\r\n\r\n this.data.nodeMsg.forEach(item => {\r\n this.nodeMsg[item.key] = item\r\n if(item.type === 2){ //结束节点对数据排序,区分执行程序还是抄送人\r\n this.nodeMsg[item.key].actionConfig.sort(this.compare('handleType'))\r\n }\r\n })\r\n this.data.nodeMsg = this.nodeMsg\r\n }\r\n\r\n if(this.data.pathMsg){\r\n this.data.pathMsg.forEach(item => {\r\n this.pathMsg[item.key] = item\r\n })\r\n this.data.pathMsg = this.pathMsg\r\n }\r\n\r\n this.data.removePath = []\r\n this.data.removeNode = []\r\n\r\n },\r\n showEditNode (node) { //双击编辑\r\n\r\n // node.findNodesOutOf()\r\n if(node.data.type === 1){\r\n let defaultObj = {\r\n conditionType: 0,\r\n ruleList: [],\r\n priority: null,\r\n defaultPriority: null,\r\n modifyId: null,\r\n id:null,\r\n triggerBt:[],\r\n visibleBt:[]\r\n }\r\n if(!node.data.id){\r\n this.nodeMsg[node.data.key] = Object.assign(defaultObj,this.nodeMsg[node.data.key])\r\n }\r\n\r\n this.drawerObject = {\r\n show: true,\r\n component: 'startNodeInfo',\r\n configData: this.nodeMsg[node.data.key],\r\n title:'开始节点配置'\r\n }\r\n }\r\n if(node.data.type === 2){\r\n let defaultObj = {\r\n id:null,\r\n manualConfig:null,\r\n actionConfig:[]\r\n }\r\n if(!node.data.id){\r\n this.nodeMsg[node.data.key] = Object.assign(defaultObj,this.nodeMsg[node.data.key])\r\n }\r\n this.drawerObject = {\r\n show: true,\r\n component: 'endNodeInfo',\r\n configData: this.nodeMsg[node.data.key],\r\n title:'结束节点配置'\r\n }\r\n }\r\n\r\n // 审批节点和操作节点用同一个配置界面,根据参数控制展示项\r\n if(node.data.category === \"Approval\" || node.data.category === \"Operation\"){\r\n this.rejectedNodes = []\r\n this.assignedNodes = []\r\n this.findNodesInto(node)\r\n this.findNodesOutOf(node)\r\n // 默认节点配置\r\n let defaultObj = {\r\n actServiceS:[],\r\n actionConfig:[],\r\n approvelList:[],\r\n backId:null,\r\n id:null,\r\n manualConfig:0,\r\n modifiableField:[],\r\n moduleId:null,\r\n name:'中间节点',\r\n nodeType:0,\r\n ruleList:[],\r\n inevitable: 1, //节点必经\r\n approveCondition: 0, //审批条件\r\n assignBack: 0, //驳回操作\r\n whetherBack: 0, //可为驳回节点\r\n nodeCancle: 0, //作废操作\r\n assignNext: 1, //指派流转节点\r\n assignNode: 1, //节点是否是必需指派\r\n assignApprover: 1, //是否动态指派操作人\r\n visibleBt:[], //可见按钮\r\n nodeBack: 0, //驳回按钮开关\r\n nodeAgree: 0, //同意按钮\r\n\r\n }\r\n\r\n if(this.data.moduleType === 0){\r\n defaultObj = {\r\n actServiceS:[],\r\n actionConfig:[],\r\n approvelList:[],\r\n backId:null,\r\n id:null,\r\n manualConfig:0,\r\n modifiableField:'',\r\n modifiableFieldName:'',\r\n moduleId:null,\r\n name:'审批节点',\r\n nodeType:0,\r\n ruleList:[]\r\n }\r\n }\r\n\r\n if(!node.data.id){\r\n this.nodeMsg[node.data.key] = Object.assign(defaultObj,this.nodeMsg[node.data.key])\r\n }\r\n this.drawerObject = {\r\n show: true,\r\n component: this.data.moduleType === 0?'ProcessNodeConfig':'DynamicProcessNodeConfig',\r\n configData: this.nodeMsg[node.data.key],\r\n node: node,\r\n title:node.data.category === \"Approval\"?'审批节点配置':'操作节点'\r\n }\r\n }\r\n\r\n // 服务节点\r\n if(node.data.category === 'Service'){\r\n let defaultObj = {\r\n id:null,\r\n actionConfig:[{\r\n \"id\":null,\t //新增不传,修改传\r\n \"handleValue\":null,\t //具体的关于请求状态,url之类的json\r\n \"handleType\":null,\t//51:rest服务实现,52:消息系统\r\n \"extraMsg\":null\t//相关参数\r\n }]\r\n }\r\n if(!node.data.id){\r\n this.nodeMsg[node.data.key] = Object.assign(defaultObj,this.nodeMsg[node.data.key])\r\n }\r\n this.drawerObject = {\r\n show: true,\r\n component: 'ServiceNodeConfig',\r\n configData: this.nodeMsg[node.data.key],\r\n title:'服务节点配置'\r\n }\r\n }\r\n\r\n if(node.data.from !== undefined){\r\n if(this.nodeMsg[node.data.from].category === 'Service' && this.data.moduleType === 1){\r\n return\r\n }\r\n // 默认连线配置\r\n let defaultObj = {\r\n endNode:null,\r\n moduleId:null,\r\n name:null,\r\n ruleList:[],\r\n sources:null,\r\n startNode:null,\r\n status:null\r\n }\r\n if(!node.data.moduleId){\r\n this.pathMsg[node.data.key] = Object.assign(defaultObj,this.pathMsg[node.data.key])\r\n }\r\n\r\n let tableConfig = [{\r\n ID: this.nodeMsg[node.data.from].nodeFormId,\r\n value: this.nodeMsg[node.data.from].nodeForm\r\n }]\r\n\r\n if(this.nodeMsg[node.data.from].category === 'Start'){\r\n tableConfig = [{\r\n ID: this.nodeMsg[node.data.from].businessType,\r\n value: this.nodeMsg[node.data.from].businessTypeName\r\n }]\r\n }\r\n\r\n this.drawerObject = {\r\n show: true,\r\n component: 'linkInfo',\r\n configData: this.pathMsg[node.data.key],\r\n TABLE_ID: this.data.moduleType === 1?tableConfig:this.data.businessType,\r\n title:'连接线配置'\r\n }\r\n }\r\n },\r\n findNodesInto (node) { //查找父节点\r\n let parents = node.findNodesInto()\r\n\r\n if(parents.count > 0){\r\n node.findNodesInto().map(item => {\r\n this.rejectedNodes.push({\r\n value:item.data.key,\r\n label:item.data.text\r\n })\r\n this.findNodesInto(item)\r\n })\r\n }else{\r\n return\r\n }\r\n },\r\n findNodesOutOf (node) { //查找子节点\r\n let childrens = node.findNodesOutOf()\r\n\r\n if(childrens.count > 0){\r\n node.findNodesOutOf().map(item => {\r\n if(item.data.key != -2){\r\n this.assignedNodes.push({\r\n value:item.data.key,\r\n label:item.data.text\r\n })\r\n this.findNodesOutOf(item)\r\n }\r\n\r\n })\r\n }else{\r\n return\r\n }\r\n },\r\n SelectionDeleted (node) { //删除节点或者线\r\n\r\n if(node.fromPort !== undefined){ //线的删除\r\n delete this.pathMsg[node.key]\r\n if(node.id){ //已保存的线\r\n this.data.removePath.push(node.id)\r\n }\r\n }else{ //节点删除\r\n delete this.nodeMsg[node.key]\r\n if(node.id){\r\n this.data.removeNode.push({\r\n id:node.id,\r\n type:node.type\r\n })\r\n }\r\n }\r\n },\r\n LinkDrawn (node) { //连线生成\r\n if(!this.judgeLoop()){\r\n this.$Modal.fcWarning({\r\n title:'警告',\r\n content:'流程图中存在回路,请重新设置!!',\r\n mask:true\r\n })\r\n\r\n this.data.guiStyle = JSON.parse(this.myDesigner.getFlowData())\r\n let linkDataArray = this.data.guiStyle.linkDataArray\r\n linkDataArray = linkDataArray.filter(item => {\r\n return item.key !== node.key\r\n })\r\n\r\n this.data.guiStyle.linkDataArray = linkDataArray\r\n this.init()\r\n // reject()\r\n return\r\n }else{\r\n this.pathMsg[node.key] = node\r\n this.pathMsg[node.key].ruleList = []\r\n }\r\n\r\n },\r\n LinkRelinked (node) { //连线修改\r\n this.pathMsg[node.key].from = node.from\r\n this.pathMsg[node.key].to = node.to\r\n this.pathMsg[node.key].fromPort = node.fromPort\r\n this.pathMsg[node.key].toPort = node.toPort\r\n },\r\n judgeLoop () { //判断是否存在闭环 true为没有闭环 false有闭环\r\n // 获取所有的节点\r\n let data = JSON.parse(this.myDesigner.getFlowData())\r\n const edges = data.linkDataArray?data.linkDataArray:JSON.parse(data).linkDataArray;\r\n const nodes = [];\r\n const list = {}; // 邻接表\r\n const queue = []; // 入度为0的节点集合\r\n const indegree = {};\r\n edges.forEach(e => {\r\n const { from, to } = e;\r\n if (!nodes.includes(from)) {\r\n nodes.push(from);\r\n }\r\n if (!nodes.includes(to)) {\r\n nodes.push(to);\r\n }\r\n addEdge(from, to);\r\n });\r\n const V = nodes.length;\r\n\r\n nodes.forEach(node => {\r\n if (!indegree[node]) indegree[node] = 0;\r\n if (!list[node]) list[node] = [];\r\n });\r\n\r\n function addEdge(source, target) {\r\n if (!list[source]) list[source] = [];\r\n if (!indegree[target]) indegree[target] = 0;\r\n list[source].push(target);\r\n indegree[target] += 1;\r\n }\r\n function sort() {\r\n Object.keys(indegree).forEach(id => {\r\n if (indegree[id] === 0) {\r\n queue.push(id);\r\n }\r\n });\r\n let count = 0;\r\n while (queue.length) {\r\n ++count;\r\n const currentNode = queue.pop();\r\n const nodeTargets = list[currentNode];\r\n for (let i = 0; i < nodeTargets.length; i++) {\r\n const target = nodeTargets[i];\r\n indegree[target] -= 1;\r\n if (indegree[target] === 0) {\r\n queue.push(target);\r\n }\r\n }\r\n }\r\n // false 没有输出全部顶点,有向图中有回路\r\n return !(count < V);\r\n }\r\n\r\n return sort();\r\n },\r\n externalobjectsdropped (node) { //节点生成\r\n\r\n if(node.category === 'Service' || node.category === 'Subprocesses'){\r\n this.nodeMsg[node.key] = node\r\n this.nodeMsg[node.key].name = node.text\r\n return\r\n }\r\n this.nodeMsg[node.key] = node\r\n this.nodeMsg[node.key].ruleList = []\r\n this.nodeMsg[node.key].actServiceS =[\r\n {\r\n status:1,\r\n handleValue:null,\r\n handleType:11\r\n },\r\n {\r\n status:1,\r\n handleValue:null,\r\n handleType:20\r\n }\r\n ]\r\n this.nodeMsg[node.key].actionConfig =[]\r\n this.nodeMsg[node.key].approvelList = []\r\n this.nodeMsg[node.key].approverStyle = 0\r\n this.nodeMsg[node.key].name = node.text\r\n },\r\n closeDrawer () { //关闭策划块\r\n this.drawerObject = {\r\n show: false\r\n }\r\n }\r\n }\r\n}\r\n</script>\r\n<style lang=scss\" >\r\n.FlowChartComponent{\r\n width: 100%;\r\n height: 100%;\r\n overflow: hidden;\r\n display: flex;\r\n position: relative;\r\n flex-direction: column;\r\n\r\n .burgeon-alert{\r\n margin-bottom: 0;\r\n }\r\n\r\n .chartContent{\r\n flex: 1;\r\n display: flex;\r\n }\r\n\r\n #paletteDiv{\r\n padding: 5px;\r\n width: 160px;\r\n height: 100%;\r\n display: inline-block;\r\n border-right: 1px solid #dcdee2;\r\n }\r\n\r\n\r\n canvas{\r\n outline: none;\r\n }\r\n\r\n #goChart,#showChart{\r\n flex-grow: 1;\r\n flex: 1;\r\n // border: solid 1px black\r\n }\r\n}\r\n</style>\r\n"]}]}
|