我有一个问题,在某些相关字段中列不可排序。
我使用以下代码片段扩展了res.partner表单:
class CrmProject(models.Model):
_name = 'crm.project'
_inherit = ['mail.thread', 'ir.needaction_mixin']
_inherits = {
'res.partner': 'partner_id',
}
_order = "name asc"
@api.model
def _get_domain_employee(self):
ids = self.env.ref('aim_contacts.res_partner_business_2').ids
return [('business_id', '=', ids)]
.
.
industry_id = fields.Many2one('crm.project.industry', 'Construction Type')
我使用以下代码扩展了sales / opportunity模块:
class CrmOpportunity(models.Model):
_name = 'crm.opportunity'
_inherit = ['mail.thread', 'ir.needaction_mixin', 'aim.res.common']
_order = 'name asc'
@api.model
def _get_domain_employee(self):
ids = self.env.ref('aim_contacts.res_partner_business_2').ids
return [('business_id', '=', ids)]
name = fields.Char('Topic', required=True)
.
.
crm_project_id = fields.Many2one('crm.project', 'Project', track_visibility='onchange')
industry_id = fields.Many2one('crm.project.industry', 'Construction Type',related='crm_project_id.industry_id', readonly=True)
视图定义如下:
<record id="crm_opportunity_tree_view" model="ir.ui.view">
<field name="name">crm.opportunity.tree.view</field>
<field name="model">crm.opportunity</field>
<field name="arch" type="xml">
<tree string="Opportunities">
<field name="name" string="Topic" invisible="1"/>
<field name="crm_project_id"/>
<field name="industry_id"/>
</tree>
</field>
</record>
问题1:加载商机页面后,单击“构造类型”(industry_id)标题不执行任何操作。
问题2:此外,当单击“项目”(crm_project_id)标题时,该列按id而不是名称排序(即使它显示名称)。
我认为可以通过添加到crm.project.py来解决问题2:
_order = "name asc"
但它不起作用。
任何帮助将不胜感激。
更新
将store = True添加到相关字段的方法有效。但是存在一个问题,如果该字段已经创建,那么它将/可能不会使用最新发送的数据进行更新。
为了解决这个问题,我创建了另一个与原始信息相同的字段,然后链接到它。我读过其他人放弃了字段并再次创建它们。
相关字段未存储在数据库中,您无法通过未存储在数据库中的字段进行排序,因此该部分的解决方案是将store=True
添加到相关字段:
industry_id = fields.Many2one('crm.project.industry', 'Construction Type',related='crm_project_id.industry_id', readonly=True, store=True)
您的项目字段应该正常工作,如果记录按名称排序,您是否已在crm.project
的树视图中签入?检查name_get
及其crm.project
场的display_name
方法。您可以解决此问题,将其他存储的相关字段添加到您的crm.opportunity
模型:
crm_project_name = fields.Char('crm.project', 'Construction Type',related='crm_project_id.name', store=True)
在您的XML中:
<record id="crm_opportunity_tree_view" model="ir.ui.view">
<field name="name">crm.opportunity.tree.view</field>
<field name="model">crm.opportunity</field>
<field name="arch" type="xml">
<tree string="Opportunities">
<field name="name" string="Topic" invisible="1"/>
<field name="crm_project_id" invisible="1"/>
<field name="crm_project_name"/>
<field name="industry_id"/>
</tree>
</field>
</record>
如果你赶时间(当你正在寻找问题时)这样做。但我会将相关字段与name
以及相关字段进行display_name
,并在树视图中对它们进行排序以检查发生了什么(如果display_name
列按ID排序,那么问题是name_get
方法或display_name
字段,毫无疑问)。