openerp学习笔记 视图中字段只变化(on_change)联动其他字段值、选择和过滤
1.修改产品数量时,自动计算产品销售金额、销售成本和销售利润
<field name="num" on_change="on_change_product(product, num, price)"/>
2.选择历史工单时,按销售单中当前选择的客户自动过滤,打开选择历史工单窗口时,过滤条件默认为销售单中当前选择的客户
<field name="work_order" domain="[('customer','=',customer)]" context="{'search_default_customer':customer}"/>
代码示例:
<!-- views dispatch_sale_form -->
<record model="ir.ui.view"
id="dispatch_sale_form">
<field
name="name">dispatch.sale.form</field>
<field
name="model">dispatch.sale</field>
<field name="type">form</field>
<field name="priority">2</field>
<field name="arch" type="xml">
<form
string="销售单明细"
version="7.0">
<header>
<button string="确认" name="set_to_confirmed" states="draft" type="object"
icon="gtk-yes"/>
<button string="还原为草稿" name="set_to_draft" states="confirmed" type="object"
icon="gtk-convert"
groups="kl_dispatch.group_dispatch_manager"/>
<field name="state" widget="statusbar" statusbar_visible="draft,confirmed"
statusbar_colors='{"draft":"blue"}'/>
</header>
<sheet>
<group>
<group>
<field
name="date"/>
<field
name="name"/>
<field
name="customer"/>
<field name="product" on_change="on_change_product(product, num,
price)"/>
<field name="num" on_change="on_change_product(product, num,
price)"/>
<field name="price" on_change="on_change_product(product, num,
price)"/>
<field name="cost" on_change="on_change_product(product, num, price)"
invisible="1"/>
<field name="cost_view"
invisible="0"/>
</group>
<group>
<field name="employee_id"
on_change="onchange_employee_id(employee_id)"/>
<field
name="department_id"/>
<field name="work_order" domain="[('customer','=',customer)]"
context="{'search_default_customer':customer}"/>
<field
name="klbh"/>
<field
name="sum_sale"/>
<field
name="sum_cost"/>
<field
name="sum_profit"/>
</group>
</group>
<group>
<field name="note"
colspan="4"/>
</group>
</sheet>
</form>
</field>
</record>
#职员修改自动更改部门
def onchange_employee_id(self, cr, uid, ids,
employee_id,
context=None):
department_id = False
if
employee_id:
emp_obj =
self.pool.get('hr.employee')
employee = emp_obj.browse(cr, uid, employee_id,
context=context)
department_id =
employee.department_id.id
return
{'value': {'department_id': department_id}}
#产品、数量、单价、成本更改,自动计算销售金额、成本金额、利润金额
def
on_change_product(self,cr,uid,ids,product_id, num,
price):
v={}
if
product_id:
product=self.pool.get("dispatch.product").browse(cr,uid,product_id)
v["cost"]=product.cost
v["cost_view"]=product.cost
else:
v["cost"]=0
v["cost_view"]=0
v['sum_sale']=num*price
v['sum_cost']=num*v["cost"]
v['sum_profit']=v['sum_sale']-v['sum_cost']
return {"value":v}
#按销售单中对应的客户,自动过滤选择工单
domain="[('customer','=',customer)]" ,打开选择窗口时过滤条件默认客户
context="{'search_default_customer':customer}"
<group>
<field
name="date"/>
<field
name="name"/>
<field
name="customer"/>
<field name="product" on_change="on_change_product(product, num,
price)"/>
<field name="num" on_change="on_change_product(product, num,
price)"/>
<field name="price" on_change="on_change_product(product, num,
price)"/>
<field name="cost" on_change="on_change_product(product, num, price)"
invisible="1"/>
<field name="cost_view"
invisible="0"/>
</group>
<group>
<field name="employee_id"
on_change="onchange_employee_id(employee_id)"/>
<field
name="department_id"/>
<field name="work_order" domain="[('customer','=',customer)]"
context="{'search_default_customer':customer}"/>
<field
name="klbh"/>
<field
name="sum_sale"/>
<field
name="sum_cost"/>
<field
name="sum_profit"/>
</group>
openerp学习笔记 视图中字段只变化(on_change)联动其他字段值、选择和过滤的更多相关文章
- openerp学习笔记 视图样式(表格行颜色、按钮,字段只读、隐藏,按钮状态、类型、图标、权限,group边距,聚合[合计、平均],样式)
表格行颜色: <tree string="请假单列表" colors="red:state == 'refuse';blue:state = ...
- openerp学习笔记 视图(tree\form)中隐藏按钮( 创建、编辑、删除 ),tree视图中启用编辑
视图(tree\form)中隐藏按钮( 创建.编辑.删除 )create="false" edit="false" delete="false&quo ...
- openerp学习笔记 视图继承(tree、form、search)
支持的视图类型:form.tree.search ... 支持的定位方法: <notebook position="inside"> ...
- openerp学习笔记 视图更新时删除已存在的菜单或其他对象
删除菜单示例: <delete id="base.menu_module_updates" model="ir.ui.menu"/><dele ...
- ArcGIS案例学习笔记-点集中最近点对和最远点对
ArcGIS案例学习笔记-点集中最近点对和最远点对 联系方式:谢老师,135-4855-4328,xiexiaokui@qq.com 目的:对于点图层,查找最近的点对和最远的点对 数据: 方法: 1. ...
- 《Cocos2d-x游戏开发实战精解》学习笔记3--在Cocos2d-x中播放声音
<Cocos2d-x游戏开发实战精解>学习笔记1--在Cocos2d中显示图像 <Cocos2d-x游戏开发实战精解>学习笔记2--在Cocos2d-x中显示一行文字 之前的内 ...
- openerp学习笔记 计算字段、关联字段(7.0中非计算字段、关联字段只读时无法修改保存的问题暂未解决)
计算字段.关联字段,对象修改时自动变更保存(当 store=True 时),当 store=False 时,默认不支持过滤和分组7.0中非计算字段.关联字段只读时无法修改保存的问题暂未解决 示例代码: ...
- openerp学习笔记 搜索视图(自己创建的、自己的、本部门的、本部门及下属部门的、今日的、日期从,日期至、多条件模糊搜索、or、and)
自己创建的: domain="[('create_uid','=',uid)]" 自己的: domain="[('employee_id','=','#kl_user_e ...
- openerp学习笔记 统计、分析、报表(过滤条件向导、分组报表、图形分析、比率计算、追加视图排序)
待解决:图形中当改变分组时,图例不正确 存储比率计算时,分组合计不正确 wizard:过滤条件向导,用于输入过滤条件 wizard/sale_chart.py # -*- cod ...
随机推荐
- 1、Bash Shell
一.什么是Bash shell BashShell是一个命令解释器,它在操作系统的最外层,负责用户程序与内核进行交互操作的一种接口,将用户输入的命令翻译给操作系统,并将处理后的结果输出至屏幕. 当我们 ...
- 十,StatefulSet简介及简单使用
目录 StatefulSet简介 为什么要用statefulset控制器 简单测试 使用 StatefulSet 创建基础的PV StatefulSet 清单 statefulset管理pod的启停顺 ...
- js遍历数组随机返回指定的数组结果
////随机生成数组中自定义的个数返回一个字符串数组 function getArrayItems(arr, num) { //新建一个数组,将传入的数组复制过来,用于运算,而不要 ...
- docker安装kafka快速入门
docker安装kafka快速入门 1.安装zookeeper docker search zookeeperdocker pull zookeeperdocker run -d -v /home/s ...
- netty-2.客户端与服务端互发消息
(原) 第二篇,客户端与服务端互发消息 与第一篇的例子类似,这里服务端需要三个类,客户端也需要三个类. 服务端关键代码如下:MyServer与上一个例子中的TestServer 差多,这里只列举不同的 ...
- idea详细设置:编码、代码提示大小写、窗口数量限制、自动导包、serialID、重复代码警告、热部署等设置
提示: idea ultimate 2018.2 idea-file-setttings设置的是当前项目的配置(只针对当前项目生效)idea-file-others settings相当于以后导入创建 ...
- Spring事务源码分析
首先看例子,这例子摘抄自开涛的跟我学spring3. @Test public void testPlatformTransactionManager() { DefaultTransactionDe ...
- React造轮子:拖拽排序组件「Dragact」
先来一张图看看: 项目地址:Github地址 (无耻求星!) 在线观看(第一次加载需要等几秒):预览地址 说起来不容易,人在国外没有过年一说,但是毕竟也是中国年,虽然不放假,但是家里总会主内一顿丰盛的 ...
- linux运维、架构之路-K8s数据管理
一.Volume介绍 容器和Pod是短暂的,它们的生命周期可能很短,会被频繁的销毁和创建,存在容器中的数据会被清除,为了持久化保存容器的数据,k8s提供了Volume.Volume的生命周期独立于容器 ...
- Golang ioutil.ReadDir 读取目录下的内容并排序
之前写的https://www.cnblogs.com/pu369/p/10620731.html一文中,也有对slice的排序,但代码乱的自己也看不下去了. 参考https://blog.csdn. ...