From dc36c9101f13b5addea3d76704ab53346d519b92 Mon Sep 17 00:00:00 2001
From: Carlos Dauden
Date: Wed, 2 Mar 2022 17:14:10 +0100
Subject: [PATCH 01/10] [ADD] agreement_rebate_partner_company_group: New
module that apply agreement to all company group members TT34815
---
.../README.rst | 87 ++++
.../__init__.py | 2 +
.../__manifest__.py | 17 +
...agreement_rebate_partner_company_group.pot | 19 +
.../readme/CONTRIBUTORS.rst | 4 +
.../readme/DESCRIPTION.rst | 2 +
.../readme/USAGE.rst | 6 +
.../static/description/icon.png | Bin 0 -> 9455 bytes
.../static/description/index.html | 438 ++++++++++++++++++
.../tests/__init__.py | 3 +
.../tests/test_agreement_rebate.py | 45 ++
.../wizards/__init__.py | 3 +
.../wizards/settlement_create.py | 23 +
13 files changed, 649 insertions(+)
create mode 100644 agreement_rebate_partner_company_group/README.rst
create mode 100644 agreement_rebate_partner_company_group/__init__.py
create mode 100644 agreement_rebate_partner_company_group/__manifest__.py
create mode 100644 agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot
create mode 100644 agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst
create mode 100644 agreement_rebate_partner_company_group/readme/DESCRIPTION.rst
create mode 100644 agreement_rebate_partner_company_group/readme/USAGE.rst
create mode 100644 agreement_rebate_partner_company_group/static/description/icon.png
create mode 100644 agreement_rebate_partner_company_group/static/description/index.html
create mode 100644 agreement_rebate_partner_company_group/tests/__init__.py
create mode 100644 agreement_rebate_partner_company_group/tests/test_agreement_rebate.py
create mode 100644 agreement_rebate_partner_company_group/wizards/__init__.py
create mode 100644 agreement_rebate_partner_company_group/wizards/settlement_create.py
diff --git a/agreement_rebate_partner_company_group/README.rst b/agreement_rebate_partner_company_group/README.rst
new file mode 100644
index 0000000000..37842b906e
--- /dev/null
+++ b/agreement_rebate_partner_company_group/README.rst
@@ -0,0 +1,87 @@
+======================================
+Agreement Rebate Partner Company Group
+======================================
+
+.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
+ !! This file is generated by oca-gen-addon-readme !!
+ !! changes will be overwritten. !!
+ !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
+
+.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
+ :target: https://odoo-community.org/page/development-status
+ :alt: Beta
+.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png
+ :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
+ :alt: License: AGPL-3
+.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fcontract-lightgray.png?logo=github
+ :target: https://github.com/OCA/contract/tree/13.0/agreement_rebate_partner_company_group
+ :alt: OCA/contract
+.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
+ :target: https://translation.odoo-community.org/projects/contract-13-0/contract-13-0-agreement_rebate_partner_company_group
+ :alt: Translate me on Weblate
+.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png
+ :target: https://runbot.odoo-community.org/runbot/110/13.0
+ :alt: Try me on Runbot
+
+|badge1| |badge2| |badge3| |badge4| |badge5|
+
+This module extends the functionality of agreement module to take into
+account if agreements affect to all company group members.
+
+**Table of contents**
+
+.. contents::
+ :local:
+
+Usage
+=====
+
+To use this module you need to:
+
+#. Create an agreement related with a company group partner.
+#. Create several invoices related with company group members.
+#. Create rebate settlements from *Agreements > Settlements > Create Settlements*
+ wizard
+
+Bug Tracker
+===========
+
+Bugs are tracked on `GitHub Issues `_.
+In case of trouble, please check there if your issue has already been reported.
+If you spotted it first, help us smashing it by providing a detailed and welcomed
+`feedback `_.
+
+Do not contact contributors directly about support or help with technical issues.
+
+Credits
+=======
+
+Authors
+~~~~~~~
+
+* Tecnativa
+
+Contributors
+~~~~~~~~~~~~
+
+* `Tecnativa `_:
+
+ * Carlos Dauden
+ * Sergio Teruel
+
+Maintainers
+~~~~~~~~~~~
+
+This module is maintained by the OCA.
+
+.. image:: https://odoo-community.org/logo.png
+ :alt: Odoo Community Association
+ :target: https://odoo-community.org
+
+OCA, or the Odoo Community Association, is a nonprofit organization whose
+mission is to support the collaborative development of Odoo features and
+promote its widespread use.
+
+This module is part of the `OCA/contract `_ project on GitHub.
+
+You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
diff --git a/agreement_rebate_partner_company_group/__init__.py b/agreement_rebate_partner_company_group/__init__.py
new file mode 100644
index 0000000000..8965bbe525
--- /dev/null
+++ b/agreement_rebate_partner_company_group/__init__.py
@@ -0,0 +1,2 @@
+# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
+from . import wizards
diff --git a/agreement_rebate_partner_company_group/__manifest__.py b/agreement_rebate_partner_company_group/__manifest__.py
new file mode 100644
index 0000000000..c89179edbc
--- /dev/null
+++ b/agreement_rebate_partner_company_group/__manifest__.py
@@ -0,0 +1,17 @@
+# Copyright 2022 Tecnativa - Carlos Dauden
+# Copyright 2022 Tecnativa - Sergio Teruel
+# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
+{
+ "name": "Agreement Rebate Partner Company Group",
+ "summary": "Rebate agreements applied to all company group members",
+ "version": "13.0.1.0.0",
+ "development_status": "Beta",
+ "category": "Contract",
+ "website": "https://github.com/OCA/contract",
+ "author": "Tecnativa, Odoo Community Association (OCA)",
+ "license": "AGPL-3",
+ "application": False,
+ "installable": True,
+ "depends": ["agreement_rebate", "partner_company_group"],
+ "data": [],
+}
diff --git a/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot b/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot
new file mode 100644
index 0000000000..977cfb9109
--- /dev/null
+++ b/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot
@@ -0,0 +1,19 @@
+# Translation of Odoo Server.
+# This file contains the translation of the following modules:
+# * agreement_rebate_partner_company_group
+#
+msgid ""
+msgstr ""
+"Project-Id-Version: Odoo Server 13.0\n"
+"Report-Msgid-Bugs-To: \n"
+"Last-Translator: \n"
+"Language-Team: \n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: \n"
+"Plural-Forms: \n"
+
+#. module: agreement_rebate_partner_company_group
+#: model:ir.model,name:agreement_rebate_partner_company_group.model_agreement_settlement_create_wiz
+msgid "Agreement settlement create wizard"
+msgstr ""
diff --git a/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst b/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst
new file mode 100644
index 0000000000..22e2c95561
--- /dev/null
+++ b/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst
@@ -0,0 +1,4 @@
+* `Tecnativa `_:
+
+ * Carlos Dauden
+ * Sergio Teruel
diff --git a/agreement_rebate_partner_company_group/readme/DESCRIPTION.rst b/agreement_rebate_partner_company_group/readme/DESCRIPTION.rst
new file mode 100644
index 0000000000..046cf36c7a
--- /dev/null
+++ b/agreement_rebate_partner_company_group/readme/DESCRIPTION.rst
@@ -0,0 +1,2 @@
+This module extends the functionality of agreement module to take into
+account if agreements affect to all company group members.
diff --git a/agreement_rebate_partner_company_group/readme/USAGE.rst b/agreement_rebate_partner_company_group/readme/USAGE.rst
new file mode 100644
index 0000000000..0e3692a70b
--- /dev/null
+++ b/agreement_rebate_partner_company_group/readme/USAGE.rst
@@ -0,0 +1,6 @@
+To use this module you need to:
+
+#. Create an agreement related with a company group partner.
+#. Create several invoices related with company group members.
+#. Create rebate settlements from *Agreements > Settlements > Create Settlements*
+ wizard
diff --git a/agreement_rebate_partner_company_group/static/description/icon.png b/agreement_rebate_partner_company_group/static/description/icon.png
new file mode 100644
index 0000000000000000000000000000000000000000..3a0328b516c4980e8e44cdb63fd945757ddd132d
GIT binary patch
literal 9455
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
z
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
Xviia!U7SGha1wx#SCgwmn*{w2TRX*I
literal 0
HcmV?d00001
diff --git a/agreement_rebate_partner_company_group/static/description/index.html b/agreement_rebate_partner_company_group/static/description/index.html
new file mode 100644
index 0000000000..6da6d46718
--- /dev/null
+++ b/agreement_rebate_partner_company_group/static/description/index.html
@@ -0,0 +1,438 @@
+
+
+
+
+
+
+Agreement Rebate Partner Company Group
+
+
+
+
+
Agreement Rebate Partner Company Group
+
+
+

+
This module extends the functionality of agreement module to take into
+account if agreements affect to all company group members.
+
Table of contents
+
+
+
+
To use this module you need to:
+
+- Create an agreement related with a company group partner.
+- Create several invoices related with company group members.
+- Create rebate settlements from Agreements > Settlements > Create Settlements
+wizard
+
+
+
+
+
Bugs are tracked on GitHub Issues.
+In case of trouble, please check there if your issue has already been reported.
+If you spotted it first, help us smashing it by providing a detailed and welcomed
+feedback.
+
Do not contact contributors directly about support or help with technical issues.
+
+
+
+
+
+
+
+
This module is maintained by the OCA.
+

+
OCA, or the Odoo Community Association, is a nonprofit organization whose
+mission is to support the collaborative development of Odoo features and
+promote its widespread use.
+
This module is part of the OCA/contract project on GitHub.
+
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
+
+
+
+
+
diff --git a/agreement_rebate_partner_company_group/tests/__init__.py b/agreement_rebate_partner_company_group/tests/__init__.py
new file mode 100644
index 0000000000..ffd17a4bc0
--- /dev/null
+++ b/agreement_rebate_partner_company_group/tests/__init__.py
@@ -0,0 +1,3 @@
+# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
+
+from . import test_agreement_rebate
diff --git a/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py b/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py
new file mode 100644
index 0000000000..f9c6ce24a5
--- /dev/null
+++ b/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py
@@ -0,0 +1,45 @@
+# Copyright 2022 Tecnativa - Carlos Dauden
+# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
+
+from odoo.addons.agreement_rebate.tests.test_agreement_rebate import TestAgreementRebate
+
+
+class TestAgreementRebatePartnerCompanyGroup(TestAgreementRebate):
+ def setUp(self):
+ super().setUp()
+ self.Partner = self.env["res.partner"]
+ self.partner_group = self.Partner.create(
+ {"name": "partner test rebate group", "ref": "TST-G01"}
+ )
+ self.partner_member_1 = self.Partner.create(
+ {
+ "name": "partner test rebate member 1",
+ "ref": "TST-M001",
+ "company_group_id": self.partner_group.id,
+ }
+ )
+ self.partner_member_2 = self.Partner.create(
+ {
+ "name": "partner test rebate member 2",
+ "ref": "TST-M002",
+ "company_group_id": self.partner_group.id,
+ }
+ )
+ self.invoice_member_1 = self.create_invoice(self.partner_member_1)
+ self.invoice_member_2 = self.create_invoice(self.partner_member_2)
+
+ def test_create_settlement_wo_filters_global_company_group(self):
+ """ Global rebate without filters apply to all company group members """
+ # Total by invoice: 3800 amount invoiced
+ # 2 invoice members: 3800 * 2 = 7600
+
+ # Global rebate without filters
+ agreement_global = self.create_agreements_rebate("global", self.partner_group)
+ agreement_global.rebate_line_ids = False
+ settlement_wiz = self.create_settlement_wizard(agreement_global)
+ settlements = self.get_settlements_from_action(
+ settlement_wiz.action_create_settlement()
+ )
+ self.assertEqual(len(settlements), 1)
+ self.assertEqual(settlements.amount_invoiced, 7600)
+ self.assertEqual(settlements.amount_rebate, 760)
diff --git a/agreement_rebate_partner_company_group/wizards/__init__.py b/agreement_rebate_partner_company_group/wizards/__init__.py
new file mode 100644
index 0000000000..1c180188ed
--- /dev/null
+++ b/agreement_rebate_partner_company_group/wizards/__init__.py
@@ -0,0 +1,3 @@
+# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
+
+from . import settlement_create
diff --git a/agreement_rebate_partner_company_group/wizards/settlement_create.py b/agreement_rebate_partner_company_group/wizards/settlement_create.py
new file mode 100644
index 0000000000..e12f892b95
--- /dev/null
+++ b/agreement_rebate_partner_company_group/wizards/settlement_create.py
@@ -0,0 +1,23 @@
+# Copyright 2022 Tecnativa - Carlos Dauden
+# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
+
+from odoo import models
+
+
+class AgreementSettlementCreateWiz(models.TransientModel):
+ _inherit = "agreement.settlement.create.wiz"
+
+ def _partner_domain(self, agreement):
+ if not agreement.partner_id.company_group_member_ids:
+ return super()._partner_domain(agreement)
+ # Try replace only child_of part in original domain
+ orig_domain = ("partner_id", "child_of", agreement.partner_id.ids)
+ domain = super()._partner_domain(agreement)
+ pos = 0
+ if orig_domain in domain:
+ pos = domain.index(orig_domain)
+ domain.remove(orig_domain)
+ domain.insert(
+ pos, ("partner_id", "in", agreement.partner_id.company_group_member_ids.ids)
+ )
+ return domain
From aa370ffdec6c4ce74b30a9bb91b3ba4aa80fda7a Mon Sep 17 00:00:00 2001
From: Ernesto Tejeda
Date: Thu, 16 Feb 2023 12:29:00 +0100
Subject: [PATCH 02/10] [IMP] agreement_rebate_partner_company_group: black,
isort, prettier
---
.../tests/test_agreement_rebate.py | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py b/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py
index f9c6ce24a5..0e889594e9 100644
--- a/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py
+++ b/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py
@@ -29,7 +29,7 @@ def setUp(self):
self.invoice_member_2 = self.create_invoice(self.partner_member_2)
def test_create_settlement_wo_filters_global_company_group(self):
- """ Global rebate without filters apply to all company group members """
+ """Global rebate without filters apply to all company group members"""
# Total by invoice: 3800 amount invoiced
# 2 invoice members: 3800 * 2 = 7600
From 598db462f0f7b21d751ebd9ee988d8ca657d6901 Mon Sep 17 00:00:00 2001
From: Ernesto Tejeda
Date: Thu, 16 Feb 2023 12:31:07 +0100
Subject: [PATCH 03/10] [MIG] agreement_rebate_partner_company_group: Migration
to 15.0
[UPD] Update agreement_rebate_partner_company_group.pot
[UPD] README.rst
---
agreement_rebate_partner_company_group/README.rst | 15 ++++++++-------
.../__manifest__.py | 5 ++---
.../agreement_rebate_partner_company_group.pot | 2 +-
.../readme/CONTRIBUTORS.rst | 5 +++--
.../static/description/index.html | 11 ++++++-----
5 files changed, 20 insertions(+), 18 deletions(-)
diff --git a/agreement_rebate_partner_company_group/README.rst b/agreement_rebate_partner_company_group/README.rst
index 37842b906e..2ee83896d0 100644
--- a/agreement_rebate_partner_company_group/README.rst
+++ b/agreement_rebate_partner_company_group/README.rst
@@ -14,13 +14,13 @@ Agreement Rebate Partner Company Group
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fcontract-lightgray.png?logo=github
- :target: https://github.com/OCA/contract/tree/13.0/agreement_rebate_partner_company_group
+ :target: https://github.com/OCA/contract/tree/15.0/agreement_rebate_partner_company_group
:alt: OCA/contract
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
- :target: https://translation.odoo-community.org/projects/contract-13-0/contract-13-0-agreement_rebate_partner_company_group
+ :target: https://translation.odoo-community.org/projects/contract-15-0/contract-15-0-agreement_rebate_partner_company_group
:alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png
- :target: https://runbot.odoo-community.org/runbot/110/13.0
+ :target: https://runbot.odoo-community.org/runbot/110/15.0
:alt: Try me on Runbot
|badge1| |badge2| |badge3| |badge4| |badge5|
@@ -49,7 +49,7 @@ Bug Tracker
Bugs are tracked on `GitHub Issues `_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us smashing it by providing a detailed and welcomed
-`feedback `_.
+`feedback `_.
Do not contact contributors directly about support or help with technical issues.
@@ -66,8 +66,9 @@ Contributors
* `Tecnativa `_:
- * Carlos Dauden
- * Sergio Teruel
+ * Carlos Dauden
+ * Sergio Teruel
+ * Ernesto Tejeda
Maintainers
~~~~~~~~~~~
@@ -82,6 +83,6 @@ OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.
-This module is part of the `OCA/contract `_ project on GitHub.
+This module is part of the `OCA/contract `_ project on GitHub.
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
diff --git a/agreement_rebate_partner_company_group/__manifest__.py b/agreement_rebate_partner_company_group/__manifest__.py
index c89179edbc..c5f589c483 100644
--- a/agreement_rebate_partner_company_group/__manifest__.py
+++ b/agreement_rebate_partner_company_group/__manifest__.py
@@ -4,7 +4,7 @@
{
"name": "Agreement Rebate Partner Company Group",
"summary": "Rebate agreements applied to all company group members",
- "version": "13.0.1.0.0",
+ "version": "15.0.1.0.0",
"development_status": "Beta",
"category": "Contract",
"website": "https://github.com/OCA/contract",
@@ -12,6 +12,5 @@
"license": "AGPL-3",
"application": False,
"installable": True,
- "depends": ["agreement_rebate", "partner_company_group"],
- "data": [],
+ "depends": ["agreement_rebate", "base_partner_company_group"],
}
diff --git a/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot b/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot
index 977cfb9109..fa8714784b 100644
--- a/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot
+++ b/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot
@@ -4,7 +4,7 @@
#
msgid ""
msgstr ""
-"Project-Id-Version: Odoo Server 13.0\n"
+"Project-Id-Version: Odoo Server 15.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: \n"
"Language-Team: \n"
diff --git a/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst b/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst
index 22e2c95561..d2152c8e91 100644
--- a/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst
+++ b/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst
@@ -1,4 +1,5 @@
* `Tecnativa `_:
- * Carlos Dauden
- * Sergio Teruel
+ * Carlos Dauden
+ * Sergio Teruel
+ * Ernesto Tejeda
diff --git a/agreement_rebate_partner_company_group/static/description/index.html b/agreement_rebate_partner_company_group/static/description/index.html
index 6da6d46718..eccfea5ea1 100644
--- a/agreement_rebate_partner_company_group/static/description/index.html
+++ b/agreement_rebate_partner_company_group/static/description/index.html
@@ -367,7 +367,7 @@ Agreement Rebate Partner Company Group
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->
-

+

This module extends the functionality of agreement module to take into
account if agreements affect to all company group members.
Table of contents
@@ -398,7 +398,7 @@
Bugs are tracked on GitHub Issues.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us smashing it by providing a detailed and welcomed
-feedback.
+feedback.
Do not contact contributors directly about support or help with technical issues.
@@ -415,8 +415,9 @@
Tecnativa:
@@ -429,7 +430,7 @@
OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.
-
This module is part of the OCA/contract project on GitHub.
+
This module is part of the OCA/contract project on GitHub.
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
From 438b9b104af6ef26e9ae89f7cd3d0eaadb8956e9 Mon Sep 17 00:00:00 2001
From: Stefan
Date: Tue, 1 Aug 2023 10:10:05 +0200
Subject: [PATCH 04/10] [MIG] agreement_rebate_partner_company_group: Migration
to 16.0
[UPD] Update agreement_rebate_partner_company_group.pot
---
.../README.rst | 24 +++++++++++--------
.../__manifest__.py | 2 +-
...agreement_rebate_partner_company_group.pot | 2 +-
.../readme/CONTRIBUTORS.rst | 1 +
.../static/description/index.html | 13 ++++++----
5 files changed, 25 insertions(+), 17 deletions(-)
diff --git a/agreement_rebate_partner_company_group/README.rst b/agreement_rebate_partner_company_group/README.rst
index 2ee83896d0..014480ce86 100644
--- a/agreement_rebate_partner_company_group/README.rst
+++ b/agreement_rebate_partner_company_group/README.rst
@@ -2,10 +2,13 @@
Agreement Rebate Partner Company Group
======================================
-.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
+..
+ !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
+ !! source digest: sha256:3d865127c9d9249d11a7967f7a99c4cb9c94385beea0143cd082a3ec8fe3ddec
+ !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
:target: https://odoo-community.org/page/development-status
@@ -14,16 +17,16 @@ Agreement Rebate Partner Company Group
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fcontract-lightgray.png?logo=github
- :target: https://github.com/OCA/contract/tree/15.0/agreement_rebate_partner_company_group
+ :target: https://github.com/OCA/contract/tree/16.0/agreement_rebate_partner_company_group
:alt: OCA/contract
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
- :target: https://translation.odoo-community.org/projects/contract-15-0/contract-15-0-agreement_rebate_partner_company_group
+ :target: https://translation.odoo-community.org/projects/contract-16-0/contract-16-0-agreement_rebate_partner_company_group
:alt: Translate me on Weblate
-.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png
- :target: https://runbot.odoo-community.org/runbot/110/15.0
- :alt: Try me on Runbot
+.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
+ :target: https://runboat.odoo-community.org/builds?repo=OCA/contract&target_branch=16.0
+ :alt: Try me on Runboat
-|badge1| |badge2| |badge3| |badge4| |badge5|
+|badge1| |badge2| |badge3| |badge4| |badge5|
This module extends the functionality of agreement module to take into
account if agreements affect to all company group members.
@@ -48,8 +51,8 @@ Bug Tracker
Bugs are tracked on `GitHub Issues `_.
In case of trouble, please check there if your issue has already been reported.
-If you spotted it first, help us smashing it by providing a detailed and welcomed
-`feedback `_.
+If you spotted it first, help us to smash it by providing a detailed and welcomed
+`feedback `_.
Do not contact contributors directly about support or help with technical issues.
@@ -69,6 +72,7 @@ Contributors
* Carlos Dauden
* Sergio Teruel
* Ernesto Tejeda
+ * Stefan Ungureanu
Maintainers
~~~~~~~~~~~
@@ -83,6 +87,6 @@ OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.
-This module is part of the `OCA/contract `_ project on GitHub.
+This module is part of the `OCA/contract `_ project on GitHub.
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
diff --git a/agreement_rebate_partner_company_group/__manifest__.py b/agreement_rebate_partner_company_group/__manifest__.py
index c5f589c483..cc2ce8dfc5 100644
--- a/agreement_rebate_partner_company_group/__manifest__.py
+++ b/agreement_rebate_partner_company_group/__manifest__.py
@@ -4,7 +4,7 @@
{
"name": "Agreement Rebate Partner Company Group",
"summary": "Rebate agreements applied to all company group members",
- "version": "15.0.1.0.0",
+ "version": "16.0.1.0.0",
"development_status": "Beta",
"category": "Contract",
"website": "https://github.com/OCA/contract",
diff --git a/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot b/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot
index fa8714784b..1acfd5deec 100644
--- a/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot
+++ b/agreement_rebate_partner_company_group/i18n/agreement_rebate_partner_company_group.pot
@@ -4,7 +4,7 @@
#
msgid ""
msgstr ""
-"Project-Id-Version: Odoo Server 15.0\n"
+"Project-Id-Version: Odoo Server 16.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: \n"
"Language-Team: \n"
diff --git a/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst b/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst
index d2152c8e91..b4b01f5635 100644
--- a/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst
+++ b/agreement_rebate_partner_company_group/readme/CONTRIBUTORS.rst
@@ -3,3 +3,4 @@
* Carlos Dauden
* Sergio Teruel
* Ernesto Tejeda
+ * Stefan Ungureanu
diff --git a/agreement_rebate_partner_company_group/static/description/index.html b/agreement_rebate_partner_company_group/static/description/index.html
index eccfea5ea1..8d008b74f6 100644
--- a/agreement_rebate_partner_company_group/static/description/index.html
+++ b/agreement_rebate_partner_company_group/static/description/index.html
@@ -3,7 +3,7 @@
-
+
Agreement Rebate Partner Company Group
-
-
Agreement Rebate Partner Company Group
+
+
+
+
+
+
+
Agreement Rebate Partner Company Group
-

+

This module extends the functionality of agreement module to take into
account if agreements affect to all company group members.
Table of contents
@@ -386,7 +391,7 @@
Agreement Rebate Partner Company Group
-
+
To use this module you need to:
- Create an agreement related with a company group partner.
@@ -396,7 +401,7 @@
-
+
Bugs are tracked on GitHub Issues.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
@@ -404,15 +409,15 @@
Do not contact contributors directly about support or help with technical issues.
+
diff --git a/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py b/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py
index 0e889594e9..003887c25d 100644
--- a/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py
+++ b/agreement_rebate_partner_company_group/tests/test_agreement_rebate.py
@@ -1,32 +1,24 @@
# Copyright 2022 Tecnativa - Carlos Dauden
+# Copyright 2025 Tecnativa - Víctor Martínez
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
-from odoo.addons.agreement_rebate.tests.test_agreement_rebate import TestAgreementRebate
+from odoo.tests import tagged
+from odoo.addons.agreement_rebate.tests.test_agreement_rebate import (
+ TestAgreementRebateBase,
+)
-class TestAgreementRebatePartnerCompanyGroup(TestAgreementRebate):
- def setUp(self):
- super().setUp()
- self.Partner = self.env["res.partner"]
- self.partner_group = self.Partner.create(
+
+@tagged("-at_install", "post_install")
+class TestAgreementRebatePartnerCompanyGroup(TestAgreementRebateBase):
+ @classmethod
+ def setUpClass(cls):
+ super().setUpClass()
+ cls.partner_group = cls.env["res.partner"].create(
{"name": "partner test rebate group", "ref": "TST-G01"}
)
- self.partner_member_1 = self.Partner.create(
- {
- "name": "partner test rebate member 1",
- "ref": "TST-M001",
- "company_group_id": self.partner_group.id,
- }
- )
- self.partner_member_2 = self.Partner.create(
- {
- "name": "partner test rebate member 2",
- "ref": "TST-M002",
- "company_group_id": self.partner_group.id,
- }
- )
- self.invoice_member_1 = self.create_invoice(self.partner_member_1)
- self.invoice_member_2 = self.create_invoice(self.partner_member_2)
+ cls.partner_1.company_group_id = cls.partner_group
+ cls.partner_2.company_group_id = cls.partner_group
def test_create_settlement_wo_filters_global_company_group(self):
"""Global rebate without filters apply to all company group members"""
From 54f9ae83c7709436d141b7d70a4fe1a64e7aa306 Mon Sep 17 00:00:00 2001
From: Quentin THEURET
Date: Sun, 4 Jan 2026 06:20:47 +0000
Subject: [PATCH 08/10] Added translation using Weblate (French)
---
.../i18n/fr.po | 22 +++++++++++++++++++
1 file changed, 22 insertions(+)
create mode 100644 agreement_rebate_partner_company_group/i18n/fr.po
diff --git a/agreement_rebate_partner_company_group/i18n/fr.po b/agreement_rebate_partner_company_group/i18n/fr.po
new file mode 100644
index 0000000000..43095b75df
--- /dev/null
+++ b/agreement_rebate_partner_company_group/i18n/fr.po
@@ -0,0 +1,22 @@
+# Translation of Odoo Server.
+# This file contains the translation of the following modules:
+# * agreement_rebate_partner_company_group
+#
+msgid ""
+msgstr ""
+"Project-Id-Version: Odoo Server 18.0\n"
+"Report-Msgid-Bugs-To: \n"
+"PO-Revision-Date: 2026-01-04 08:42+0000\n"
+"Last-Translator: Quentin THEURET \n"
+"Language-Team: none\n"
+"Language: fr\n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: \n"
+"Plural-Forms: nplurals=2; plural=n > 1;\n"
+"X-Generator: Weblate 5.10.4\n"
+
+#. module: agreement_rebate_partner_company_group
+#: model:ir.model,name:agreement_rebate_partner_company_group.model_agreement_settlement_create_wiz
+msgid "Agreement settlement create wizard"
+msgstr "Assistant de création d'accord de règlement"
From b5507e3a0c75556b28a153328b0f57c0dea34a55 Mon Sep 17 00:00:00 2001
From: Maksym Yankin
Date: Fri, 13 Mar 2026 11:47:24 +0200
Subject: [PATCH 09/10] [MIG] agreement_rebate_partner_company_group: Migration
to 19.0
---
agreement_rebate_partner_company_group/README.rst | 10 +++++-----
agreement_rebate_partner_company_group/__manifest__.py | 2 +-
.../static/description/index.html | 6 +++---
3 files changed, 9 insertions(+), 9 deletions(-)
diff --git a/agreement_rebate_partner_company_group/README.rst b/agreement_rebate_partner_company_group/README.rst
index cc311cbb80..1aced2eecc 100644
--- a/agreement_rebate_partner_company_group/README.rst
+++ b/agreement_rebate_partner_company_group/README.rst
@@ -21,13 +21,13 @@ Agreement Rebate Partner Company Group
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fcontract-lightgray.png?logo=github
- :target: https://github.com/OCA/contract/tree/18.0/agreement_rebate_partner_company_group
+ :target: https://github.com/OCA/contract/tree/19.0/agreement_rebate_partner_company_group
:alt: OCA/contract
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
- :target: https://translation.odoo-community.org/projects/contract-18-0/contract-18-0-agreement_rebate_partner_company_group
+ :target: https://translation.odoo-community.org/projects/contract-19-0/contract-19-0-agreement_rebate_partner_company_group
:alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
- :target: https://runboat.odoo-community.org/builds?repo=OCA/contract&target_branch=18.0
+ :target: https://runboat.odoo-community.org/builds?repo=OCA/contract&target_branch=19.0
:alt: Try me on Runboat
|badge1| |badge2| |badge3| |badge4| |badge5|
@@ -56,7 +56,7 @@ Bug Tracker
Bugs are tracked on `GitHub Issues `_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
-`feedback `_.
+`feedback `_.
Do not contact contributors directly about support or help with technical issues.
@@ -91,6 +91,6 @@ OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.
-This module is part of the `OCA/contract `_ project on GitHub.
+This module is part of the `OCA/contract `_ project on GitHub.
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
diff --git a/agreement_rebate_partner_company_group/__manifest__.py b/agreement_rebate_partner_company_group/__manifest__.py
index 17bd2b307b..ee56a4909a 100644
--- a/agreement_rebate_partner_company_group/__manifest__.py
+++ b/agreement_rebate_partner_company_group/__manifest__.py
@@ -4,7 +4,7 @@
{
"name": "Agreement Rebate Partner Company Group",
"summary": "Rebate agreements applied to all company group members",
- "version": "18.0.1.0.0",
+ "version": "19.0.1.0.0",
"development_status": "Beta",
"category": "Contract",
"website": "https://github.com/OCA/contract",
diff --git a/agreement_rebate_partner_company_group/static/description/index.html b/agreement_rebate_partner_company_group/static/description/index.html
index aabd0e5f7d..b1aef8c844 100644
--- a/agreement_rebate_partner_company_group/static/description/index.html
+++ b/agreement_rebate_partner_company_group/static/description/index.html
@@ -374,7 +374,7 @@ Agreement Rebate Partner Company Group
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:f3e97d58253f03b1da7857a63526e03fa23597ffe1798156f871ddd5a3c0b653
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->
-

+

This module extends the functionality of agreement module to take into
account if agreements affect to all company group members.
Table of contents
@@ -405,7 +405,7 @@
Bugs are tracked on GitHub Issues.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
-feedback.
+feedback.
Do not contact contributors directly about support or help with technical issues.
@@ -440,7 +440,7 @@
OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.
-
This module is part of the OCA/contract project on GitHub.
+
This module is part of the OCA/contract project on GitHub.
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
From efc5d236791930d6737355c0edc9a7f7fd3a6524 Mon Sep 17 00:00:00 2001
From: Maksym Yankin
Date: Fri, 13 Mar 2026 11:49:45 +0200
Subject: [PATCH 10/10] dont merge test requirements
---
test-requirements.txt | 2 ++
1 file changed, 2 insertions(+)
create mode 100644 test-requirements.txt
diff --git a/test-requirements.txt b/test-requirements.txt
new file mode 100644
index 0000000000..cb2467585a
--- /dev/null
+++ b/test-requirements.txt
@@ -0,0 +1,2 @@
+odoo-addon-agreement @ git+https://github.com/OCA/agreement.git@refs/pull/99/head#subdirectory=agreement
+odoo-addon-agreement_rebate @ git+https://github.com/OCA/agreement.git@refs/pull/108/head#subdirectory=agreement_rebate