diff --git a/account_move_original_partner/__init__.py b/account_move_original_partner/__init__.py new file mode 100644 index 00000000000..e69f2a68606 --- /dev/null +++ b/account_move_original_partner/__init__.py @@ -0,0 +1,5 @@ +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from . import models + +from .hooks import post_init_hook diff --git a/account_move_original_partner/__manifest__.py b/account_move_original_partner/__manifest__.py new file mode 100644 index 00000000000..6f596140b54 --- /dev/null +++ b/account_move_original_partner/__manifest__.py @@ -0,0 +1,17 @@ +# Copyright 2021 Camptocamp +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +{ + "name": "Acccount Move Original Partners", + "version": "14.0.1.0.0", + "summary": "Display original customers when creating invoices from" + " multiple sale orders.", + "author": "Camptocamp, Odoo Community Association (OCA)", + "website": "https://github.com/OCA/account-invoicing", + "license": "AGPL-3", + "category": "Accounting & Finance", + "depends": ["account", "sale"], + "data": ["views/account_move.xml"], + "installable": True, + "post_init_hook": "post_init_hook", +} diff --git a/account_move_original_partner/hooks.py b/account_move_original_partner/hooks.py new file mode 100644 index 00000000000..bb2f99c4abe --- /dev/null +++ b/account_move_original_partner/hooks.py @@ -0,0 +1,28 @@ +# Copyright 2021 Camptocamp SA +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html) + +from logging import getLogger + +from odoo import SUPERUSER_ID, api + +_logger = getLogger(__name__) + + +def post_init_hook(cr, registry): + with api.Environment.manage(): + env = api.Environment(cr, SUPERUSER_ID, {}) + force_compute_original_partners(env) + + +def force_compute_original_partners(env): + """Force compute original partners. + + Since field `original_partner_ids` is not automatically computed upon + module installation, we need to compute it manually on existing records. + + :param env: an Odoo Environment instance + """ + domain = [("move_type", "=", "out_invoice")] + invs = env["account.move"].search(domain) + _logger.info("Force-compute original partners on %s invoices" % len(invs)) + invs._compute_original_partner_ids() diff --git a/account_move_original_partner/models/__init__.py b/account_move_original_partner/models/__init__.py new file mode 100644 index 00000000000..9c0a4213854 --- /dev/null +++ b/account_move_original_partner/models/__init__.py @@ -0,0 +1 @@ +from . import account_move diff --git a/account_move_original_partner/models/account_move.py b/account_move_original_partner/models/account_move.py new file mode 100644 index 00000000000..d124ccc8d01 --- /dev/null +++ b/account_move_original_partner/models/account_move.py @@ -0,0 +1,26 @@ +# Copyright 2021 Camptocamp SA +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html) + +from odoo import api, fields, models + + +class AccountMove(models.Model): + _inherit = "account.move" + + original_partner_ids = fields.Many2many( + comodel_name="res.partner", + relation="account_move_original_partner_rel", + column1="account_move_id", + column2="res_partner_id", + compute="_compute_original_partner_ids", + store=True, + string="Original Partners", + ) + + @api.depends("move_type", "invoice_line_ids.sale_line_ids.order_id.partner_id") + def _compute_original_partner_ids(self): + for move in self: + move.original_partner_ids = ( + move.move_type == "out_invoice" + and move.invoice_line_ids.mapped("sale_line_ids.order_id.partner_id") + ) diff --git a/account_move_original_partner/readme/CONTRIBUTORS.rst b/account_move_original_partner/readme/CONTRIBUTORS.rst new file mode 100644 index 00000000000..60641f5f92c --- /dev/null +++ b/account_move_original_partner/readme/CONTRIBUTORS.rst @@ -0,0 +1,3 @@ +* `Camptocamp `_ + + * Silvio Gregorini diff --git a/account_move_original_partner/readme/CREDITS.rst b/account_move_original_partner/readme/CREDITS.rst new file mode 100644 index 00000000000..f5cc070c78e --- /dev/null +++ b/account_move_original_partner/readme/CREDITS.rst @@ -0,0 +1,3 @@ +The development of this module has been financially supported by: + +* Camptocamp diff --git a/account_move_original_partner/readme/DESCRIPTION.rst b/account_move_original_partner/readme/DESCRIPTION.rst new file mode 100644 index 00000000000..f886be002da --- /dev/null +++ b/account_move_original_partner/readme/DESCRIPTION.rst @@ -0,0 +1,6 @@ +When invoicing multiple sale orders at the same time, they may be grouped into +a single invoice. When it happens, it is hard to retrieve who the original SO +partners were. + +This module helps by retrieving such partners and showing them into the invoice +form view, alongside the invoice partner itself. diff --git a/account_move_original_partner/static/description/icon.png b/account_move_original_partner/static/description/icon.png new file mode 100644 index 00000000000..3a0328b516c Binary files /dev/null and b/account_move_original_partner/static/description/icon.png differ diff --git a/account_move_original_partner/views/account_move.xml b/account_move_original_partner/views/account_move.xml new file mode 100644 index 00000000000..23e4067be37 --- /dev/null +++ b/account_move_original_partner/views/account_move.xml @@ -0,0 +1,36 @@ + + + + + view.account.invoice.filter.inherit + account.move + + + + + + + + + + view.move.form.inherit + account.move + + + + + + + + + diff --git a/setup/account_move_original_partner/odoo/addons/account_move_original_partner b/setup/account_move_original_partner/odoo/addons/account_move_original_partner new file mode 120000 index 00000000000..9294c096228 --- /dev/null +++ b/setup/account_move_original_partner/odoo/addons/account_move_original_partner @@ -0,0 +1 @@ +../../../../account_move_original_partner \ No newline at end of file diff --git a/setup/account_move_original_partner/setup.py b/setup/account_move_original_partner/setup.py new file mode 100644 index 00000000000..28c57bb6403 --- /dev/null +++ b/setup/account_move_original_partner/setup.py @@ -0,0 +1,6 @@ +import setuptools + +setuptools.setup( + setup_requires=['setuptools-odoo'], + odoo_addon=True, +)