Coder Social home page Coder Social logo

Comments (4)

boyongjiong avatar boyongjiong commented on August 27, 2024

没看懂什么意思

from logicflow.

csx-bill avatar csx-bill commented on August 27, 2024

没看懂什么意思

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

from logicflow.

DymoneLewis avatar DymoneLewis commented on August 27, 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/[email protected]/dist/index.min.js"></script>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@logicflow/[email protected]/dist/index.css" />

<!-- 引入 extension包样式 -->
<script src="https://cdn.jsdelivr.net/npm/@logicflow/[email protected]/dist/index.min.js"></script>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@logicflow/[email protected]/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>

from logicflow.

csx-bill avatar csx-bill commented on August 27, 2024

新版本已解决

from logicflow.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.