在 odoo 14 中加载表单时下拉列表的默认值
Default values for a dropdown when forms loads in odoo 14
我希望在加载表单时根据表单的另一个值过滤下拉列表,
我一直在尝试在 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')
我希望根据表单中的值加载域
我正好 this issue presented in this question,我尝试了建议的答案,但运气不佳
当我们从 many2one 类型的字段中进行下拉时,Odoo 为该对象调用 name_search
和 name_get
方法(在本例中为 res.users
)。
覆盖 res.users
对象的 name_search
方法并从 xml 端传递上下文值以获取特定视图的更改。否则申请全球。
最后我按照this approach,解决方案的亮点:
- 定义创建动态域的函数对我不起作用
- 我用过滤后的信息创建了一个计算字段
- 在视图中设置域,而不是在代码中
- 使用设置列表值的常用函数
- 将计算字段添加到视图
- 相同的函数设置下拉列表和计算字段上的更改值
检查以下代码:
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
下拉菜单的更改事件,重新填充字段
@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>
我希望在加载表单时根据表单的另一个值过滤下拉列表, 我一直在尝试在 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')
我希望根据表单中的值加载域 我正好 this issue presented in this question,我尝试了建议的答案,但运气不佳
当我们从 many2one 类型的字段中进行下拉时,Odoo 为该对象调用 name_search
和 name_get
方法(在本例中为 res.users
)。
覆盖 res.users
对象的 name_search
方法并从 xml 端传递上下文值以获取特定视图的更改。否则申请全球。
最后我按照this approach,解决方案的亮点:
- 定义创建动态域的函数对我不起作用
- 我用过滤后的信息创建了一个计算字段
- 在视图中设置域,而不是在代码中
- 使用设置列表值的常用函数
- 将计算字段添加到视图
- 相同的函数设置下拉列表和计算字段上的更改值
检查以下代码:
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
下拉菜单的更改事件,重新填充字段
@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>