1.通过上一节的操作,能够知道流程启动以后会同一时候生成一个流程实例和用户任务。这个用户任务保存在act_ru_task和act_hi_task表中,从表明能够看出ru是runtime,hi是history。可是须要注意的是,和操作流程使用的service不同。操作正在发生任务不是使用runtimeService,而是专门的taskService。

2.后台业务代码,

  (1)自己定义的任务实体类

[java] view
plain
 copy

  1. package model;
  2. import java.util.Date;
  3. public class TaskModel {
  4. private String id;
  5. private String name;
  6. private String processInstanceId;
  7. private String assignee;
  8. private Date createTime;
  9. private String nextPerson;
  10. private String cause;
  11. private String content;
  12. private String taskType;
  13. private String processKey;
  14. private String processDefId;
  15. public String getTaskType() {
  16. return taskType;
  17. }
  18. public void setTaskType(String taskType) {
  19. this.taskType = taskType;
  20. }
  21. public String getId() {
  22. return id;
  23. }
  24. public void setId(String id) {
  25. this.id = id;
  26. }
  27. public String getName() {
  28. return name;
  29. }
  30. public void setName(String name) {
  31. this.name = name;
  32. }
  33. public String getProcessInstanceId() {
  34. return processInstanceId;
  35. }
  36. public void setProcessInstanceId(String processInstanceId) {
  37. this.processInstanceId = processInstanceId;
  38. }
  39. public String getAssignee() {
  40. return assignee;
  41. }
  42. public void setAssignee(String assignee) {
  43. this.assignee = assignee;
  44. }
  45. public Date getCreateTime() {
  46. return createTime;
  47. }
  48. public void setCreateTime(Date createTime) {
  49. this.createTime = createTime;
  50. }
  51. public String getNextPerson() {
  52. return nextPerson;
  53. }
  54. public void setNextPerson(String nextPerson) {
  55. this.nextPerson = nextPerson;
  56. }
  57. public String getCause() {
  58. return cause;
  59. }
  60. public void setCause(String cause) {
  61. this.cause = cause;
  62. }
  63. public String getContent() {
  64. return content;
  65. }
  66. public void setContent(String content) {
  67. this.content = content;
  68. }
  69. public String getProcessKey() {
  70. return processKey;
  71. }
  72. public void setProcessKey(String processKey) {
  73. this.processKey = processKey;
  74. }
  75. public String getProcessDefId() {
  76. return processDefId;
  77. }
  78. public void setProcessDefId(String processDefId) {
  79. this.processDefId = processDefId;
  80. }
  81. @Override
  82. public String toString() {
  83. return "TaskModel [id=" + id + ", name=" + name
  84. + ", processInstanceId=" + processInstanceId + ", assignee="
  85. + assignee + ", createTime=" + createTime + ", nextPerson="
  86. + nextPerson + ", cause=" + cause + ", content=" + content
  87. + ", taskType=" + taskType + ", processKey=" + processKey
  88. + ", processDefId=" + processDefId + "]";
  89. }
  90. }

(2)业务逻辑:查询任务使用taskService调用相关的方法来完毕,能够依据特定的条件,也能够不加条件查询全部。能够返回task为元素的list。也能够返回单独的task对象,可是须要注意的是,假设要返回单独的task对象。则必须确定返回值是唯一的对象,否则就会抛出异常。下边的样例中。我是依据当前登陆的username来查询出相应的全部task:

[java] view
plain
 copy

  1. /**
  2. * @throws XMLStreamException
  3. *             查询个人任务
  4. *
  5. * @author:tuzongxun
  6. * @Title: findTask
  7. * @param @return
  8. * @return Object
  9. * @date Mar 17, 2016 2:44:11 PM
  10. * @throws
  11. */
  12. @RequestMapping(value = "/findTask.do", method = RequestMethod.POST, produces = "application/json;charset=utf-8")
  13. @ResponseBody
  14. public Object findTask(HttpServletRequest req) throws XMLStreamException {
  15. Map<String, Object> map = new HashMap<String, Object>();
  16. boolean isLogin = this.isLogin(req);
  17. if (isLogin) {
  18. List<TaskModel> taskList = new ArrayList<TaskModel>();
  19. HttpSession session = req.getSession();
  20. String assginee = (String) session.getAttribute("userName");
  21. List<Task> taskList1 = taskService.createTaskQuery()
  22. .taskAssignee(assginee).list();
  23. if (taskList1 != null && taskList1.size() > 0) {
  24. for (Task task : taskList1) {
  25. TaskModel taskModel = new TaskModel();
  26. taskModel.setAssignee(task.getAssignee());
  27. taskModel.setCreateTime(task.getCreateTime());
  28. taskModel.setId(task.getId());
  29. taskModel.setName(task.getName());
  30. taskModel.setProcessInstanceId(task.getProcessInstanceId());
  31. taskModel.setProcessDefId(task.getProcessDefinitionId());
  32. // 获取流程变量
  33. Map<String, Object> variables = runtimeService
  34. .getVariables(task.getProcessInstanceId());
  35. Set<String> keysSet = variables.keySet();
  36. Iterator<String> keySet = keysSet.iterator();
  37. while (keySet.hasNext()) {
  38. String key = keySet.next();
  39. if (key.endsWith("cause")) {
  40. taskModel.setCause((String) variables.get("cause"));
  41. } else if (key.endsWith("content")) {
  42. taskModel.setContent((String) variables
  43. .get("content"));
  44. } else if (key.endsWith("taskType")) {
  45. taskModel.setTaskType((String) variables
  46. .get("taskType"));
  47. } else if (!assginee.equals(variables.get(key))) {
  48. // 想办法查询是否还有下一个任务节点
  49. Iterator<FlowElement> iterator = this.findFlow(task
  50. .getProcessDefinitionId());
  51. while (iterator.hasNext()) {
  52. FlowElement flowElement = iterator.next();
  53. String classNames = flowElement.getClass()
  54. .getSimpleName();
  55. if (classNames.equals("UserTask")) {
  56. UserTask userTask = (UserTask) flowElement;
  57. String assginee11 = userTask.getAssignee();
  58. String assginee12 = assginee11.substring(
  59. assginee11.indexOf("{") + 1,
  60. assginee11.indexOf("}"));
  61. String assignee13 = (String) variables
  62. .get(assginee12);
  63. if (assginee.equals(assignee13)) {
  64. // 看下下一个节点是什么
  65. iterator.next();
  66. FlowElement flowElement2 = iterator
  67. .next();
  68. String classNames1 = flowElement2
  69. .getClass().getSimpleName();
  70. // 设置下一个任务人
  71. if (!(classNames1.equals("EndEvent"))) {
  72. UserTask userTask2 = (UserTask) flowElement2;
  73. String assginee21 = userTask2
  74. .getAssignee();
  75. String assginee22 = assginee21
  76. .substring(
  77. assginee21
  78. .indexOf("{") + 1,
  79. assginee21
  80. .indexOf("}"));
  81. String assignee23 = (String) variables
  82. .get(assginee22);
  83. taskModel.setNextPerson(ToolUtils
  84. .isEmpty(assignee23));
  85. }
  86. }
  87. }
  88. }
  89. // //////////
  90. }
  91. }
  92. taskList.add(taskModel);
  93. }
  94. }
  95. map.put("isLogin", "yes");
  96. map.put("userName",
  97. (String) req.getSession().getAttribute("userName"));
  98. map.put("result", "success");
  99. map.put("data", taskList);
  100. } else {
  101. map.put("isLogin", "no");
  102. }
  103. return map;
  104. }

3.angular js前台代码(前台仅仅是做简单的展示,不多讲):

  (1)app.js中配置路由:

[javascript] view
plain
 copy

  1. $stateProvider
  2. .state('taskList', {
  3. url: "/taskList",
  4. views: {
  5. 'view': {
  6. templateUrl: 'activi_views/taskList.html',
  7. controller: 'taskCtr'
  8. }
  9. }
  10. });

(2)逻辑相关代码:

[javascript] view
plain
 copy

  1. angular.module('activitiApp')
  2. .controller('taskCtr', ['$rootScope','$scope','$http','$location','$state', function($rootScope,$scope,$http,$location,$state){
  3. $scope.init=function(){
  4. $http.post("./findTask.do").success(function(result) {
  5. if(result.isLogin==="yes"){
  6. console.log(result.data);
  7. $rootScope.userName=result.userName;
  8. $scope.taskList=result.data;
  9. }else{
  10. $location.path("/login");
  11. }
  12. });
  13. }
  14. $scope.completeTaskTo=function(task){
  15. console.log(task);
  16. $rootScope.task=task;
  17. //$location.path("/completeTaskTo");
  18. $location.path("/completeTaskTo1");
  19. }
  20. }])

4.相应的填写相关信息的页面:

[html] view
plain
 copy

  1. <div id="logdiv1" ng-init="init();">
  2. <p style="font-size:22px;margin-top:10px">当前任务列表</p>
  3. <center>
  4. <table border="1px" style="width:87%;font-size:14px;text-align:center;margin-top:1px;margin-left:2px;position:relative;float:left;" cellSpacing="0px" cellPadding="0px">
  5. <tr style="background-color:#ccc">
  6. <td>类型</td>
  7. <td>ID</td>
  8. <td>NAME</td>
  9. <td>ProcessIntanceId</td>
  10. <td>ProcessDefId</td>
  11. <td>创建时间</td>
  12. <td>申请人</td>
  13. <td>受理人</td>
  14. <td>申请原因</td>
  15. <td>申请内容
posted @ 2017-08-05 18:32 yxysuanfa 阅读(...) 评论(...) 编辑 收藏

activiti自己定义流程之Spring整合activiti-modeler实例(七):任务列表展示的更多相关文章

  1. activiti自己定义流程之Spring整合activiti-modeler5.16实例(四):部署流程定义

    注:(1)环境搭建:activiti自己定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建         (2)创建流程模型:activiti自己定义流程之Spr ...

  2. activiti自己定义流程之Spring整合activiti-modeler实例(一):环境搭建

    项目中须要整合activiti-modeler自己定义流程,找了非常多资料后,最终成功的跳转到activiti-modeler流程设计界面.下面是记录: 一.整合基础:eclipse4.4.1.tom ...

  3. activiti自己定义流程之Spring整合activiti-modeler实例(六):启动流程

    1.启动流程并分配任务是单个流程的正式開始,因此要使用到runtimeService接口.以及相关的启动流程的方法.我习惯于用流程定义的key启动,由于有多个版本号的流程定义时,用key启动默认会使用 ...

  4. activiti自定义流程之Spring整合activiti-modeler5.16实例(五):流程定义列表

    注:(1)环境搭建:activiti自定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建        (2)创建流程模型:activiti自定义流程之Spring ...

  5. activiti自定义流程之Spring整合activiti-modeler5.16实例(四):部署流程定义

    注:(1)环境搭建:activiti自定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建        (2)创建流程模型:activiti自定义流程之Spring ...

  6. activiti自定义流程之Spring整合activiti-modeler5.16实例(九):历史任务查询

    注:(1)环境搭建:activiti自定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建        (2)创建流程模型:activiti自定义流程之Spring ...

  7. activiti自定义流程之Spring整合activiti-modeler5.16实例(八):完成个人任务

    注:(1)环境搭建:activiti自定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建        (2)创建流程模型:activiti自定义流程之Spring ...

  8. activiti自定义流程之Spring整合activiti-modeler5.16实例(七):任务列表展示

    注:(1)环境搭建:activiti自定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建        (2)创建流程模型:activiti自定义流程之Spring ...

  9. activiti自定义流程之Spring整合activiti-modeler5.16实例(六):启动流程

    注:(1)环境搭建:activiti自定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建        (2)创建流程模型:activiti自定义流程之Spring ...

随机推荐

  1. [转载]C++内存管理

    [导语] 内存管理是C++最令人切齿痛恨的问题,也是C++最有争议的问题,C++高手从中获得了更好的性能,更大的自由,C++菜鸟的收获则是一遍一遍的检查代码和对C++的痛恨,但内存管理在C++中无处不 ...

  2. bzoj 1415 无环期望

    #include <cstdio> #include <vector> #include <queue> #include <algorithm> #d ...

  3. PHP -- 页面传值的6种获取方法

    1.PHP4以后获取传值的方法 一般在页面中传值常见的是POST.GET和COOKIE几种,所以下面我也主要介绍这几种.PHP4以后都采用的是$_POST.$_GET等数组来获取网页传值.在PHP3. ...

  4. 《python学习手册》第32章 异常基础

    发生异常与默认的异常处理   当发生异常的时候,我们代码没有刻意捕获这个异常,所以它会一直向上返回到程序顶层,并启用默认的异常处理器:打印标准出错信息.而且会终止程序.   执行下面程序 def fu ...

  5. miniSpartan6, another Spartan 6 Kit

    http://thehardwarer.com/2013/05/minispartan-6-another-spartan-6-kit/ miniSpartan6 is an Opens Source ...

  6. zookeeper疑难杂症

    1.zookeeper是怎么写数据的?因为是master写再同步广播到follow节点,如果master写完,following在写的过程中出现失败怎么办? :zookeeper支持原子的写入操作,要 ...

  7. nginx实现openfire负载均衡

    Nginx版本必须是1.9以上,不然不支持tcp连接,要么加入其他插件 在nginx.conf文件中加入下图中的代码,图中的ip与端口配成自己的,配置好后,客户端请求listen监听的端口,ip为ng ...

  8. Android开发project师,前行路上的14项技能

    导读: 你是否曾渴望回到宋朝? 或者什么朝,反正就是男耕女织的古代. 哦,那时的首都在汴梁(开封),房价想必没有如今这么高,工作?无非就是给你把锄头,去,种地去.夕阳西下了,麦子垛后,你和翠姑搂抱在一 ...

  9. [翻译] TSActivityIndicatorView 自定义指示器

    TSActivityIndicatorView 自定义指示器 https://github.com/tomkowz/TSActivityIndicatorView TSActivityIndicato ...

  10. FFmpeg YUV2RGB

    AVFrame* YUV2RGB( AVCodecContext * avctx, AVFrame * frame ) { AVFrame* pFrameRGB=NULL; pFrameRGB=avc ...