首页 > 其他 > 详细

OpenERP name_search方法的使用

时间:2014-03-25 22:18:06      阅读:485      评论:0      收藏:0      [点我收藏+]


             在many2one类型中,页面下拉时会首先触发name_search方法,参数这里就不解释了


             优化前:

                     

def name_search(self, cr, user, name, args=None, operator=‘ilike‘, context=None, limit=100):
        if not args:
            args = []
        if context.has_key(‘current_id‘):
            current_pid = context[‘current_id‘]
            cr.execute(‘select id from stock_picking_apply_move‘)
            ids_get = cr.fetchall()
            ids = []
            if not ids_get:
                pass
            else:
                for id in ids_get:
                    ids.append(id[  0])
            moves_obj = self.pool.get(‘stock.picking.apply.move‘).browse(cr, user, ids, context=context)
            pro_ids = []
            for move in moves_obj:
                if move.jp_apply_picking_id.id==current_pid:
                    pro_ids.append(move.product_id.id)
            return self.name_get(cr, user, pro_ids, context=context)
        else:
            #super(jp_product_product,self).name_search(cr, user, name, args=args, operator=operator, context=context, limit=limit)
            tenant_id = context[‘tenant_id‘]
            if not tenant_id:
                raise except_osv(_(‘warning‘),_(‘必须选择租户‘))
            if context.has_key(‘tenant_id‘):
                cr.execute(‘select id from product_product where tenant_id = %s‘,(tenant_id,))
                ids_get = cr.fetchall()
                ids = []
                if not ids_get:
                    return {}
                else:
                    for id in ids_get:
                        ids.append(id[  0])
                    return self.name_get(cr, user, ids, context=context)
            else:
                raise except_osv(_(‘warning‘),_(‘必须选择租户‘))
 
 
 
    def name_get(self, cr, uid, ids, context=None):
        """Get Product In Picking"""
        if not len(ids):
            return []
        res = [ (r[‘id‘], r[‘name‘] and r[‘name‘]
                                      or r[‘name‘] )
                for r in self.read(cr, uid, ids, [‘name‘, ‘id‘],
                                   context=context) ]
        return res



             优化后:


                       

def name_search(self, cr, user, name, args=None, operator=‘ilike‘, context=None, limit=100):
        if context.has_key(‘current_id‘):
            current_pid = context[‘current_id‘]

            ids = []
            apply_obj = self.pool.get(‘stock.picking.apply‘).browse(cr, user, current_pid, context=context)
            for move_line in apply_obj.move_lines_apply:
                prod = move_line.product_id
                ids.append(move_line.product_id.id)

            return self.name_get( cr, user, ids, context=None)

        elif context.has_key(‘tenant_id‘):
            if context[‘tenant_id‘] == False:
                raise except_osv(_(‘提示:‘),_(‘请选择租户‘))
            args = [(‘tenant_id‘, ‘=‘, context[‘tenant_id‘])]

        return super(jp_product_product,self).name_search(cr, user, name, args=args, operator=operator, context=context, limit=limit)

有没有发现,差异很大呢。

注意:使用了name_search方法,在xml中加的domain可能会不起作用


OpenERP name_search方法的使用,布布扣,bubuko.com

OpenERP name_search方法的使用

原文:http://blog.csdn.net/littlebo01/article/details/22075573

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!