我将“location_id”字段添加到res.user以将用户连接到某个位置
类ResUser(models.Model): _inherit = 'res.users'
current_location_id=fields.Many2one('physical.location',string="Current Loction")
allowed_location_ids=fields.Many2many('physical.location',string="Allowed Location")
我想只使用current_location_id = user_current_location_id
过滤访问次数<filter string="My visits" name="filter_my_visits"
domain="[('current_location_id','=',current_location_id)]"/>
给出了此错误消息
Uncaught Error: Failed to evaluate search criterions:
{"code":400,"message":"Evaluation Error","data":{"type":"local_exception","debug":"Local evaluation failure\nNameError: name 'current_location_id' is not defined\n\n{\"domains\":[[],\"[('current_location_id','=',current_location_id)]\"],\"contexts\":[{\"lang\":\"en_US\",\"tz\":false,\"uid\":1,\"params\":{\"action\":354,\"min\":1,\"limit\":80,\"view_type\":\"list\",\"model\":\"visit.visit\",\"menu_id\":241,\"_push_me\":false}},{}],\"group_by_seq\":[]}"}}
直接调用的唯一可用字段是uid lang ...等 所以我试图覆盖read方法来更新上下文,但它似乎没有在视图中更新,仍然给出了未定义的'current_location_id'
@api.multi
def read(self, fields=None, load='_classic_read'):
ctx = self.env.context.copy()
ctx.update({ 'user_current_location_id':self.env.user.current_location_id.id})
return super(Visit,self.with_context(ctx)).read(fields=fields,load=load)
visit_tree_view
<record id="visit_visit_tree_view" model="ir.ui.view">
<field name="name">visit.visit.tree</field>
<field name="model">visit.visit</field>
<field name="arch" type="xml">
<tree string="Visits">
<field name="name" />
<field name="date"/>
<field name="visit_type" />
<field name="patient_id"/>
<field name="hcp_id"/>
<field name="current_location_id" />
<field name="user_current_location_id"/>
<field name="severity"/>
<field name="state"/>
</tree>
</field>
</record>
访问行动
<record id="visit_visit_act" model="ir.actions.act_window">
<field name="name">Visit</field>
<field name="res_model">visit.visit</field>
<field name="view_type">form</field>
<field name="view_mode">tree,form</field>
<field name="context">{'search_default_filter_my_visits':1}</field>
<field name="search_view_id" ref="view_visit_filter"/>
</record>
这就是我所做的:
@api.multi
def vsit_action(self):
ctx = self.env.context.copy()
ctx.update({'search_default_current_location_id': self.env.user.current_location_id.id,
'user_current_location_id': self.env.user.current_location_id.id})
return {
'name': 'Visit',
'view_type': 'form',
'view_mode': 'tree,form',
'res_model': 'visit.visit',
'type': 'ir.actions.act_window',
'context': dict(ctx),
'search_view_id': self.env.ref('eroyal_visit.view_visit_filter').id
}
过滤器:
<filter string="My visits" name="filter_my_visits"
domain="[('current_location_id', '=', context.get('user_current_location_id'))]"/>
the visit action
<record id="visit_visit_act" model="ir.actions.server">
<field name="name">Visit</field>
<field name="model_id" ref="model_visit_visit"/>
<field name="state">code</field>
<field name="code">
action = env['visit.visit'].vsit_action()
</field>
</record>
default_search_current_id工作正常,但过滤器filter_my_visits使用current_location_id = none过滤视图,同时在上下文中正确设置 坦克
答案 0 :(得分:2)
应该可以通过一些解决方法。而不是使用ir.actions.act_window
尝试使用应返回窗口操作的ir.actions.server
。
为什么?因为您需要有可能将用户的位置ID放入该窗口操作的上下文中。我只通过使用带代码的服务器操作来看到这种可能性。
只需使用位置ID填写窗口操作的上下文:
ctx = dict(env.context,
{'user_location_id': env.user.current_location_id.id,
'search_default_filter_my_visits': 1}
return {
'name': 'Visit',
'view_type': 'form',
'res_model': 'visit.visit',
'type': 'ir.actions.act_window',
'context': ctx,
'search_view_id': env.ref('my_module.view_visit_filter');
}
对于您的过滤器:
<filter string="My visits" name="filter_my_visits"
domain="[('current_location_id', '=', context.get('user_location_id')]"/>