Maintainers
+Maintainers
This module is maintained by the OCA.
OCA, or the Odoo Community Association, is a nonprofit organization whose
diff --git a/procurement_purchase_no_grouping/README.rst b/procurement_purchase_no_grouping/README.rst index 5c8c6b444b3..10b7f7ce51d 100644 --- a/procurement_purchase_no_grouping/README.rst +++ b/procurement_purchase_no_grouping/README.rst @@ -52,6 +52,14 @@ Go to each product category, and select one of these values in the field System default behaviour can be set up in System settings / Purchase / Procurement Purchase Grouping +Known issues / Roadmap +====================== + +- If you reuse the same procurement group between several sales orders, and + using "No line grouping", they will be grouped anyways, as the criteria for + grouping or not should be kept to the same procurement group, as it's the only + way to get proper quantities updates after confirming the sales order. + Bug Tracker =========== diff --git a/procurement_purchase_no_grouping/__manifest__.py b/procurement_purchase_no_grouping/__manifest__.py index db069e664b1..b82e1c084a2 100644 --- a/procurement_purchase_no_grouping/__manifest__.py +++ b/procurement_purchase_no_grouping/__manifest__.py @@ -5,7 +5,7 @@ { "name": "Procurement Purchase No Grouping", - "version": "14.0.1.0.0", + "version": "14.0.1.0.1", "author": "AvanzOSC, Tecnativa, Odoo Community Association (OCA)", "website": "https://github.com/OCA/purchase-workflow", "category": "Procurements", diff --git a/procurement_purchase_no_grouping/models/purchase_order.py b/procurement_purchase_no_grouping/models/purchase_order.py index 427d6afba1c..4057a6f1f20 100644 --- a/procurement_purchase_no_grouping/models/purchase_order.py +++ b/procurement_purchase_no_grouping/models/purchase_order.py @@ -1,6 +1,6 @@ # Copyright 2015 AvanzOsc (http://www.avanzosc.es) -# Copyright 2015-2016 Tecnativa - Pedro M. Baeza # Copyright 2018 Tecnativa - Carlos Dauden +# Copyright 2015-2021 Tecnativa - Pedro M. Baeza # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl) from odoo import models @@ -20,9 +20,19 @@ def _find_candidate( company_id, values, ): + """If not grouping by line, we should make an exception when you update an + existing sales order line, so we filter a bit more by procurement group. + + NOTE: This makes that if you manually assign the same procurement group to + several different sales orders, the grouping will be done no matter the grouping + criteria, but this is the only way to do it without having to put a lot of glue + modules, and on standard operation mode, procurement groups are not reused + between sales orders. + """ + obj = self if values.get("grouping") == "line": - return False - return super()._find_candidate( + obj = self.filtered(lambda x: x.order_id.group_id == values.get("group_id")) + return super(PurchaseOrderLine, obj)._find_candidate( product_id, product_qty, product_uom, diff --git a/procurement_purchase_no_grouping/readme/ROADMAP.rst b/procurement_purchase_no_grouping/readme/ROADMAP.rst new file mode 100644 index 00000000000..2cffa937137 --- /dev/null +++ b/procurement_purchase_no_grouping/readme/ROADMAP.rst @@ -0,0 +1,4 @@ +- If you reuse the same procurement group between several sales orders, and + using "No line grouping", they will be grouped anyways, as the criteria for + grouping or not should be kept to the same procurement group, as it's the only + way to get proper quantities updates after confirming the sales order. diff --git a/procurement_purchase_no_grouping/static/description/index.html b/procurement_purchase_no_grouping/static/description/index.html index 55b322fcfa5..7a5a25edebb 100644 --- a/procurement_purchase_no_grouping/static/description/index.html +++ b/procurement_purchase_no_grouping/static/description/index.html @@ -375,11 +375,12 @@
System default behaviour can be set up in System settings / Purchase / Procurement Purchase Grouping
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 @@ -410,16 +420,16 @@
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