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