在odoo 14中加载表单时下拉列表的默认值

2024-04-25 20:49:34 发布

您现在位置:Python中文网/ 问答频道 /正文

我希望在加载表单时,根据表单的另一个值筛选下拉列表, 我一直在尝试使用默认的_get方法,字段接收正确的数据,但下拉列表似乎没有更新

@api.model
def default_get(self, fields_list):
    result = super(ProjectTask, self).default_get(fields_list)
    #some logic to get user list, pre filtered
    result['user_id'] = users_list

user_list包含预筛选的用户ID列表

编辑

此列表的填充方式如下:

 for e in result_list:
        users_list.append((0,0,{
            'user_id':e['user_id'].id
        }))

这种关系是多对一的,如下所示:

user_id = fields.Many2one('res.users',
    string='Assigned to',
    default=False,
    index=True, track_visibility='always')

我希望根据表单中的值加载一个域 我已经完全做到了,我尝试了提出的答案,但没有任何运气


Tags: to数据方法selfapiiddefault表单
2条回答

当我们从多个类型的字段中下拉时,Odoo调用该对象的name_searchname_get方法(在本例中为res.users

重写res.users对象的name_search方法,并从xml端传递上下文值,以获得对特定视图的更改。否则,它将申请全球专利

最后,我介绍了解决方案的要点:

  • 定义一个函数来创建一个动态域对我来说不起作用
  • 我用过滤后的信息创建一个计算字段
  • 在视图中设置域,而不是在代码中设置域
  • 使用公共函数设置列表的值
  • 将计算字段添加到视图中
  • 相同的函数在下拉列表和计算字段上设置on更改的值

检查以下代码:

fetched_users = fields.Many2many('res.users', compute='fetch_available_employees_default')

def fetch_available_employees_default(self):
    # custom logic, set the computed field and also return the list
    self.fetched_users = users_list      
    return users_list

下拉列表的on change事件,用于重新填充字段

@api.onchange('role_id')
def fetch_available_employees(self):
    users_list = self.fetch_available_employees_default()
    if len(users_list)>0:
        return {'domain': {'user_id': [('id', 'in', users_list)] }}
    else:
        # return empy list by default
        return {'domain': {'user_id': [('id', '=', -1)]}}

他认为:

<field name="fetched_users" invisible="True"/>

<xpath expr="//field[@name='user_id']" position="attributes">
     <attribute name="domain">
         [('id','in',fetched_users)]
     </attribute>
 </xpath>

相关问题 更多 >