workflow钉钉审批流程设置

workflow钉钉审批流程设置,基于vue开发。QQ交换群:639251756

  • 线上开源地址 https://github.com/StavinLi/Workflow github点个星吧!
  • 预览地址 https://stavinli.github.io/Workflow/dist/index.html#/

我的项目介绍

  • UI钉钉格调
  • 技术点
  • 组件自调用+递归解决,按树状终局解决审批流程问题
  • 次要性能点
  • 界面缩放

    <div class="zoom">  <div :class="'zoom-out'+ (nowVal==50?' disabled':'')" @click="zoomSize(1)"></div>  <span>{{nowVal}}%</span>  <div :class="'zoom-in'+ (nowVal==300?' disabled':'')" @click="zoomSize(2)"></div></div>
  • 节点设置(包含审批人、发起人、抄送人、条件设置)

    <el-drawer title="审批人设置" :visible.sync="approverDrawer" direction="rtl" class="set_promoter" size="550px" :before-close="saveApprover">   <div class="demo-drawer__content">      <div class="drawer_content">          <div class="approver_content">              <el-radio-group v-model="approverConfig.settype" class="clear" @change="changeType">                  <el-radio :label="1">指定成员</el-radio>                  <el-radio :label="2">主管</el-radio>                  <el-radio :label="4">发起人自选</el-radio>                  <el-radio :label="5">发起人本人</el-radio>                  <el-radio :label="7">间断多级主管</el-radio>              </el-radio-group>              ...
  • 节点新增

    <div class="add-node-btn">  <el-popover placement="right-start" v-model="visible">        <div class="add-node-popover-body">            <a class="add-node-popover-item approver" @click="addType(1)">                <div class="item-wrapper">                    <span class="iconfont"></span>                </div>                <p>审批人</p>            </a>            <a class="add-node-popover-item notifier" @click="addType(2)">                <div class="item-wrapper">                    <span class="iconfont"></span>                </div>                <p>抄送人</p>            </a>            <a class="add-node-popover-item condition" @click="addType(4)">                <div class="item-wrapper">                    <span class="iconfont"></span>                </div>                <p>条件分支</p>            </a>        </div>        ...

    5.谬误校验

    let {type,error,nodeName,conditionNodes} = childNodeif (type == 1 || type == 2) {  if (error) {      this.tipList.push({ name: nodeName, type: ["","审核人","抄送人"][type] })  }  this.reErr(childNode)} else if (type == 3) {  this.reErr(childNode)} else if (type == 4) {  this.reErr(childNode)  for (var i = 0; i < conditionNodes.length; i++) {      if (conditionNodes[i].error) {          this.tipList.push({ name: conditionNodes[i].nodeName, type: "条件" })      }      this.reErr(conditionNodes[i])  }}

    6.含糊搜寻匹配人员、职位、角色

    <input type="text" placeholder="搜寻成员" v-model="searchVal" @input="getDebounceData($event,activeName)"><input type="text" placeholder="搜寻角色" v-model="searchVal" @input="getDebounceData($event,2)"><input type="text" placeholder="请抉择具体人员/角色/部门" v-if="conditionConfig.nodeUserList.length == 0" @click="addConditionRole">

    我的项目装置

git clone https://github.com/StavinLi/W... 点个赞吧!

我的项目运行

1.环境依赖 npm i

2.本地运行 npm run serve

3.打包运行 npm run build