openerp学习笔记 domain 增加扩展支持,例如支持 <field name="domain">[('type','=','get_user_ht_type()')]</field>

示例代码1,ir_action_window.read :

# -*- coding: utf-8 -*-
from openerp.osv import fields,osv

class res_users(osv.osv):
    _name = 'res.users'
    _inherit = 'res.users'
    _columns = {
                'ht_type' : fields.selection([
                ('makings',u'材料'),
                ('theme',u'主题'),
                ('decorate',u'装修')
                ],u'类型'),
                }

    #获取用户具有审核权限的合同类型   
    def _get_ht_type(self, cr, uid, context=None):
        return self.browse(cr, uid, uid, context=context).ht_type
       
res_users()

# 为 domain 增加扩展支持,使用 get_user_ht_type() 获取用户具有审核权限的合同类型
class ir_action_window(osv.osv):
    _inherit = 'ir.actions.act_window'

    def read(self, cr, uid, ids, fields=None, context=None, load='_classic_read'):
        if context is None:
            context = {}
        obj_user = self.pool.get('res.users')
        select = ids
        if isinstance(ids, (int, long)):
            select = [ids]
        res = super(ir_action_window, self).read(cr, uid, select, fields=fields, context=context, load=load)
        for r in res:
            mystring = 'get_user_ht_type()'
            if mystring in (r.get('domain', '[]') or ''):
                r['domain'] = r['domain'].replace(mystring, str(obj_user._get_ht_type(cr, uid)))
        if isinstance(ids, (int, long)):
            if res:
                return res[0]
            else:
                return False
        return res

ir_action_window()

视图中调用:

<field name="domain">[('type','=','get_user_ht_type()')]</field>

 

其它示例代码:

 1 # -*- coding: utf-8 -*-
 2 
 3 from openerp.osv import fields, osv
 4 from openerp import tools
 5 
 6 class hr_department(osv.osv):
 7     def name_get(self, cr, uid, ids, context=None):
 8         if context is None:
 9             context = {}
10         if not ids:
11             return []
12         reads = self.read(cr, uid, ids, ['name','parent_id'], context=context)
13         res = []
14         for record in reads:
15             name = record['name']
16             if record['parent_id']:
17                 name = record['parent_id'][1]+' / '+name
18             res.append((record['id'], name))
19         return res
20 
21     def _dept_name_get_fnc(self, cr, uid, ids, prop, unknow_none, context=None):
22         res = self.name_get(cr, uid, ids, context=context)
23         return dict(res)
24 
25     _name = "hr.department"
26     _columns = {
27         'name': fields.char('Department Name', size=64, required=True),
28         'complete_name': fields.function(_dept_name_get_fnc, type="char", string='Name'),
29         'company_id': fields.many2one('res.company', 'Company', select=True, required=False),
30         'parent_id': fields.many2one('hr.department', 'Parent Department', select=True),
31         'child_ids': fields.one2many('hr.department', 'parent_id', 'Child Departments'),
32         'note': fields.text('Note'),
33     }
34 
35     _defaults = {
36         'company_id': lambda self, cr, uid, c: self.pool.get('res.company')._company_default_get(cr, uid, 'hr.department', context=c),
37                 }
38 
39     def _get_members(self, cr, uid, context=None):
40         mids = self.search(cr, uid, [('manager_id', '=', uid)], context=context)
41         result = {uid: 1}
42         for m in self.browse(cr, uid, mids, context=context):
43             for user in m.member_ids:
44                 result[user.id] = 1
45         return result.keys()
46 
47     def _check_recursion(self, cr, uid, ids, context=None):
48         if context is None:
49             context = {}
50         level = 100
51         while len(ids):
52             cr.execute('select distinct parent_id from hr_department where id IN %s',(tuple(ids),))
53             ids = filter(None, map(lambda x:x[0], cr.fetchall()))
54             if not level:
55                 return False
56             level -= 1
57         return True
58 
59     _constraints = [
60         (_check_recursion, 'Error! You cannot create recursive departments.', ['parent_id'])
61     ]
62 
63 hr_department()
64 
65 class ir_action_window(osv.osv):
66     _inherit = 'ir.actions.act_window'
67 
68     def read(self, cr, uid, ids, fields=None, context=None, load='_classic_read'):
69         if context is None:
70             context = {}
71         obj_dept = self.pool.get('hr.department')
72         select = ids
73         if isinstance(ids, (int, long)):
74             select = [ids]
75         res = super(ir_action_window, self).read(cr, uid, select, fields=fields, context=context, load=load)
76         for r in res:
77             mystring = 'department_users_get()'
78             if mystring in (r.get('domain', '[]') or ''):
79                 r['domain'] = r['domain'].replace(mystring, str(obj_dept._get_members(cr, uid)))
80         if isinstance(ids, (int, long)):
81             if res:
82                 return res[0]
83             else:
84                 return False
85         return res
86 
87 ir_action_window()
88 
89 
90 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
View Code

 

 1 # -*- encoding: utf-8 -*-
 2 
 3 from osv import osv, fields
 4 
 5 class partner_category(osv.osv):
 6     _inherit = 'res.partner.category'
 7     _columns = {
 8         'company_id': fields.many2one('res.company', 'Company',select=1, help="The \"Company\" field is used to filter data in the \"Company Partners\" view.")
 9         }
10     
11     def _get_company(self, cr, uid, id, context=None):
12         if context is None:
13             context={}
14         return self.pool.get('res.partner.category').browse(cr, uid, id, context).company_id.id
15     
16     def _default_company(self, cr, uid, context=None):
17         if context is None:
18             context={}
19         return self.pool.get('res.users').browse(cr, uid, uid, context).company_id.id
20         
21     def onchange_parent_id(self, cr, uid, ids, parent_id, context=None):
22         if context is None:
23             context={}
24         
25         v={}
26 
27         if parent_id:
28             parent_company = self._get_company(cr, uid, parent_id, context)
29             if parent_company:
30                 v['company_id'] = parent_company
31         return {'value': v}
32     
33     _defaults = {  
34         'company_id': _default_company,  
35         }
36 partner_category()
37 
38 class ir_action_window(osv.osv):
39     _inherit = 'ir.actions.act_window'
40 
41     def read(self, cr, uid, ids, fields=None, context=None,
42             load='_classic_read'):
43         select = ids
44         if isinstance(ids, (int, long)):
45             select = [ids]
46         res = super(ir_action_window, self).read(cr, uid, select, fields=fields,
47                 context=context, load=load)
48         for r in res:
49             mystring = 'get_company_categories()'
50             user_obj = self.pool.get('res.users').browse(cr, uid, uid)
51             if mystring in (r.get('domain', '[]') or ''):
52                 r['domain'] = r['domain'].replace(mystring, str(
53                     self.pool.get('res.partner.category').search(cr, uid, [('company_id', '=', user_obj.company_id.id)])))
54         if isinstance(ids, (int, long)):
55             if res:
56                 return res[0]
57             else:
58                 return False
59         return res
60 
61 ir_action_window()
62 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
View Code

视图中调用:

        <record id="action_company_partners_form" model="ir.actions.act_window">
            <field name="name">Company Partners</field>
            <field name="type">ir.actions.act_window</field>
            <field name="res_model">res.partner</field>
            <field name="view_type">form</field>
            <field name="domain">[('category_id', 'in', get_company_categories())]</field>
        </record>
View Code

 

示例代码2,self.search

This is an example.
Look to USER_PARTNER_IDS and USER_PAYMENT_MODE_IDS.

Part of example.xml:
    <record id="action_income_payment_line_tree" model="ir.actions.act_window">
      <field name="name">Входящие платежи</field>
      <field name="res_model">payment.line</field>
      <field name="view_type">form</field>
      <field name="view_mode">tree,form</field>
      <field name="limit">300</field>
      <field name="context">{"search_default_today":1}</field>
      <field name="domain">[('partner_id','in','USER_PARTNER_IDS')]</field>
      <field name="search_view_id" ref="view_payment_line_search"/>
    </record>

    <record id="action_outgoing_payment_line_tree" model="ir.actions.act_window">
      <field name="name">Исходящие платежи</field>
      <field name="res_model">payment.line</field>
      <field name="view_type">form</field>
      <field name="view_mode">tree,form</field>
      <field name="limit">300</field>
      <field name="context">{"search_default_today":1}</field>
      <field name="domain">[('payment_mode','in','USER_PAYMENT_MODE_IDS')]</field>
      <field name="search_view_id" ref="view_payment_line_search"/>
    </record>

Part of example.py:
    def search(self, cr, uid, args, offset=0, limit=None, order=None, context=None, count=False, xtra=None):
        user = self.pool.get('res.users').browse(cr, uid, uid, context=context)
        new_args = []
        for arg in args:
            if type(arg) is not tuple:
                new_args += arg
                continue
            if arg[2] == 'USER_PARTNER_IDS':
                new_args += [(arg[0], arg[1], [p.id for p in user.partner_ids])]
            elif arg[2] == 'USER_PAYMENT_MODE_IDS':
                new_args += [(arg[0], arg[1], [m.id for m in user.payment_mode_ids])]
            else:
                new_args += [arg]
        return super(payment_line, self).search(cr, uid, new_args, offset, limit, order, context, count)

posted @ 2013-07-02 15:34  cnshen  阅读(472)  评论(0编辑  收藏  举报