Odoo10.0中的工作流
Odoo10.0中可以通过两种方式来实现工作流(workflow)
一种的官网API中给出的方式,链接:https://www.odoo.com/documentation/10.0/reference/workflows.html
还有一种是通过查看Odoo10.0的源码,发现自带模块中使用的方式;
先来说下第一种方式:
首先,创建文件目录:

接下来编写model及XML文件:
model文件:
# -*- coding: utf-8 -*- from odoo import models, fields, api class WorkflowDemo(models.Model):
_name = 'workflow_demo.leave'
_description = u'工作流请假测试' name = fields.Char(u'请假说明')
start_date = fields.Datetime(u'开始时间')
end_date = fields.Datetime(u'结束时间') state = fields.Selection(
[
('init', u'初始'),
('start', u'开始'),
('confirm', u'确认'),
('complete', u'完成'),
],
default='init',
string=u'状态',
copy=False,
readonly=True,
) @api.one
def do_start(self):
print '-' * 40
print 'do_start'
self.state = 'start' @api.one
def do_confirm(self):
print '-' * 40
print 'do_confirm'
self.state = 'confirm' @api.one
def do_complete(self):
print '-' * 40
print 'do_complete'
self.state = 'complete'
view.xml文件:
<odoo>
<data>
<record model="ir.ui.view" id="workflow_demo.list">
<field name="name">workflow_demo list</field>
<field name="model">workflow_demo.leave</field>
<field name="arch" type="xml">
<tree>
<field name="name"/>
<field name="start_date"/>
<field name="end_date"/>
<field name="state"/>
</tree>
</field>
</record> <record model="ir.ui.view" id="workflow_demo.form">
<field name="name">workflow_demo form</field>
<field name="model">workflow_demo.leave</field>
<field name="arch" type="xml">
<form string="请假单">
<header>
<button name="leave_start" states="init" string="开始" groups="workflow_demo.workflow_leave_group_employee" type="workflow" class="oe_highlight"/>
<button name="leave_confirm" states="start" string="确认" groups="workflow_demo.workflow_leave_group_manager" type="workflow" class="oe_highlight"/>
<button name="leave_complete" states="confirm" string="完成" groups="workflow_demo.workflow_leave_group_leader" type="workflow" class="oe_highlight"/> <field name="state" widget="statusbar" statusbar_visible="start,confirm,complete"/>
</header>
<group>
<field name="name"/>
<field name="start_date"/>
<field name="end_date"/>
</group>
</form>
</field>
</record> <record model="ir.actions.act_window" id="workflow_demo.action_window">
<field name="name">workflow_demo window</field>
<field name="res_model">workflow_demo.leave</field>
<field name="view_mode">tree,form</field>
<field name="help" type="html">
<p class="oe_view_nocontent_create">创建请假单</p>
</field>
</record> <!-- Top menu item -->
<menuitem name="workflow_demo" id="workflow_demo.menu_root"/> <!-- menu categories -->
<menuitem name="Menu 1" id="workflow_demo.menu_1" parent="workflow_demo.menu_root"/> <!-- actions -->
<menuitem name="List" id="workflow_demo.menu_1_list" parent="workflow_demo.menu_1"
action="workflow_demo.action_window"/> </data>
</odoo>
leave_security.xml文件:
<?xml version="1.0" encoding="utf-8" ?>
<odoo>
<!--
noupdate
0,升级模块时更新数据
1,只在安装时创建数据,开发时可设置为0,定版后改回1
-->
<data noupdate="0">
<record id="model_workflow_leave_category" model="ir.module.category">
<field name="name">请假管理</field>
</record> <record id="workflow_leave_group_employee" model="res.groups">
<field name="name">团队成员</field>
<field name="category_id" ref="model_workflow_leave_category"/>
<field name="implied_ids" eval="[(4, ref('base.group_user'))]"/>
<field name="comment">团队成员</field>
</record>
<record id="workflow_leave_group_manager" model="res.groups">
<field name="name">项目经理</field>
<field name="category_id" ref="model_workflow_leave_category"/>
<field name="implied_ids" eval="[(4, ref('workflow_demo.workflow_leave_group_employee'))]"/>
<field name="comment">项目经理</field>
</record>
<record id="workflow_leave_group_leader" model="res.groups">
<field name="name">领导</field>
<field name="category_id" ref="model_workflow_leave_category"/>
<field name="implied_ids" eval="[(4, ref('workflow_demo.workflow_leave_group_manager'))]"/>
<field name="users" eval="[(4, ref('base.user_root'))]"/>
<field name="comment"></field>
</record>
</data>
</odoo>
ir.model.access.csv文件:
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_workflow_demo_workflow_demo,workflow_demo.leave,model_workflow_demo_leave,workflow_leave_group_leader,1,1,1,0
access_workflow_demo_workflow_demo,workflow_demo.leave,model_workflow_demo_leave,workflow_leave_group_manager,1,1,1,1
access_workflow_demo_workflow_demo,workflow_demo.leave,model_workflow_demo_leave,workflow_leave_group_employee,1,1,1,1
leave_workflow.xml文件:
<odoo>
<data>
<!-- 设置record为系统自带的workflow -->
<record model="workflow" id="workflow_leave">
<field name="name">workflow_demo</field>
<!-- 关联model -->
<field name="osv">workflow_demo.leave</field>
<!-- 是否主动被实例化 -->
<field name="on_create">True</field>
</record> <!-- workflow.activity 用来指定要调用的model里的方法, 一般用来更改state的状态 -->
<!--<record model="workflow.activity" id="activity_start">-->
<!--<!– wkf_id 指定上面生命的workflow –>-->
<!--<field name="wkf_id" ref="workflow_leave" />-->
<!--<field name="name">workflow_demo.leave start</field>-->
<!--<!– dummy 类型用来指定这个activity是workflow的开始还是结束 –>-->
<!--<field name="kind">dummy</field>-->
<!--<!– flow_start:开始, flow_end:结束 –>-->
<!--<field name="flow_start">True</field>-->
<!--</record>--> <record model="workflow.activity" id="activity_do_start">
<field name="wkf_id" ref="workflow_leave" />
<field name="name">workflow_demo.leave do start</field>
<field name="flow_start">True</field>
<!-- function 表示要执行model中的方法 -->
<field name="kind">function</field>
<!-- 对应model中的方法 -->
<field name="action">do_start()</field>
</record> <record model="workflow.activity" id="activity_do_confirm">
<field name="wkf_id" ref="workflow_leave" />
<field name="name">workflow_demo.leave do confirm</field>
<!-- function 表示要执行model中的方法 -->
<field name="kind">function</field>
<!-- 对应model中的方法 -->
<field name="action">do_confirm()</field>
</record> <record model="workflow.activity" id="activity_do_complete">
<field name="wkf_id" ref="workflow_leave" />
<field name="name">workflow_demo.leave do complete</field>
<field name="flow_end">True</field>
<!-- function 表示要执行model中的方法 -->
<field name="kind">function</field>
<!-- 对应model中的方法 -->
<field name="action">do_complete()</field>
</record> <!--<record model="workflow.activity" id="activity_end">-->
<!--<field name="wkf_id" ref="workflow_leave" />-->
<!--<field name="name">workflow_demo.leave end</field>-->
<!--<field name="kind">dummy</field>-->
<!--<field name="flow_end">True</field>-->
<!--</record>--> <!-- Transitions control how the workflow progresses from activity to activity. -->
<!-- Transitions 来控制activity的走向 -->
<record model="workflow.transition" id="transition_one">
<field name="act_from" ref="activity_start" />
<field name="act_to" ref="activity_do_start" />
<field name="condition">state == 'init'</field>
<field name="signal">leave_start</field>
</record> <record model="workflow.transition" id="transition_two">
<field name="act_from" ref="activity_do_start" />
<field name="act_to" ref="activity_do_confirm" />
<field name="condition">state == 'start'</field>
<field name="signal">leave_confirm</field>
</record> <record model="workflow.transition" id="transition_three">
<field name="act_from" ref="activity_do_confirm" />
<field name="act_to" ref="activity_do_complete" />
<field name="condition">state == 'confirm'</field>
<field name="signal">leave_complete</field>
</record> </data>
</odoo>
__mainfest__.py文件:
# -*- coding: utf-8 -*-
{
'name': "工作流Demo",
'summary': """
工作流测试
""",
'description': """
Long description of module's purpose
""",
'author': "ed",
'website': "http://www.yourcompany.com",
'category': 'Uncategorized',
'version': '0.1',
'application': True,
# any module necessary for this one to work correctly
'depends': ['base'],
'sequence': 10,
# always loaded
'data': [
'security/leave_security.xml',
'security/ir.model.access.csv',
'views/leave_workflow.xml',
'views/views.xml',
],
# only loaded in demonstration mode
'demo': [
],
}
使用这种方式定义workflow,FromView中有两处需要注意:
1.button中的name属性对应workflow.transition中的signal;
2.button的type属性必须设置为workflow,否则会报错;
接下来第二种方式定义workflow,这种方式相比较第一种方式,要简单一些
原理是直接在button中调用model中定义的方法来修改state的状态,但是此处button的type属性需要定义为object
具体如下:
__mainfest__.py文件中注释掉该行
# 'views/leave_workflow.xml',
view.xml中需要将header中的button坐下调整:
<header>
<button name="do_start" states="init" string="开始" groups="workflow_demo.workflow_leave_group_employee" type="object" class="oe_highlight"/>
<button name="do_confirm" states="start" string="确认" groups="workflow_demo.workflow_leave_group_manager" type="object" class="oe_highlight"/>
<button name="do_complete" states="confirm" string="完成" groups="workflow_demo.workflow_leave_group_leader" type="object" class="oe_highlight"/> <field name="state" widget="statusbar" statusbar_visible="start,confirm,complete"/>
</header>
其中name属性为model中的方法,type属性修改为object,其他不用修改。
以上两种方式我自己都本地验证过,是没有问题的,有疑问的伙伴可以留言
大家共同学习,共同进步
Odoo10.0中的工作流的更多相关文章
- odoo-10.0 create database 失败
在初始化数据库的界面点击[create database] create database 失败 报错如下 2017-01-05 20:15:18,529 4652 INFO ? werkzeug: ...
- 通过配置文件启动odoo-10.0
odoo-10.0文件夹中找到odoo-bin,这是10.0的启动文件,也是一个py文件 使用pycharm启动后,找到run->edit configuration 找到odoo-bin 找到 ...
- odoo10.0在odoo12.0环境的基础上搭建环境
在前边的文章中,讲述了如何搭建12.0的环境,现由业务的需要需要在此基础上搭建基于python2.7的10.0版本. 第一步,安装python2.7 sudo apt- 第二步,安装python-de ...
- [译] C# 5.0 中的 Async 和 Await (整理中...)
C# 5.0 中的 Async 和 Await [博主]反骨仔 [本文]http://www.cnblogs.com/liqingwen/p/6069062.html 伴随着 .NET 4.5 和 V ...
- Spring.Net在Mvc4.0中应用的说明
案例Demo:http://yunpan.cn/cJ5aZrm7Uybi3 访问密码 414b Spring.Net在Mvc4.0中应用的说明 1.引用dll 2.修改Global文件 (Spring ...
- WCF学习之旅—WCF4.0中的简化配置功能(十五)
六 WCF4.0中的简化配置功能 WCF4.0为了简化服务配置,提供了默认的终结点.绑定和服务行为.也就是说,在开发WCF服务程序的时候,即使我们不提供显示的 服务终结点,WCF框架也能为我们的服务提 ...
- 看看C# 6.0中那些语法糖都干了些什么(终结篇)
终于写到终结篇了,整个人像在梦游一样,说完这一篇我得继续写我的js系列啦. 一:带索引的对象初始化器 还是按照江湖老规矩,先扒开看看到底是个什么玩意. 1 static void Main(strin ...
- 看看C# 6.0中那些语法糖都干了些什么(中篇)
接着上篇继续扯,其实语法糖也不是什么坏事,第一个就是吃不吃随你,第二个就是最好要知道这些糖在底层都做了些什么,不过有一点 叫眼见为实,这样才能安心的使用,一口气上五楼,不费劲. 一:字符串嵌入值 我想 ...
- FineUI(开源版)v6.0中FState服务器端验证的实现原理
前言 1. FineUI(开源版)是完整开源,最早发起于 2008-04,下载全部源代码:http://fineui.codeplex.com/ 2. 你可以通过捐赠作者来支持FineUI(开源版)的 ...
随机推荐
- java web应用启动报错:Several ports (8080, 8009) required by Tomcat v6.0 Server at localhost are already in use.
Several ports (8080, 8009) required by Tomcat v6.0 Server at localhost are already in use. The serve ...
- Nginx安装与运行配置总结
Nginx安装与运行配置总结 1. 去官网下载对应的nginx包,推荐使用稳定版本 2. 上传nginx到linux系统 3. 安装依赖环境 (1)安装gcc环境 yun install gcc-c+ ...
- vue跳转页面问题记录
跳转到别的页面带参数 const space = this.pageHelperspace['search'] = this.searchconst query_params = Object.ass ...
- 【趣味设计模式系列】之【代理模式2--JDK动态代理源码解析】
1. 图解 上图主要描述了JDK动态代理的执行过程,下面做详细分析. 2. Proxy源码分析 上一篇,在使用JDK动态代理的时候,借助于Proxy类,使用newProxyInstance静态方法,创 ...
- Mybatis-02-CRUD及配置解析
CRUD 1.namespace namespace中的包名要和Dao/Mapper接口的包名一致! 2.select 选择,查询语句; id:对应的namespace中的方法名 resultType ...
- Python 使用BrowserMob Proxy + selenium 获取Ajax加密数据
BrowserMob Proxy,简称 BMP,它是一个 HTTP 代理服务,我们可以利用它截获 HTTP 请求和响应内容. 第一步:先安装 BrowserMob Proxy 的包. pip inst ...
- 什么是BFC?看这一篇就够了
BFC 定义 BFC(Block formatting context)直译为"块级格式化上下文".它是一个独立的渲染区域,只有Block-level box参与, 它规定了内部的 ...
- JavaScript正则、错误处理、操作表单
一.正则表达式:用单个字符串描述或者匹配符合特定语句规则的字符串 一些字符序列组合在一起,可以简单也可以复杂模式的,可以去搜索,可以去替换 二.语法: /表达式/修饰符(可选) var para=/i ...
- SparkStreaming支持的业务场景
目前而言SparkStreaming 主要支持以下三种业务场景: ➢ 无状态操作:只关注当前的DStream中的实时数据.例如:只对当前DStream中的数据做正确性校验.(下一条与上一条数据无关) ...
- Kubernetes 编写自定义 controller
原文链接:Kubernetes编写自定义controller 来自kubernetes官方github的一张图: 如图所示,图中的组件分为client-go和custom controller两部分: ...