activiti自定义代理人、候选人、候选组选择

介绍

AdminEAP框架中集成了Activiti工作流组件,使用了activiti-explorer中的在线流程设计器,其中在选择代理人(审批人)中,原生的操作是输入数据,没有和系统自动关联。同时,原生的在线流程设计器使用AngularJs写的,而框架使用的Jquery,两者之间集成需要注意几点,避免踩坑;

效果

1、Activiti流程设计器

Activiti流程设计器

2、选择代理人、候选人、候选组

选择代理人

3、选择代理人(单选)

选择代理人

4、选择候选人(多选)

选择候选人

5、选择候选组(多选)

选择候选组

核心代码

1、修改properties-assignment-controller.js

扩展候选人和候选组对象属性

第47行:$scope.assignment.candidateUsers = [{value: '', name: ''}];
第62行:$scope.assignment.candidateGroups = [{value: '', name: ''}];
这样在界面上既可以显示用户/用户组的名称,也显示实际存储的ID值

打开选择弹窗,数据回填的核心代码

  //-----------add select User/Group button handler By billJiang--------------
    //代理人(审批人)/候选人
    $scope.selectUser = function (multiple) {
        var title = "选择代理人(单选)"
        var ids = ($scope.assignment.assignee ? $scope.assignment.assignee : 0);
        if (multiple == 1) {
            title = "选择候选人(多选)";
            //候选人id
            ids = 0;
            if($scope.assignment.candidateUsers) {
                var idsArr = [];
                //alert( $scope.assignment.candidateUsers.length);
                for (var i = 0; i < $scope.assignment.candidateUsers.length; i++) {
                    if ($scope.assignment.candidateUsers[i].value)
                        idsArr.push($scope.assignment.candidateUsers[i].value);
                }
                if (idsArr.length > 0) {
                    ids = idsArr.join(",");
                }
            }
        }
        modals.openWin({
            winId: 'userSelectWin',
            url: basePath + '/activiti/user/select/' + multiple + '/' + ids,
            width: '800px',
            title: title
        })
    };

    //候选组
    $scope.selectGroup = function () {
        var ids = 0;
        if($scope.assignment.candidateGroups) {
            var idsArr = [];
            for (var i = 0; i < $scope.assignment.candidateGroups.length; i++) {
                if ($scope.assignment.candidateGroups[i].value)
                    idsArr.push($scope.assignment.candidateGroups[i].value);
            }
            if (idsArr.length > 0) {
                ids = idsArr.join(",");
            }
        }
        modals.openWin({
            winId: 'groupSelectWin',
            url: basePath + '/activiti/group/select/' + ids,
            width: '1200px',
            title: '选择候选组(多选)'
        })
    }

    //回填受理人
    $scope.setAssignee = function (assignee, userName) {
        $scope.assignment.assignee = assignee;
        $scope.assignment.assigneeName = userName;
        //jQuery("#assigneeNameField").val(userName);
        $scope.$apply();
    };

    //回填候选人
    $scope.setCandidateUsers = function (userIds, userNames) {
        var users = null;
        if (!userIds) {
            $scope.assignment.candidateUsers = users;
        } else {
            var userIdArr = userIds.split(",");
            var userNameArr = userNames.split(",");
            users = [];
            for (var i = 0; i < userIdArr.length; i++) {
                var userObj = {};
                userObj["value"] = userIdArr[i];
                userObj["name"] = userNameArr[i];
                users.push(userObj);
            }
            $scope.assignment.candidateUsers = users;

        }
        $scope.$apply();
    };

    //回填候选组
    $scope.setCandidateGroups = function (groupIds, groupNames) {
        var groups = null;
        if (!groupIds) {
            $scope.assignment.candidateGroups = groups;
        } else {
            var groupIdArr = groupIds.split(",");
            var groupNameArr = groupNames.split(",");
            groups = [];
            for (var i = 0; i < groupIdArr.length; i++) {
                var groupObj = {};
                groupObj["value"] = groupIdArr[i];
                groupObj["name"] = groupNameArr[i];
                groups.push(groupObj);
            }
            $scope.assignment.candidateGroups = groups;
        }
        //加上这句话回填后界面立即生效
        $scope.$apply();
    };

    //--------------------------------------------------------------------------

以上代码需要注意 scope. apply(), 否则回填以后界面双向绑定不能立即生效;

代理人、候选人选择的核心代码

代理人和候选人选择器使用了同一个界面,通过multiple参数值进行区分

var userSelectTable;
    var ids = "${ids?default(0)}";//回填ids
    ids = ids == 0 ? '' : ids;
    var multiple = "${multiple?default(0)}";//默认单选
    //用户选择控制器
    var userSelectCtrl = {
        initTable: function () {
            jQuery("#userIds").val(ids);
            this.updateSelectedUserNames();
            var self = this;
            userSelectTable = new CommonTable("user_select_table", "id_user_list", "searchDiv_user_select");
            //回调选中
            userSelectTable.serverCallback = function () {
                self.setCheckBoxState();
            }
        },
        //查询 换页选择框回填
        setCheckBoxState: function () {
            var selectUserIds = jQuery("#userIds").val();
            if (selectUserIds) {
                var userIdArr = selectUserIds.split(",");
                //选中增加的用户
                jQuery.each(userIdArr, function (index, userId) {
                    if (userSelectTable.table.$("#" + userId).length > 0) {
                        userSelectTable.table.$("#" + userId).find(":checkbox.checkbox_user").prop("checked", true);
                    }
                });
                //删除已经选中的
                userSelectTable.table.$("tr").find(":checkbox.checkbox_user:checked").each(function () {
                    var curUserId = jQuery(this).parents("tr").attr("id");
                    //找不到,已经被删除
                    if (selectUserIds.indexOf(curUserId) == -1) {
                        userSelectTable.table.$("#" + curUserId).find(":checkbox.checkbox_user").prop("checked", false);
                    }
                });
            } else {
                jQuery(":checkbox.checkbox_user").prop("checked", false);
            }
        },
        //绑定用户选择事件
        bindSelectUserEvent: function () {
            jQuery("#selectUser").click(function () {
                var controllerScope = jQuery('div[ng-controller="KisBpmAssignmentPopupCtrl"]').scope();  // Get controller's scope
                var userIds = jQuery("#userIds").val();
                var userNames = jQuery("#userNames").val();
                if (multiple == 0) {
                    controllerScope.setAssignee(userIds, userNames);
                } else {
                    controllerScope.setCandidateUsers(userIds, userNames);
                }
                modals.hideWin("userSelectWin");
            })
        },
        selectThis: function (obj) {
            var isChecked = jQuery(obj).is(":checked");
            //单选
            var userIds = jQuery("#userIds").val();
            if (userIds && userIds.split(',').length == 1 && multiple == 0 && isChecked) {
                alert("只能选择一个用户");
                jQuery(obj).attr("checked", false);
                return;
            }
            var value = jQuery(obj).parents("tr").eq(0).attr("id");
            var userArr = this.getSelectedUserArr(userIds, value, isChecked);
            jQuery("#userIds").val(userArr.join(","));
            this.updateSelectedUserNames();
        },
        updateSelectedUserNames: function () {
            var userIds = jQuery("#userIds").val();
            if (userIds == 0 || !userIds) {
                jQuery("#userNames").val("");
            } else {
                ajaxPost(basePath + "/activiti/user/names", {ids: userIds}, function (map) {
                    jQuery("#userNames").val(map.name);
                });
            }
        },
        getSelectedUserArr: function (userIdss, curValue, isChecked) {
            var userArr = [];
            if (userIdss)
                userArr = userIdss.split(",");
            if (isChecked) {
                var flag = true;
                for (var i = 0; i < userArr.length; i++) {
                    if (userArr[i] == curValue) {
                        flag = false;
                        break;
                    }
                }
                if (flag)
                    userArr.push(curValue);
            } else {
                for (var i = 0; i < userArr.length; i++) {
                    var userIdValue = userArr[i];
                    if (userIdValue == curValue) {
                        userArr.splice(i, 1);
                        break;
                    }
                }
            }
            return userArr;
        }


    }


    function fnRenderSelectUser(value) {
        return "<input type='checkbox' value='1' class='checkbox_user' onchange='userSelectCtrl.selectThis(this)'>";
    }
    //方法入口
    jQuery(function () {
        userSelectCtrl.initTable();
        userSelectCtrl.bindSelectUserEvent();
    })

以上代码有三点需要特别注意
(1)使用jQuery选择器时,使用jQuery而不用 (…)未定义的异常,因为弹出的选择器窗口依然在angularJs的域中,不能识别$。
(2)数据回填时,使用controllerScope = jQuery('div[ng-controller="KisBpmAssignmentPopupCtrl"]').scope() 获取回填于对象,然后执行相关操作
(3)因为modeler.html中引用了prototype-1.5.1.js,在使用JSON.stringify时,会调用Array的toJSON方法,从而导致带有数组的JSON格式的字符串参数到后台后无法转换为相应的对象。所以使用了以下toJSONString()对JSON对象进行字符串化。

  CommonTable.prototype.toJSONString = function (value) {
        var _array_tojson = Array.prototype.toJSON;
        delete Array.prototype.toJSON;
        var r = JSON.stringify(value);
        Array.prototype.toJSON = _array_tojson;
        return r;
    }
  • 12
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 39
    评论
Activiti候选人是用于指定具有某个任务的执行权限的一用户的标识符。任务可以分配给一个或多个候选人,并且只有属于该用户才能执行该任务。这样可以实现任务的协作和分配。 要创建一个候选人,可以在流程定义文件(BPMN文件)使用`<candidate-groups>`元素来指定。例如: ```xml <userTask id="task1" name="Task 1" activiti:assignee="${assignee}"> <extensionElements> <activiti:candidateGroups> <activiti:candidateGroup>group1</activiti:candidateGroup> <activiti:candidateGroup>group2</activiti:candidateGroup> </activiti:candidateGroups> </extensionElements> </userTask> ``` 上述示例,`task1`任务会被分配给`group1`和`group2`这两个候选人。只有属于这两个用户才能执行该任务。 在运行时,可以使用Activiti的API来查询候选人候选人信息,并将任务分配给具体的候选人。例如,可以使用以下代码将任务分配给具体的用户: ```java TaskService taskService = processEngine.getTaskService(); Task task = taskService.createTaskQuery().taskCandidateGroup("group1").singleResult(); taskService.setAssignee(task.getId(), "user1"); ``` 上述代码,首先通过`taskCandidateGroup`方法查询属于`group1`候选人的任务,然后使用`setAssignee`方法将任务分配给具体的用户`user1`。 希望以上信息对你有所帮助!如果还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 39
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值