1

我想在表单加载时根据表单的另一个值过滤一个下拉列表,我一直在尝试在 default_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')

我希望根据表单中的值加载

4

2 回答 2

1

最后,我按照这个方法,解决方案的亮点:

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

检查以下代码:

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>
于 2021-02-01T16:05:54.890 回答
0

当我们从 many2one 类型的字段中进行下拉时,Odoo 会为该对象调用name_searchname_get方法(在本例中res.users)。

覆盖对象name_search的方法res.users并从 xml 端传递上下文值以获取特定视图的更改。否则它适用于全局。

于 2021-01-20T18:46:10.423 回答