如何在domain中获得登录用户的信息来进行过滤 及 fnct_search怎么写?
-
我的需求: 我想获得登录用户的信息,用这个信息在domain中过滤tree显示数据
res.users类:class ccc_users(osv.osv):<br /> _name = "res.users"<br /> _description = "自己的用户表"<br /> _inherit = "res.users"<br /> _columns = { <br /> 'region_id': fields.many2one('ccc.region', '区域'), #指示该用户是哪个区域的<br /> 'parent_id': fields.many2one('res.users', '区域负责人'),<br /> 'child_ids': fields.one2many('res.users', 'parent_id', '本区域业务员'),<br /> }<br /> _sql_constraints = [<br /> ('uniq_name', 'unique(name)', u'用户姓名必须唯一,已经存在这个用户姓名的用户了')<br /> ]
客户表:class ccc_partner(osv.osv):<br /> _name = "ccc.partner"<br /> _description = "ccc客户表"<br /><br /> def _is_this_region_read(self, cr, uid, ids, name, arg, context=None):<br /> res = {}<br /> for id in ids:<br /> result = self.read(cr, uid, id, ['region_id'])<br /> login_region = self.pool.get('res.users').browse(cr, uid, uid).region_id<br /> print result<br /> print login_region<br /> print result['region_id'][0]<br /> print login_region['id']<br /> if result['region_id'][0] == login_region['id']:<br /> res[id] = True<br /> # res[id] = False<br /> else:<br /> res[id] = False<br /><br /> return res<br /><br /> _columns = {<br /> 'name' : fields.char("客户名称", size=64, required=True),<br /> 'user_id' : fields.many2one('res.users', "责任人"),<br /> 'is_this_region': fields.function(_is_this_region_read, string='是否与登录用户同区域', type="boolean", store=True, readonly=True),<br /> }
domain代码:<field name="domain">[('is_this_region', '=', True)]</field>
我用这个方法去写了一下(即用function字段来作为domain过滤),但是还是有问题。domain的过滤先与 is_this_region的求解,所以每个数据的is_this_region都是False,所以根本没有起到过滤的效果。经群里的大虾提示说 ,可以用 fnct_search, 因为domain过滤就是通过search()来实现的。 但是fnct_search我根本不知道怎么写? 也没有看到比较容易看懂得例子。所以在此发帖问一下是不是用fnct_search就能实现完成这个需求,并且fnct_search应该怎么写? 谢谢! -
[quote author=mrshelly link=topic=4281.msg11668#msg11668 date=1343871623]
在 search 方法中. 获取 uid 能管辖的 region id 并组合一个
[('region_id', 'in', 查到的ids)] 的 domain 添加到现有 domain 中即可...
[/quote]
谢谢,问题已经解决了