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)联动其他字段值、选择和过滤的更多相关文章

  1. openerp学习笔记 视图样式(表格行颜色、按钮,字段只读、隐藏,按钮状态、类型、图标、权限,group边距,聚合[合计、平均],样式)

    表格行颜色:             <tree string="请假单列表" colors="red:state == 'refuse';blue:state = ...

  2. openerp学习笔记 视图(tree\form)中隐藏按钮( 创建、编辑、删除 ),tree视图中启用编辑

    视图(tree\form)中隐藏按钮( 创建.编辑.删除 )create="false" edit="false" delete="false&quo ...

  3. openerp学习笔记 视图继承(tree、form、search)

    支持的视图类型:form.tree.search ... 支持的定位方法:                  <notebook position="inside"> ...

  4. openerp学习笔记 视图更新时删除已存在的菜单或其他对象

    删除菜单示例: <delete id="base.menu_module_updates" model="ir.ui.menu"/><dele ...

  5. ArcGIS案例学习笔记-点集中最近点对和最远点对

    ArcGIS案例学习笔记-点集中最近点对和最远点对 联系方式:谢老师,135-4855-4328,xiexiaokui@qq.com 目的:对于点图层,查找最近的点对和最远的点对 数据: 方法: 1. ...

  6. 《Cocos2d-x游戏开发实战精解》学习笔记3--在Cocos2d-x中播放声音

    <Cocos2d-x游戏开发实战精解>学习笔记1--在Cocos2d中显示图像 <Cocos2d-x游戏开发实战精解>学习笔记2--在Cocos2d-x中显示一行文字 之前的内 ...

  7. openerp学习笔记 计算字段、关联字段(7.0中非计算字段、关联字段只读时无法修改保存的问题暂未解决)

    计算字段.关联字段,对象修改时自动变更保存(当 store=True 时),当 store=False 时,默认不支持过滤和分组7.0中非计算字段.关联字段只读时无法修改保存的问题暂未解决 示例代码: ...

  8. openerp学习笔记 搜索视图(自己创建的、自己的、本部门的、本部门及下属部门的、今日的、日期从,日期至、多条件模糊搜索、or、and)

    自己创建的: domain="[('create_uid','=',uid)]" 自己的: domain="[('employee_id','=','#kl_user_e ...

  9. openerp学习笔记 统计、分析、报表(过滤条件向导、分组报表、图形分析、比率计算、追加视图排序)

    待解决:图形中当改变分组时,图例不正确            存储比率计算时,分组合计不正确 wizard:过滤条件向导,用于输入过滤条件 wizard/sale_chart.py # -*- cod ...

随机推荐

  1. SSH安装配置

    一.环境准备 二.SSH配置 1.root用户进入home目录,确实有无隐藏文件夹 .ssh cd ~ ls -lrta 2.有,则跳过本步骤:没有,执行如下命令 ##根据提示输入当前用户密码 ssh ...

  2. 9.1.远程过程调用协议_RPC

    6. RPC 6.1.什么是 RPC RPC(Remote Procedure Call Protocol)远程过程调用协议 通俗的描述是:客户端在不知道调用细节的情况下,调用存在于远程计算机上的某个 ...

  3. DA_04_解决Xshell中文乱码问题

    一:解决Xshell中文乱码问题      二:解决克隆后eth0不见的问题 2.1:虚拟机克隆步骤:          1.直接修改  /etc/sysconfig/network-script/i ...

  4. YII2组件之GridView

    采用的是yii2.0.14版本,为了学习方便,以问答式书写. 开始GridView GridView主要是为了实现表格复用,尤其我们做后台的时候,你发现表单和表格占据了大部分页面,而表格的样式又是高度 ...

  5. SAP笔记

    1,负数的表示增强 负号从数字后更改到数字前面 适用于字符型字段: CALL FUNCTION 'CLOI_PUT_SIGN_IN_FRONT' CHANGING VALUE = gt_table-c ...

  6. IntelliJ IDEA安装后几个重要的目录及配置文件讲解

    本文大概记录了IntelliJ IDEA安装之后比较重要的目录和几个核心文件 重要的安装目录 安装完之后的bin目录大致如下 IntelliJ IDEA 的安装目录并不复杂,上图为最常改动的 bin ...

  7. 谷歌插件学习笔记:把iframe干掉……

    好久不写博客了,感觉自己变得越来越懒了,是没有时间吗?不是,是自己变得越来越懒了,好多东西不愿意去总结了,可能也是学的不精总结不出来什么玩意儿.不过,一切都是借口.还是坚持学习,坚持写博客吧,虽然写的 ...

  8. laravel开发扩展记录

    whoops 错误提示扩展 whoops 是一个非常优秀的 PHP Debug 扩展,它能够使你在开发中快速定位出错的位置.laravel默认安装.区域 1 -- 是错误异常的简介区域 2 -- 是错 ...

  9. 洛谷-P3805-Manacher模板

    链接: https://www.luogu.org/problem/P3805 题意: 给出一个只由小写英文字符a,b,c...y,z组成的字符串S,求S中最长回文串的长度. 字符串长度为n 思路: ...

  10. mybatis使用@Insert @SelectKey 执行插入语句时获得主键自增长值(转)

    @Insert(" insert into table(c1,c2) " + " values (#{c1},#{c2}) ") @SelectKey(resu ...