Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Bug Report]: 插件换成 BpmnXmlAdapter bpmn:parallelGateway 组件没有了 #1685

Closed
csx-bill opened this issue Jul 15, 2024 · 4 comments
Closed
Labels
bug Something isn't working

Comments

@csx-bill
Copy link

发生了什么?

demo 地址: https://github.com/csx-bill/logic-flow/tree/master
问题: 插件换成 BpmnXmlAdapter bpmn:parallelGateway 组件没有了

logicflow/core版本

1.2.27

logicflow/extension版本

1.2.27

logicflow/engine版本

1.2.27

浏览器&环境

Chrome

@csx-bill csx-bill added the bug Something isn't working label Jul 15, 2024
@boyongjiong
Copy link
Collaborator

没看懂什么意思

@csx-bill
Copy link
Author

没看懂什么意思

我上面有案例,我使用的html 页面引入的js 实现的,浏览器可直接打开index.html 拖拽并行网关组件,其他组件是正常的
image

@csx-bill csx-bill changed the title [Bug Report]: [Bug Report]: 插件换成 BpmnXmlAdapter bpmn:parallelGateway 组件没有了 Jul 17, 2024
@DymoneLewis
Copy link
Collaborator

DymoneLewis commented Jul 22, 2024

看了一下,目前1.x版本的cdn里没有导出BPMNElements相关的内容,可以升到我们最新的2.0.beta.4这里导出了完整的内容,不过我们在2.0版本优化了CDN包的打包逻辑,在引入的时候写法上需要调整一下,具体可以参考下面这段根据你的demo改写的逻辑
(Tip: 在写法上一个不同点是引入CDN时只能整体引入,取方法/插件时需要增加前缀(如下文中new LogicFlow需要写成new Core.LogicFlow, plugins传入的插件需要写成Extension.插件名

<title>flow-ui</title>
<!-- 引入 core包 -->
<script src="https://cdn.jsdelivr.net/npm/@logicflow/core@2.0.0-beta.4/dist/index.min.js"></script>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@logicflow/core@2.0.0-beta.4/dist/index.css" />

<!-- 引入 extension包样式 -->
<script src="https://cdn.jsdelivr.net/npm/@logicflow/extension@2.0.0-beta.4/dist/index.min.js"></script>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@logicflow/extension@2.0.0-beta.4/dist/index.css" />

<style>
  #container {
    width: 1000px;
    height: 500px
  }
</style>
<style>
.drawer {
  position: fixed;
  top: 0;
  right: -100%;
  width: 300px;
  height: 100%;
  background-color: #f1f1f1;
  transition: right 0.3s ease-in-out;
  padding: 20px;
  box-sizing: border-box;
  z-index: 1000;
}

.drawer.open {
  right: 0;
}

.overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 999;
  display: none;
}

.overlay.show {
  display: block;
}

.drawer-button {
  margin: 10px;
}
</style>
<div>
    <div class="overlay" onclick="closeDrawer()"></div>

    <div class="drawer" id="bpmn:startEvent">
        <div>
          start-event-drawer
        </div>
        <div>
          <div>节点编码 <input type="" name="" /> </div>
          <div>节点名称 <input type="" name="" /> </div>
          <div>监听器类型 <select> <option>任务创建</option></select> </div>
          <div>监听器路径 <textarea name=""></textarea> </div>
        </div>
    </div>
    <div class="drawer" id="bpmn:userTask">
        <div>
          user-task-drawer
        </div>
        <div>
          <div>节点编码 <input type="" name="" /> </div>
          <div>节点名称 <input type="" name="" /> </div>
          <div>协作方式 
            <input type="radio" name=""/>或签
            <input type="radio" name=""/>票签
            <input type="radio" name=""/>会签
          </div>
          <div>权限标识 <select> <option>任务创建</option></select> </div>
          <div>是否可以跳转任意节点
            <input type="radio" name=""/>否
            <input type="radio" name=""/>是
          </div>
          <div>监听器类型 <select> <option>任务创建</option></select> </div>
          <div>监听器路径 <textarea name=""></textarea> </div>
        </div>
    </div>
    <div class="drawer" id="bpmn:exclusiveGateway">
        <div>
          exclusive-gateway-drawer
        </div>
        <div>
          <div>节点编码 <input type="" name="" /> </div>
          <div>节点名称 <input type="" name="" /> </div>
        </div>
    </div>
    <div class="drawer" id="bpmn:parallelGateway">
        <div>
          parallel-gateway-drawer
        </div>
        <div>
          <div>节点编码 <input type="" name="" /> </div>
          <div>节点名称 <input type="" name="" /> </div>
        </div>
    </div>
    <div class="drawer" id="bpmn:endEvent">
        <div>
          end-event-drawer
        </div>
        <div>
          <div>节点编码 <input type="" name="" /> </div>
          <div>节点名称 <input type="" name="" /> </div>
        </div>
    </div>
    <div class="drawer" id="bpmn:sequenceFlow">
        <div>
          sequence-flow-drawer
        </div>
        <div>
          <div>跳转类型 <select> <option>审批通过</option> <option>退回</option></select> </div>
        </div>
    </div>
</div>


<script>
  window.onload = function () {
    console.log('Extension', Extension)
    InitLogicFlow();
  }

  function InitLogicFlow() {
    // LogicFlow配置选项
    const lf = new Core.LogicFlow({
      container: document.querySelector("#container"),
      grid: {
        visible: true,
        type: 'mesh',
        size: 10,
        config: {
          color: '#eeeeee'
        }
      },
      height: 500,
      hoverOutline: false,
      edgeSelectedOutline: false,
      keyboard: {
        enabled: true
      },
      plugins: [Extension.BpmnElement, Extension.BPMNElements, Extension.BpmnXmlAdapter, Extension.SelectionSelect, Extension.DndPanel, Extension.Control]
    })
    console.log('lf', lf)
    // 拖拽面板
    lf.extension.dndPanel.setPatternItems([
      {
        label: '选区',
        icon: '',
        callback: () => {
          // lf.current!.extension.selectionSelect.openSelectionSelect()
          // lf.current!.once('selection:selected', () => {
          //   lf.current!.extension.selectionSelect.closeSelectionSelect()
          // })
        }
      },
      {
        type: 'bpmn:startEvent',
        text: '开始',
        label: '开始节点',
        icon: ''
      },
      {
        type: 'bpmn:userTask',
        text: '用户任务',
        label: '用户任务',
        icon: ''
      },
      {
        type: 'bpmn:exclusiveGateway',
        text: '排他网关',
        label: '排他网关',
        icon: ''
      },
      {
        type: 'bpmn:parallelGateway',
        text: '并行网关',
        label: '并行网关',
        icon: ''
      },
      {
        type: 'bpmn:endEvent',
        text: '结束',
        label: '结束节点',
        icon: ''
      }
    ])

  // 控制面板
  lf.extension.control.addItem({
    //iconClass: 'lf-control-save',
    title: '',
    text: '保存',
    onClick: (lf, ev) => {
      console.log('getGraphData', lf.getGraphData())
    }
  })

    // 监听被点击节点
    lf.on('node:click', data => {
      console.log('data.type', data)

      openDrawer(data.data.type)

    })

    // 监听被点击节点
    lf.on('edge:click', data => {
      console.log('data.type', data)
      openDrawer(data.data.type)
    })

    lf.render({})
    // 方便调试
    window.lf = lf;


  }
</script>
<script type="text/javascript"> function openDrawer(drawerId) { const drawer = document.getElementById(drawerId); drawer.classList.add('open'); document.querySelector('.overlay').classList.add('show'); } function closeDrawer() { const drawers = document.querySelectorAll('.drawer'); drawers.forEach(drawer => { drawer.classList.remove('open'); }); document.querySelector('.overlay').classList.remove('show'); } </script>

@csx-bill
Copy link
Author

新版本已解决

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants