darge组件使用并用来判断连接管道条数

本文介绍了如何在Vue项目中使用darge组件,并详细说明了如何利用该组件来判断连接管道的数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

darge组件使用并用来判断连接管道条数

1、引用

import dagre from 'dagre'
      // 通过叶子节点数判断画布是完整的一条/多条管道,如果不是完整管道则无法保存
      if (streamInAssembly && actionInAssembly && allElementsConnected) {
        // if (this.flowGraph.getLeafNodes().length === 1 || this.flowGraph.getLeafNodes().length > 1) {
        //   onlyOnePipelineCreated = true
        // } else {
        //   onlyOnePipelineCreated = false
        // }
        onlyOnePipelineCreated = this.onlyOnePipelineCreated(rawPipelineModel)
      }
      return streamInAssembly && actionInAssembly && allElementsConnected && onlyOnePipelineCreated
    },
 onlyOnePipelineCreated(rawPipelineModel) {
      const g = this.makeGraph(rawPipelineModel)
      const tarjan = dagre.graphlib.alg.tarjan(g)
      console.log(tarjan, 5555555555555555555555555555555555555)
      return tarjan.length === 1
    },
    makeGraph(rawPipelineModel) {
      var g = new dagre.graphlib.Graph()
      g.setGraph({ rankdir: 'LR' })
      g.setDefaultEdgeLabel(function() {
        return {}
      })
      // 获取所有节点的id
      rawPipelineModel.forEach((item) => {
        if (item.shape === 'flow-chart-rect' || item.shape === 'flow-chart-rect1' || item.shape === 'flow-chart-rect2') {
          const currentPipelineElement = item.attrs.pipelineElement.payload
          g.setNode(item.id, {
            label: item.id,
            type: currentPipelineElement.type,
            name: currentPipelineElement.name
          })
        } if (item.shape === 'edge') {
          // 获取所有线连接的起点和终点的id
          g.setEdge(item.source.cell, item.target.cell)
          g.setEdge(item.target.cell, item.source.cell)
        }
      })
      return g
    },
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值