#服务卡创建,自动更新服务卡为开卡状态
   
def create(self, cr, uid, values,
context=None):
        values['state'] =
'1'
        values['times_limit'] =
values['remaining_times']
#保存时按设置的剩余次数给初始次数赋值
        cardid = 
super(dispatch_service_card, self).create(cr, uid, values,
context=context)
        #开卡记录  

       
service_card=self.pool.get("dispatch.service_card")
       
service_card_rec=service_card.browse(cr,uid,cardid)
       
# 自动记录服务卡增减记录(创建对象过程)
       
card_record =
self.pool.get('dispatch.service.card.recording')

       
card_record.create(cr, uid, {'customer': service_card_rec.customer.id,
'service_card': service_card_rec.id,

                                                     
'start_times': 0, 'increase_times': service_card_rec.remaining_times,
'end_times': service_card_rec.remaining_times,

                                                     
'action': "开卡"})

        return cardid

#服务单报工,验证并更新服务卡状态
   
def set_to_done(self, cr, uid, ids,
context=None):
        for rec in
self.browse(cr, uid, ids,
context=context):
           
if not rec.engineer:

               
raise
osv.except_osv(_(u'警告!'),_(u'服务单报工时必须指定服务工程师.'))
           
#判断是否已指定需要扣卡
           
if not
rec.state_use_card:
               
raise
osv.except_osv(_(u'警告!'),_(u'请首先指定是否需要扣卡.'))
           
if (rec.state_use_card ==
"1"):
               
if not rec.service_card:

                   
raise
osv.except_osv(_(u'警告!'),_(u'需要扣卡时必须指定服务卡.'))
               
service_card=self.pool.get("dispatch.service_card")
               
service_card_rec=service_card.browse(cr,uid,rec.service_card.id)
               
if rec.customer.id !=
service_card_rec.customer.id:
                   
raise
osv.except_osv(_(u'警告!'),_(u'当前服务卡所属客户与当前服务单对应客户不一致,请更换服务卡.'))
               
if service_card_rec.remaining_times <=
0:
                   
raise
osv.except_osv(_(u'警告!'),_(u'当前服务卡已经扣完,请更换新卡.'))
               
if rec.bill_date >
service_card_rec.due_date:
                   
raise
osv.except_osv(_(u'警告!'),_(u'当前服务卡已超期,请更换新卡.'))
               
if service_card_rec.state !=
'1':
                   
raise
osv.except_osv(_(u'警告!'),_(u'当前服务卡未处于开卡状态,请更换服务卡.'))
               
#扣卡
               
service_card.write(cr, uid, service_card_rec.id,
{'remaining_times':service_card_rec.remaining_times-1})
               
#更新服务卡为已完成状态
               
if service_card_rec.remaining_times ==
1:
                    
service_card.write(cr, uid, service_card_rec.id,
{'state':'2'}) #(更新对象过程)

               
#
自动记录服务卡增减记录
               
card_record =
self.pool.get('dispatch.service.card.recording')
               
card_record.create(cr, uid, {'customer': rec.customer.id, 'service_card':
service_card_rec.id,

                                                             
'start_times': service_card_rec.remaining_times, 'decrease_times': 1,
'end_times': service_card_rec.remaining_times-1,

                                                             
'work_order': rec.id, 'action':
"扣卡"})
               
return self.write(cr, uid, ids, {'state':'done', 'done_date':
datetime.datetime.now()})
           
else:
               
return self.write(cr, uid, ids, {'service_card':False,
'service_card_remaining_times':False, 'state':'done', 'done_date':
datetime.datetime.now()}) #(更新对象过程)

    #新增产品时,记录初始成本
    def
create(self, cr, uid, values,
context=None):
        productid =
super(dispatch_product, self).create(cr, uid, values,
context=context)
        costrecord =
self.pool.get('dispatch.product.cost.recording')
       
costrecord.create(cr, uid, {'dispatch_product': productid, 'cost':
values['cost']})
        return
productid
       

   
#修改产品时,判断成本是否修改并记录成本变更
    def write(self, cr, uid,
ids, vals, context=None):
        #
更新成本是自动记录
        if (vals != [])
and
vals.has_key('cost'): #(更新时判断对象中的字段是否被修改)
           
costrecord =
self.pool.get('dispatch.product.cost.recording')
           
for productid in
ids:
               
costrecord.create(cr, uid, {'dispatch_product': productid, 'cost':
vals['cost']})
        return
super(dispatch_product, self).write(cr, uid, ids, vals, context=context)

openerp学习笔记 对象调用(创建、修改),用于后台代码创建和更新对象的更多相关文章

  1. openerp学习笔记 跟踪状态,记录日志,发送消息

    跟踪状态基础数据: kl_qingjd/kl_qingjd_data.xml <?xml version="1.0"?><openerp>    <d ...

  2. 多线程编程学习笔记——异步调用WCF服务

    接上文 多线程编程学习笔记——使用异步IO 接上文 多线程编程学习笔记——编写一个异步的HTTP服务器和客户端 接上文 多线程编程学习笔记——异步操作数据库 本示例描述了如何创建一个WCF服务,并宿主 ...

  3. python 四种方法修改类变量,实例对象调用类方法改变类属性的值,类对象调用类方法改变类属性的值,调用实例方法改变类属性的值,直接修改类属性的值

    三种方法修改类变量,实例对象调用类方法改变类属性的值,类对象调用类方法改变类属性的值,调用实例方法改变类属性的值,类名就是类对象,city就是类变量, #coding=utf-8 class empl ...

  4. 【转】Pandas学习笔记(三)修改&添加值

    Pandas学习笔记系列: Pandas学习笔记(一)基本介绍 Pandas学习笔记(二)选择数据 Pandas学习笔记(三)修改&添加值 Pandas学习笔记(四)处理丢失值 Pandas学 ...

  5. C# step by step 学习笔记8 CHAPTER 9 使用枚举和结构创建值类型

    C# 2012 step by step 学习笔记8 CHAPTER 9 使用枚举和结构创建值类型 本章内容 声明一个枚举类型 创建并使用一个枚举类型 声明一个结构类型 创建并使用一个结构类型 解释结 ...

  6. iOS回顾笔记( 01 )-- XIB和纯代码创建应用的对比

    header{font-size:1em;padding-top:1.5em;padding-bottom:1.5em} .markdown-body{overflow:hidden} .markdo ...

  7. Swift学习笔记(一)搭配环境以及代码运行成功

    原文:Swift学习笔记(一)搭配环境以及代码运行成功 1.Swift是啥? 百度去!度娘告诉你它是苹果最新推出的编程语言,比c,c++,objc要高效简单.能够开发ios,mac相关的app哦!是苹 ...

  8. amazeui学习笔记--css(HTML元素2)--代码Code

    amazeui学习笔记--css(HTML元素2)--代码Code 一.总结 1.行内代码:code标签<code> 2.代码片段:pre标签<pre> 3.限制代码块高度:添 ...

  9. openerp学习笔记 数据合法性约束(对象约束+数据库约束)

    #检测同一时间段内是否存在相同的请假单,False 是存在,不允许创建    def _check_date(self, cr, uid, ids):        for rec in self.b ...

随机推荐

  1. 平时工作常用linux命令总结

    mkdir 创建目录  make dir cp 拷贝文件  copy mv 移动文件   move rm  删除文件 remove # 创建连级目录 mkdir -p a/b/c # 拷贝文件夹a到文 ...

  2. Delphi TIdTCPClient组件

    樊伟胜

  3. Python中的字符串及其相关操作

    1.表示: 字符串可以用单引号或者双引号括起来,两者效果是完全一样的. 针对较长的字符串,也可以用三个引号括起来,即"""..."""或者' ...

  4. P3731 二分图匹配必经边

    题意经过一番转换变成了 让你在一个二分图上删一条边使得二分图的最大独立集大小至少+1 二分图的最大独立集=点数-最小点覆盖(最大匹配) 点数是固定不变的 所以我们要减少最大匹配数 则删掉的哪一条边必须 ...

  5. Mybatis config.xml 配置

    <!-- xml标准格式 --><?xml version="1.0" encoding="UTF-8"?>  <!DOCTYPE ...

  6. 集合(六) WeakHashMap与LinkedHashMap

    5.WeakHashMap (1) 简介 WeakHashMap与HashMap几乎都是相同的,就是它的键是“弱引用”. 第一个问题:何为弱引用?即WeakReference类对象. String a ...

  7. BZOJ2238 Mst[最小生成树+树剖+线段树]

    跑一遍mst.对于非mst上的边,显然删掉不影响. 如果删边在树上,相当于这时剩下两个连通块.可以证明要重新构成mst只需要再加一条连接两个连通块的最小边,不会证,yy一下,因为原来连通块连的边权和已 ...

  8. 论文参考文献中的M R J意义

    1 期刊作者.题名[J].刊名,出版年,卷(期):起止页码 2 专著作者.书名[M].版本(第一版不著录).出版地:出版者,出版年.起止页码 3 论文集作者.题名[C].//编者.论文集名.出版地:出 ...

  9. 快速傅立叶变换FFT模板

    递归版 UOJ34多项式乘法 //容易暴栈,但是很好理解 #include <cmath> #include <iostream> #include <cstdio> ...

  10. javascript中的正确错误处理------------引用

    JavaScript的事件驱动机制让JavaScript更加丰富,浏览器好比就是一个事件驱动的机器,错误也是一种事件.当一个错误发生时,一个事件就在某个点抛出. 解释起来就是,当发生错误时,JavaS ...