美文网首页
一、工作流 Activiti7-18.动态表单数据提交

一、工作流 Activiti7-18.动态表单数据提交

作者: 那钱有着落吗 | 来源:发表于2021-04-09 09:27 被阅读0次
    image.png

    1.实战

    我们存储一个表单的实际数据,然后到接口中解析保存到数据库中,需要注意的一点是,我们要判断是否是有值的表单,如果有就使用带参数的完成任务否则就不带参数的完成任务:

     //动态表单保存
        @PostMapping(path = "/formDataSave")
        public AjaxResponse formDataSave(String taskId,String formData) {
            try {
                if(GlobalConfig.Test){
                    securityUtil.logInAs("bajie");
                }
                Task task = taskRuntime.task(taskId);
    
                UserTask userTask = (UserTask)repositoryService.getBpmnModel(task.getProcessDefinitionId())
                        .getFlowElement(task.getFormKey());
    
                if(userTask==null){
                    return AjaxResponse.ajaxData(GlobalConfig.ResponseCode.SUCCESS.getCode(),
                            GlobalConfig.ResponseCode.SUCCESS.getDesc(),"无表单数据");
                }
    
                //解析数据
                String[] formDataArr = formData.split("!_!");
    
                List<Map<String,Object>> result = new ArrayList<>();
    
                Boolean hasVariables = false;
                HashMap<String,Object> variables = new HashMap<>();
                for(String data:formDataArr){
                    String[] splitForm = data.split("-_!");
                    Map<String,Object> map = new HashMap<>();
    
                    map.put("process_def_id",task.getProcessDefinitionId());
                    map.put("process_ins_id",task.getProcessInstanceId());
                    map.put("form_key",task.getFormKey());
    
                    map.put("control_id",splitForm[0]);
                    map.put("control_value",splitForm[1]);
                    // map.put("control_param",splitForm[2]);
    
                    variables = new HashMap<>();
                    switch (splitForm[2]){
                        case "f":
                            System.out.println("空间不作为参数");
                            break;
                        case "s":
                            map.put(splitForm[0],splitForm[1]);
                            hasVariables = true;
                            break;
                        case "t":
                            SimpleDateFormat simpleDateFormat = new SimpleDateFormat("YYYY-MM-dd HH:mm");
                            map.put(splitForm[0],simpleDateFormat.parse(splitForm[1]));
                            hasVariables = true;
                            break;
                        case "b":
                            map.put(splitForm[0], BooleanUtils.toBoolean(splitForm[1]));
                            hasVariables = true;
                            break;
                        default:
                            System.out.println("空间ID:"+splitForm[0]+":"+splitForm[2]);
                    }
                    result.add(map);
                }
    
                if(hasVariables){
                    //带参数完成任务
                    taskRuntime.complete(TaskPayloadBuilder.complete().withTaskId(taskId).withVariables(variables).build());
                }else{
                    taskRuntime.complete(TaskPayloadBuilder.complete().withTaskId(taskId).build());
                }
    
                //插入数据
                jdbcTemplate.batchUpdate("INSERT INTO school.formdata (PROC_DEF_ID_, PROC_INST_ID_, FORM_KEY_, Control_ID_, Control_VALUE_) VALUES (?,?,?,?,?)",
                        new BatchPreparedStatementSetter() {
                            public void setValues(PreparedStatement ps, int i) throws SQLException {
                                ps.setString(1, String.valueOf(result.get(i).get("process_def_id")));//随机id
                                ps.setString(2, String.valueOf(result.get(i).get("process_ins_id")));
                                ps.setString(3, String.valueOf(result.get(i).get("form_key")));
                                ps.setString(4, String.valueOf(result.get(i).get("control_id")));
                                ps.setString(5, String.valueOf(result.get(i).get("control_value")));
                            }
                            public int getBatchSize() {
                                return result.size();
                            }
                        });
    
                return AjaxResponse.ajaxData(GlobalConfig.ResponseCode.SUCCESS.getCode(),
                        GlobalConfig.ResponseCode.SUCCESS.getDesc(),null);
            }catch (Exception e){
                return AjaxResponse.ajaxData(GlobalConfig.ResponseCode.ERROR.getCode(),"保存动态表单失败!",null);
            }
        }
    

    下面是我实际测试中用的数据和图:

    FormProperty-_!不是参数-_!f!_!FormProperty1-_!是参数-_!s
    
    image.png

    注意:
    在之前的帖子中说过在activiti7中全局变量,后面的不会覆盖之前的,也就是说如果有如下的流程:

    image.png

    我们请假6天就会到b,然后b觉得请假多然后就打回,这个时候用户请假的UEL表达式中的day变量改为2,则是不生效的。

    这个不生效是针对于taskService.complete方法,如果使用

    taskRuntime.complete(TaskPayloadBuilder.complete().withTaskId(taskId).withVariables(variables).build());
    

    这种方式则不会覆盖。所以在之后我们尽量使用taskRuntime来完成任务。

    2.表单历史数据填充

    image.png

    我们还会遇到这种需求,例如上图中所述,如果八戒表单1中使用了表单并且赋值了,如果在八戒表单2中也想使用怎么办?我们可以在表单字段中使用前一个的表单字段的key,那么在代码中实现,就是我们把formdata表中的数据查出来当做历史数据,然后在当前任务的表单字段中查找,如果有历史key则进行数值的替换。

    //渲染动态表单
        @GetMapping(path = "/formDataShow")
        public AjaxResponse formDataShow(String taskId) {
            try {
                if (GlobalConfig.Test) {
                    securityUtil.logInAs("bajie");
                }
                Task task = taskRuntime.task(taskId);
    
                //构建表单控件历史数据
                Map<String, String> controlMap = new HashMap<>();
                List<CommonInfo> commonInfos = jdbcTemplate.query("select Control_ID_ as id,Control_VALUE_ as value" +
                        " from formdata where PROC_INST_ID_='" + task.getProcessInstanceId() + "'", new BeanPropertyRowMapper(CommonInfo.class));
                controlMap = commonInfos.stream().collect(Collectors.toMap(CommonInfo::getId, CommonInfo::getValue));
    
    
                UserTask userTask = (UserTask) repositoryService.getBpmnModel(task.getProcessDefinitionId())
                        .getFlowElement(task.getFormKey());
    
    
                if (userTask == null) {
                    return AjaxResponse.ajaxData(GlobalConfig.ResponseCode.SUCCESS.getCode(),
                            GlobalConfig.ResponseCode.SUCCESS.getDesc(), "无表单");
                }
    
                List<Map<String, Object>> result = new ArrayList<>();
                List<FormProperty> formPropertiesList = userTask.getFormProperties();
                for (FormProperty formProperty : formPropertiesList) {
                    String[] splitForm = formProperty.getId().split("-_!");
                    Map<String, Object> map = new HashMap<>();
                    map.put("id", splitForm[0]);
                    map.put("type", splitForm[1]);
                    map.put("label", splitForm[2]);
    
                    if (splitForm[3].startsWith("FormProperty_")) {
                        if (controlMap.containsKey(splitForm[3])) {
                            map.put("defaultValue", controlMap.get(splitForm[3]));
                        } else {
                            map.put("defaultValue", "读取失败,检查"+splitForm[0]+"的配置");
                        }
                    } else {
                        map.put("defaultValue", splitForm[3]);
                    }
    
                    map.put("param", splitForm[4]);
                    result.add(map);
                }
    
    
                return AjaxResponse.ajaxData(GlobalConfig.ResponseCode.SUCCESS.getCode(),
                        GlobalConfig.ResponseCode.SUCCESS.getDesc(), result);
            } catch (Exception e) {
                return AjaxResponse.ajaxData(GlobalConfig.ResponseCode.ERROR.getCode(), "渲染动态表单失败!", null);
            }
        }
    
    

    相关文章

      网友评论

          本文标题:一、工作流 Activiti7-18.动态表单数据提交

          本文链接:https://www.haomeiwen.com/subject/ohuchltx.html