[MIG] base_partner_ref from v12 to v14
This commit is contained in:
committed by
clementmbr
parent
5e4d1b3c8d
commit
4873b8bd21
@@ -1 +1 @@
|
|||||||
from . import partner
|
from . import models
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
# Copyright 2017-2019 Akretion (http://www.akretion.com)
|
# Copyright 2017-2021 Akretion (http://www.akretion.com)
|
||||||
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
{
|
{
|
||||||
'name': 'Base Partner Reference',
|
'name': 'Base Partner Reference',
|
||||||
'version': '12.0.1.0.0',
|
'version': '14.0.1.0.0',
|
||||||
'category': 'Partner',
|
'category': 'Partner',
|
||||||
'license': 'AGPL-3',
|
'license': 'AGPL-3',
|
||||||
'summary': "Improve usage of partner's Internal Reference",
|
'summary': "Improve usage of partner's Internal Reference",
|
||||||
@@ -21,6 +21,6 @@ Base Partner Reference
|
|||||||
'author': 'Akretion',
|
'author': 'Akretion',
|
||||||
'website': 'http://www.akretion.com',
|
'website': 'http://www.akretion.com',
|
||||||
'depends': ['base'],
|
'depends': ['base'],
|
||||||
'data': ['partner_view.xml'],
|
'data': ['views/res_partner.xml'],
|
||||||
'installable': False,
|
'installable': True,
|
||||||
}
|
}
|
||||||
|
|||||||
1
base_partner_ref/models/__init__.py
Normal file
1
base_partner_ref/models/__init__.py
Normal file
@@ -0,0 +1 @@
|
|||||||
|
from . import res_partner
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
# Copyright 2017-2019 Akretion
|
# Copyright 2017-2021 Akretion
|
||||||
# @author: Alexis de Lattre <alexis.delattre@akretion.com>
|
# @author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
@@ -18,9 +18,9 @@ class ResPartner(models.Model):
|
|||||||
)]
|
)]
|
||||||
|
|
||||||
# add 'ref' in depends
|
# add 'ref' in depends
|
||||||
@api.depends('is_company', 'name', 'parent_id.name', 'type', 'company_name', 'ref', 'invalidate_display_name')
|
@api.depends('ref', 'invalidate_display_name')
|
||||||
def _compute_display_name(self):
|
def _compute_display_name(self):
|
||||||
super(ResPartner, self)._compute_display_name()
|
super()._compute_display_name()
|
||||||
|
|
||||||
def _get_name(self):
|
def _get_name(self):
|
||||||
partner = self
|
partner = self
|
||||||
@@ -32,12 +32,13 @@ class ResPartner(models.Model):
|
|||||||
# END modif of native method
|
# END modif of native method
|
||||||
if partner.company_name or partner.parent_id:
|
if partner.company_name or partner.parent_id:
|
||||||
if not name and partner.type in ['invoice', 'delivery', 'other']:
|
if not name and partner.type in ['invoice', 'delivery', 'other']:
|
||||||
name = dict(self.fields_get(['type'])['type']['selection'])[partner.type]
|
name = dict(self.fields_get(
|
||||||
|
['type'])['type']['selection'])[partner.type]
|
||||||
if not partner.is_company:
|
if not partner.is_company:
|
||||||
# START modif of native name_get() method
|
# START modif of native name_get() method
|
||||||
company_name = partner.commercial_company_name or partner.parent_id.name
|
company_name = partner.commercial_company_name or partner.parent_id.name
|
||||||
if partner.parent_id.ref:
|
if partner.parent_id.ref:
|
||||||
company_name = u"[%s] %s" % (partner.parent_id.ref, company_name)
|
company_name = "[%s] %s" % (partner.parent_id.ref, company_name)
|
||||||
name = "%s, %s" % (company_name, name)
|
name = "%s, %s" % (company_name, name)
|
||||||
# END modif of native name_get() method
|
# END modif of native name_get() method
|
||||||
if self._context.get('show_address_only'):
|
if self._context.get('show_address_only'):
|
||||||
@@ -47,7 +48,8 @@ class ResPartner(models.Model):
|
|||||||
name = name.replace('\n\n', '\n')
|
name = name.replace('\n\n', '\n')
|
||||||
name = name.replace('\n\n', '\n')
|
name = name.replace('\n\n', '\n')
|
||||||
if self._context.get('address_inline'):
|
if self._context.get('address_inline'):
|
||||||
name = name.replace('\n', ', ')
|
splitted_names = name.split("\n")
|
||||||
|
name = ", ".join([n for n in splitted_names if n.strip()])
|
||||||
if self._context.get('show_email') and partner.email:
|
if self._context.get('show_email') and partner.email:
|
||||||
name = "%s <%s>" % (name, partner.email)
|
name = "%s <%s>" % (name, partner.email)
|
||||||
if self._context.get('html_format'):
|
if self._context.get('html_format'):
|
||||||
@@ -63,5 +65,6 @@ class ResPartner(models.Model):
|
|||||||
if name and operator == 'ilike':
|
if name and operator == 'ilike':
|
||||||
recs = self.search([('ref', '=', name)] + args, limit=limit)
|
recs = self.search([('ref', '=', name)] + args, limit=limit)
|
||||||
if recs:
|
if recs:
|
||||||
return recs.name_get()
|
rec_childs = self.search([('id', 'child_of', recs.ids)])
|
||||||
|
return rec_childs.name_get()
|
||||||
return super().name_search(name=name, args=args, operator=operator, limit=limit)
|
return super().name_search(name=name, args=args, operator=operator, limit=limit)
|
||||||
@@ -11,29 +11,34 @@
|
|||||||
<field name="name">Move ref in partner form to make it more visible</field>
|
<field name="name">Move ref in partner form to make it more visible</field>
|
||||||
<field name="model">res.partner</field>
|
<field name="model">res.partner</field>
|
||||||
<field name="inherit_id" ref="base.view_partner_form"/>
|
<field name="inherit_id" ref="base.view_partner_form"/>
|
||||||
|
<field name="priority">1000</field> <!-- inherit after l10n_fr -->
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
<field name="type" position="after">
|
<field name="type" position="after">
|
||||||
<field name="ref"/>
|
<field name="ref"/>
|
||||||
</field>
|
</field>
|
||||||
<xpath expr="//page[@name='sales_purchases']//field[@name='ref']" position="replace"/>
|
<xpath expr="//page[@name='sales_purchases']//field[@name='ref']" position="attributes">
|
||||||
|
<attribute name="invisible">1</attribute>
|
||||||
|
</xpath>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
|
<!-- show name and ref in separate columns -->
|
||||||
|
<!-- ref is added in tree view by base_usability with optional="hide"
|
||||||
<record id="view_partner_tree" model="ir.ui.view">
|
<record id="view_partner_tree" model="ir.ui.view">
|
||||||
<field name="name">Add ref in partner tree view</field>
|
<field name="name">Add ref in partner tree view</field>
|
||||||
<field name="model">res.partner</field>
|
<field name="model">res.partner</field>
|
||||||
<field name="inherit_id" ref="base.view_partner_tree"/>
|
<field name="inherit_id" ref="base.view_partner_tree"/>
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
<!-- show name and ref in separate columns -->
|
|
||||||
<field name="display_name" position="after">
|
<field name="display_name" position="after">
|
||||||
<field name="name"/>
|
<field name="name"/>
|
||||||
<field name="ref"/>
|
<field name="ref" optional="hide"/>
|
||||||
</field>
|
</field>
|
||||||
<field name="display_name" position="attributes">
|
<field name="display_name" position="attributes">
|
||||||
<attribute name="invisible">1</attribute>
|
<attribute name="invisible">1</attribute>
|
||||||
</field>
|
</field>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
-->
|
||||||
|
|
||||||
<record id="res_partner_kanban_view" model="ir.ui.view">
|
<record id="res_partner_kanban_view" model="ir.ui.view">
|
||||||
<field name="name">Add ref in partner kanban view</field>
|
<field name="name">Add ref in partner kanban view</field>
|
||||||
@@ -39,6 +39,9 @@
|
|||||||
<field name="model">res.partner</field>
|
<field name="model">res.partner</field>
|
||||||
<field name="inherit_id" ref="base.view_partner_tree"/>
|
<field name="inherit_id" ref="base.view_partner_tree"/>
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
|
<field name="display_name" position="after">
|
||||||
|
<field name="ref" optional="hide"/>
|
||||||
|
</field>
|
||||||
<field name="phone" position="after">
|
<field name="phone" position="after">
|
||||||
<field name="mobile" optional="show" widget="phone" class="o_force_ltr"/>
|
<field name="mobile" optional="show" widget="phone" class="o_force_ltr"/>
|
||||||
</field>
|
</field>
|
||||||
|
|||||||
Reference in New Issue
Block a user