基于jeecgboot-vue3的Flowable流程仿钉钉流程设计器-支持VForm3表单的选择与支持

因为这个项目license问题无法开源,更多技术支持与服务请加入我的知识星球。

1、初始化的时候加载表单

javascript 复制代码
/** 查询表单列表 */
const getFormList = () => {
  listForm().then(res => formOptions.value = res.result.records)
}

2、开始节点的修改,增加表单选择

javascript 复制代码
<el-tab-pane label="表单选择" name="formSelect">
       <el-form size="small" label-width="90px" @submit.native.prevent>
         <el-form-item label="表单" prop="formKey">
           <el-select v-model="activeData.formKey" placeholder="请选择表单" @change="updateFormKey" clearable>
             <el-option v-for="item in formOptions" :key="item.id" :label="item.formName" :value="item.id" />
           </el-select>
         </el-form-item>
         <el-form-item prop="localScope">
           <span slot="label">
             <el-tooltip content="若为节点表单,则表单信息仅在此节点可用,默认为全局表单,表单信息在整个流程实例中可用" placement="top-start">
               <i class="header-icon el-icon-info"></i>
             </el-tooltip>
             <span>节点表单</span>
           </span>
           <el-switch disabled  v-model="activeData.localScope" active-text="是" inactive-text="否" @change="updateFormScope()" />
         </el-form-item>
       </el-form>
    </el-tab-pane>

3、选择表单的更新,后续还要传递到父组件,以便其它组件使用这些字段

javascript 复制代码
const updateFormKey = (formKey) => {
  console.log("updateFormKey formKey",formKey)
  props.activeData.formKey = formKey
  const formItem  = formOptions.value?.find((f) => f.id === formKey)
  const formContent = JSON.parse(formItem.formContent)
  props.activeData.formProperties = formContent.widgetList
  console.log("updateFormKey formProperties",props.activeData.formProperties)
}

4、相应watchEffect修改如下:

javascript 复制代码
watchEffect(() => {
  const formProperties = props.activeData.formProperties
  props.activeData.formProperties = formProperties?.map((field) => ({
    id: field.id,
    name: field.options.label,
    readonly: field.options.readonly,
    hidden: field.options.hidden,
    required: field.options.required
  }))
  props.activeData.formProperties?.forEach((item) => {
    const properties = formProperties.find((f) => f.id === item.id)
    if (properties) {
      item.readonly = properties.options.readonly
      item.hidden = properties.options.hidden
      item.required = properties.options.required
    }
  })
})

5、效果图如下:

相关推荐
申阳2 分钟前
Day 5:03. 基于Nuxt开发博客项目-页面结构组织
前端·后端·程序员
全马必破三10 分钟前
React的设计理念与核心特性
前端·react.js·前端框架
ttod_qzstudio16 分钟前
替代 TDesign Dialog:用 div 实现可拖拽、遮罩屏蔽的对话框
前端·tdesign
洞窝技术20 分钟前
前端人必看的 node_modules 瘦身秘籍:从臃肿到轻盈,Umi 项目依赖优化实战
前端·vue.js·react.js
Asort30 分钟前
React函数组件深度解析:从基础到最佳实践
前端·javascript·react.js
golang学习记31 分钟前
VS Code + Chrome DevTools MCP 实战:用 AI 助手自动分析网页性能
前端
用户40993225021233 分钟前
Vue 3中reactive函数如何通过Proxy实现响应式?使用时要避开哪些误区?
前端·ai编程·trae
Qinana38 分钟前
🌐 从 HTML/CSS/JS 到页面:浏览器渲染全流程详解
前端·程序员·前端框架
BBB努力学习程序设计40 分钟前
网页布局必备技能:手把手教你实现优雅的纵向导航
前端·html