iDempiere 开发指南 Process(iDem后台进程)及插件的开发及部署

Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/
iDempiere官方中文wiki主页 http://wiki.idempiere.org/zh
iDempiere 中文社区www.idempiere.org.cn
iDempiere 中文社区QQ群 65713012

本文说明如何给iDempiere创建一个Process,包括如何定义一个插件工程,建立Process,并在系统中进行调用。

本文参考的youtube视频为:https://www.youtube.com/user/evenosconsulting/videos视频下载地址(百度网盘):http://pan.baidu.com/s/1vqLRo

Process表示一段运行的程序,他的输出可以是报表,也可以不输出任何东西。

Process可以在运行过程中对其他对象进行改变,比如销售订单界面上面的Process Order就是一个Process,他将销售订单进行了Complete或者Close操作。又比如MRP运算的process,在运行的过程中生成了采购申请。

Process 也可以用来执行一系列的检查,将结果在运行的过程中输出到文件中或者直接存入数据库。

Process可以设定成为按时、按计划运行,比如每天晚上凌晨3点做MRP运算。

该文档主要分为两个大步骤
1. 在iDempiere系统中定义Process,包括使用到的参数,调用的菜单等
2. 使用eclipse开发该Process的OSGI插件,并部署到iDempiere上

下面为开发process的详细操作

  1. 使用System账户登录系统,进入Report & Process
  2. 建立一个新的process
  3. 给该process添加几个参数,String, Boolean, Timedate



  4. 创建一个Menu,对该process进行调用
  5. 创建Menu,同时将该menu指向刚建立好的Process
  6. 保存以后,退出登录,重新以GardenAdmin用户进行登录,查看菜单,发现该功能已经显示在菜单里面了
  7. 打开该功能,已经能够正常录入参数,说明我们的Process和Menu的系统配置正常完成。下一步可以进行Process的实际开发。
  8. 开发部分,开发部分使用eclipse进行开发,具体的eclipse配置请查看前面的博客:http://www.cnblogs.com/zzyan/p/4124087.html
  9. 在eclipse中创建一个plugin project
  10. 提供一个工程名字,同时选中Target to run with "Equinox"。建议将工程建立在单独的文件夹而不是workspace文件夹,这样可以将自己的代码和系统标准代码分离开来。
  11. 选中java6,确保使用java6的用户能够正常使用
  12. 新的插件创建完成以后,打开项目文件,设置项目的Manifest文件。
    为其添加两个Dependencies:
    org.adempiere.base和org.adempiere.plugins.utils

  13. 创建对应的包以及process的java class文件,注意,包名和java class名字组合必须和process系统设置中的名字一样
  14. 更改java文件,iDempiere的process必须继承SvrProcess
    process有两个函数
    prepare() – 主要用于参数设置
    doIt() – process的主函数,进行该process的主任务
  15. 具体的process实现我们后续添加
  16. Process建立好了以后,我们需要新建一个factory类,并将其进行注册,这样我们的插件工程在启用的时候,iDempiere的OSGI服务能够通过该注册找到我们提供的service。
    新建一个package,并添加一个factory类
    在这里我建立org.zzya.factories.MyProcessFactory类
  17. Factory类必须继承IProcessFactory。
    我们同时重写其函数newProcessInstance如下
  18. 我们需要创建一个component definition,来告诉OSGI我们提供了这个服务
    注意,eclipse需要是J2EE版本的indigo,之前我的eclipse版本为java普通版本,导致没有这个wizard,请重新下载一下开发环境,eclipse文件夹名称为eclipse-jee
  19. 创建一个component definition
  20. 设置component definition的参数
    其中,service.ranking为每个plugin必须设置的一个参数

  21. 现在我们可以回去更改MyProcess的定义,执行实际的编程操作
    下面的函数中:
    getParameter为继承的函数,用于获取process调用时候传入的参数
    log为继承的对象,用于输出日志
    addLog用于输出结果到process的结果报表
  22. 编写完毕以后,我们重新启动服务,并尝试调用该process
    在运行时,在run -> run configuration中,选中该plugin,同时将auto-start设置为true
  23. 运行process,设置参数
  24. 运行结果如下
  25. 查看eclipse中的log,发现log已经正常打印,说明该process插件已经正常运行
  26. Process运行完了以后,可以在process audit中进行查看该运行的历史记录
  27. Process audit中可以看到传入的参数值,以及使用addlog输出的log信息

  28. 下面我们进行一下扩展,看一下怎样能够在报表里面打印出料号信息,同时从报表中导航到料号界面。
    更改MyProcess.java文件中的doIt(),同时添加一个getProducts函数,如下
  29. 重新运行,查看报表,发现报表结果显示了产品信息
  30. 点击超链接,可以看到界面导航到了产品product 界面

以上文档说明了怎样对idempiere系统开发及调用一个Process

时间: 2024-08-28 23:18:19

iDempiere 开发指南 Process(iDem后台进程)及插件的开发及部署的相关文章

phonegap 开发指南系列(3) ----在Eclipse中Android开发环境搭建

  前提条件:已在Eclipse中安装好Android SDK 和 ADT. 1.下载PhoneGap,解压. 2.用Eclipse新建一个安卓项目. 3.将phoneGap解压包里的Android文件夹下的phonegap-1.0.0.js 复制到安卓项目的 /assets/www/ 目录下. 4.将phoneGap解压包里的Android文件夹下的phonegap-1.0.0.jar 复制到安卓项目的 /libs 目录下. 5.在/assets/www/目录下新建一个index.html,内

开发指南专题七:JEECG微云快速开发平台查询HQL过滤器

开始学习wxWidgets,上一篇写了"安装wxWidgets遭遇的两大关卡"(简称"前文"). 先推荐一下这两天找到的学习材料. 博客中有一个系列教程,貌似作者没有写完,见<跟我学wxWidgets开发>系列教程. 要看书,就<使用wxWidgets进行跨平台程序开发>.我给的链接中,包括中书中的源码.这本书,是<Cross Platform GUI Programming With wxWidget>的中译本,译本中没有附录部

开发指南专题九 JEECG微云快速开发平台-表单校验组件ValidForm

开发指南专题九:JEECG微云快速开发平台表单校验组件ValidForm 10.表单校验组件ValidForm 10.1使用入门 1.引入css 请查看下载文件中的style.css,把里面Validform必须部分复制到你的css中(文件里这个注释 "/*==========以下部分是Validform必须的===========*/" 之后的部分是必须的).(之前发现有部分网友把整个style.css都引用在了页面里,然后发现样式冲突了) 2.引入js (jquery 1.4.2

转:Oculus Unity Development Guide开发指南(2015-7-21更新)

http://forum.exceedu.com/forum/forum.php?mod=viewthread&tid=34175 Oculus Unity Development Guide开发指南转载请保留原始地   http://t.cn/RAblKoh Oculus/GearVR开发者群 302294234 Welcometo the Unity Development GuideIntroduction简介Welcometo the Oculus Unity Developer Gui

freeMarker(八)——程序开发指南之配置(Configuration)

1.基本内容 配置(configuration)就是 freemarker.template.Configuration 对象, 它存储了常用(全局,应用程序级)的设置,定义了想要在所有模板中可用的变量(称为共享变量). 而且,它会处理 Template 实例的新建和缓存. 应用程序典型的用法是使用一个独立的共享 Configuration 实例.更精确来说, 典型的做法是每一个独立开发的组件(比如项目,模块等)都有一个 Configuration 实例,它在内部使用FreeMarker, 每一

[Phonegap+Sencha Touch] 移动开发77 Cordova Hot Code Push插件实现自己主动更新App的Web内容

原文地址:http://blog.csdn.net/lovelyelfpop/article/details/50848524 插件地址:https://github.com/nordnet/cordova-hot-code-push 以下是我对GitHub项目readme的翻译 ---------------------------------------------- Cordova Hot Code Push Plugin 此插件提供了能够使cordova app自己主动更新web内容的功

Freemaker_入门+深入+开发指南+学习笔记

freemaker的基本语法 freemaker的基本语法:<# ... > 中存放所有freemaker的内容,之外的内容全部原样输出.<@ ... /> 是函数调用两个定界符内的内容中,第一个符号表示指令或者函数名,其后的跟随参数.freemaker提供的控制包括如下: <#if condition><#elseif condition><#else></#if> 条件判断<#list hash_or_seq as var&

开发指南专题八:JEECG微云快速开发平台数据字典

   开发指南专题八:JEECG微云快速开发平台数据字典的使用 1.标签中使用数据字典 数据字典为系统中可能用到的字典类型数据提供了使用的便利性和可维护性.以下拉框标签<t:dictSelect>为例进行讲解 1.1. 标签参数 属性名 类型 描述 是否必须 默认值 typeGroupCode string 字典分组编码 是 null field string 对应表单 是 null id string 唯一标识 否 null title string 显示文本 否 null defaul

开发指南专题十:JEECG微云快速开发平台--表单校验组件ValidForm

10.4Validform对象[方法支持链式调用] 如示例 var demo=$(".formsub").Validform(),那么demo对象会有以下属性和方法可以调用: tipmsg[object] 如:demo.tipmsg.s="error! no messageinputed."; 通过该对象可以修改除 tit 以外的其他提示文字,这样可以实现同一个页面的不同表单使用不同的提示文字. 具体可修改的提示文字 $.Tipmsg={//默认提示文字; tit: