注:(1)环境搭建:activiti自定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建
        (2)创建流程模型:activiti自定义流程之Spring整合activiti-modeler5.16实例(二):创建流程模型
        (3)流程模型列表展示:activiti自定义流程之Spring整合activiti-modeler5.16实例(三):流程模型列表展示
        (4)部署流程定义:activiti自定义流程之Spring整合activiti-modeler5.16实例(四):部署流程定义

1.流程定义依旧属于流程资源,因此查询流程定义也还是使用repositoryService进行操作

2.后台业务代码,
  (1)自定义的流程定义实体类:

  1. package model;
  2. public class processModel {
  3. private String id;
  4. private String deploymentId;
  5. private String key;
  6. private String resourceName;
  7. private int version;
  8. private String name;
  9. private String diagramResourceName;
  10. public String getName() {
  11. return name;
  12. }
  13. public void setName(String name) {
  14. this.name = name;
  15. }
  16. public String getDiagramResourceName() {
  17. return diagramResourceName;
  18. }
  19. public void setDiagramResourceName(String diagramResourceName) {
  20. this.diagramResourceName = diagramResourceName;
  21. }
  22. public String getId() {
  23. return id;
  24. }
  25. public void setId(String id) {
  26. this.id = id;
  27. }
  28. public String getDeploymentId() {
  29. return deploymentId;
  30. }
  31. public void setDeploymentId(String deploymentId) {
  32. this.deploymentId = deploymentId;
  33. }
  34. public String getKey() {
  35. return key;
  36. }
  37. public void setKey(String key) {
  38. this.key = key;
  39. }
  40. public String getResourceName() {
  41. return resourceName;
  42. }
  43. public void setResourceName(String resourceName) {
  44. this.resourceName = resourceName;
  45. }
  46. public int getVersion() {
  47. return version;
  48. }
  49. public void setVersion(int version) {
  50. this.version = version;
  51. }
  52. @Override
  53. public String toString() {
  54. return "processModel [id=" + id + ", deploymentId=" + deploymentId
  55. + ", key=" + key + ", resourceName=" + resourceName
  56. + ", version=" + version + ", name=" + name
  57. + ", diagramResourceName=" + diagramResourceName + "]";
  58. }
  59. }

(2)业务逻辑:

  1. /**
  2. * 流程定义列表
  3. *
  4. * @author:tuzongxun
  5. * @Title: processList
  6. * @param @return
  7. * @return Object
  8. * @date Mar 17, 2016 12:34:10 PM
  9. * @throws
  10. */
  11. @RequestMapping(value = "/processList.do", method = RequestMethod.POST, produces = "application/json;charset=utf-8")
  12. @ResponseBody
  13. public Object processList(HttpServletRequest req) {
  14. Map<String, Object> map = new HashMap<String, Object>();
  15. boolean isLogin = this.isLogin(req);
  16. if (isLogin) {
  17. List<processModel> processList = new ArrayList<processModel>();
  18. List<ProcessDefinition> processList1 = repositoryService
  19. .createProcessDefinitionQuery().list();
  20. for (ProcessDefinition pro : processList1) {
  21. processModel processModel = new processModel();
  22. processModel.setDeploymentId(pro.getDeploymentId());
  23. processModel.setId(pro.getId());
  24. processModel.setKey(pro.getKey());
  25. processModel.setResourceName(pro.getResourceName());
  26. processModel.setVersion(pro.getVersion());
  27. processModel.setName(pro.getName());
  28. processModel.setDiagramResourceName(pro
  29. .getDiagramResourceName());
  30. processList.add(processModel);
  31. }
  32. map.put("isLogin", "yes");
  33. map.put("userName",
  34. (String) req.getSession().getAttribute("userName"));
  35. map.put("result", "success");
  36. map.put("data", processList);
  37. } else {
  38. map.put("isLogin", "no");
  39. }
  40. return map;
  41. }

3.angular js前台代码,:
  (1)app.js中配置路由:

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

(2)逻辑相关代码:

  1. angular.module('activitiApp')
  2. .controller('processCtr', ['$rootScope','$scope','$http','$location', function($rootScope,$scope,$http,$location){
  3. $scope.init=function(){
  4. $http.post("./processList.do").success(function(result) {
  5. if(result.isLogin==="yes"){
  6. console.log(result.data);
  7. $rootScope.userName=result.userName;
  8. $scope.processList=result.data;
  9. }else{
  10. $location.path("/login");
  11. }
  12. });
  13. }
  14. //这个方法主要是为下一节,启动流程实例时使用
  15. $scope.toProcess=function(process){
  16. console.log(process);
  17. $http.post("./startProcess.do",process).success(function(deployResult){
  18. $rootScope.process=process;
  19. $location.path("/startProcess");
  20. });
  21. }
  22. }])

4.对应的流程定义列表的页面:

  1. <div id="logdiv1" ng-init="init();">
  2. <p style="font-size:24px;margin-top:10px">模型列表</p>
  3. <center>
  4. <table border="1px" style="width:87%;font-size:18px;text-align:center;margin-left:2px;margin-top:auto;position:relative;float:left;" cellSpacing="0px" cellPadding="0px">
  5. <tr style="background-color:#ccc">
  6. <td>ID</td>
  7. <td>NAME</td>
  8. <td>KEY</td>
  9. <td>描 述</td>
  10. <td>版本</td>
  11. <td>创建时间</td>
  12. <td>修改时间</td>
  13. <td>操 作</td>
  14. </tr>
  15. <tr ng-repeat="model in modelList | orderBy:'id'" >
  16. <td>{{model.id}}</td>
  17. <td>{{model.name}}</td>
  18. <td>{{model.key}}</td>
  19. <td>{{model.metaInfo}}</td>
  20. <td>{{model.version}}</td>
  21. <td>{{model.createTime | date:"yyyy-MM-dd HH:mm:ss"}}</td>
  22. <td>{{model.lastUpdateTime | date:"yyyy-MM-dd HH:mm:ss"}}</td>
  23. <td><a href="script:;" ng-click="deploye(model)">部署</a>
  24. <a href="script:;" ng-click="delete(model)">删除</a>
  25. <a href="script:;" ng-click="update(model.id)">修改</a>
  26. </td>
  27. </tr>
  28. </table>
  29. </center>
  30. </div>

5.页面示图如下:

 
0

activiti自定义流程之Spring整合activiti-modeler5.16实例(五):流程定义列表的更多相关文章

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

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

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

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

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

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

  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实例(一):环境搭建 1.maven导包,这里就没有什么多的好说了,直接代码: <depe ...

  8. activiti自定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建

    项目中需要整合activiti-modeler自定义流程,找了很多资料后,终于成功的跳转到activiti-modeler流程设计界面,以下是记录: 一.整合基础:eclipse4.4.1.tomca ...

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

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

随机推荐

  1. sublime text3 本地化

    博客園中搜到n篇 同題日誌 沒一篇靠譜 超級反感這種行為,浪費別人的時間無異於謀財害命 自動: Control+` (注意不是cmd+p) import urllib.request,os,hashl ...

  2. zboot/xtract.c

    /* *  linux/zBoot/xtract.c * *  Copyright (C) 1993  Hannu Savolainen * *    Extracts the system imag ...

  3. Codeforces Round #135 (Div. 2)

    A. k-String 统计每个字母出现次数即可. B. Special Offer! Super Price 999 Bourles! 枚举末尾有几个9,注意不要爆掉\(long\ long\)的范 ...

  4. GRANT ALL PRIVILEGES 限制某个或所有客户端都可以连接至mysql

    GRANT ALL PRIVILEGES 1. 改表法.可能是你的帐号不允许从远程登陆,只能在localhost.这个时候只要在localhost的那台电脑,登入mysql后,更改 "mys ...

  5. 通过laravel理解IoC(控制反转)容器和DI(依赖注入)

    原文地址: http://www.insp.top/learn-laravel-container ,转载务必保留来源,谢谢了! 容器,字面上理解就是装东西的东西.常见的变量.对象属性等都可以算是容器 ...

  6. 详解LUA开发工具及其环境配置

    LUA开发工具及其环境配置是本文要介绍的内容,主要是来了解并学习lua开发工具的使用和环境的配置,第一次接触LUA的话,就跟本人一起学习吧.看我能不能忽悠到你. LUA是语言,那么一定有编写的工具.第 ...

  7. 运用@media实现网页自适应中的几个关键分辨率

    http://jingyan.baidu.com/article/6f2f55a1ab36c3b5b83e6c46.html http://www.5imoban.net/jiaocheng/div+ ...

  8. Python-描述符

    Python中包含了许多内建的语言特性,它们使得代码简洁且易于理解.这些特性包括列表/集合/字典推导式,属性(property).以及装饰器(decorator).对于大部分特性来说,这些“中级”的语 ...

  9. 伪类选择器:root的妙用

    css3的元素旋转功能非常强大,也非常吸引人,但是很多时候因为浏览器使用率的问题,我们必需要想办法兼容一些低版本的浏览器,特别是ie这朵奇葩. 想要实现元素旋转本来很简单的一个属性就能实现,那就是tr ...

  10. SVN server环境搭建

    VisualSVN server搭建: 1. 下载VisualSVN server for Windows安装包:https://www.visualsvn.com/ 2. 安装过程,基本就是下一步一 ...