From 953f37da188ac6c62c2120b2a271ea6716e742bf Mon Sep 17 00:00:00 2001 From: FrankC013 Date: Tue, 16 Jan 2024 18:07:38 +0100 Subject: [PATCH] [IMP] connector_oxigesti: allow delete items if the user is not a manager & avoid problems if you delete the pricelist --- .../models/product_pricelist_item/binding.py | 18 ++++++++++++++++++ .../models/product_pricelist_item/listener.py | 2 +- 2 files changed, 19 insertions(+), 1 deletion(-) diff --git a/connector_oxigesti/models/product_pricelist_item/binding.py b/connector_oxigesti/models/product_pricelist_item/binding.py index 0d16a1ea5..c1db6410f 100644 --- a/connector_oxigesti/models/product_pricelist_item/binding.py +++ b/connector_oxigesti/models/product_pricelist_item/binding.py @@ -7,6 +7,24 @@ from odoo.exceptions import ValidationError +class Pricelist(models.Model): + _inherit = "product.pricelist" + + # TODO: Review use deleter to mark items as deprecated + def unlink(self): + for rec in self: + if rec.item_ids.oxigesti_bind_ids: + raise ValidationError( + _( + "You can't delete a pricelist that has been exported " + "the product prices by customer to Oxigesti. If you " + "want to delete it, you must first delete the items " + "of the pricelist." + ) + ) + return super().unlink() + + class ProductPricelistItem(models.Model): _inherit = "product.pricelist.item" diff --git a/connector_oxigesti/models/product_pricelist_item/listener.py b/connector_oxigesti/models/product_pricelist_item/listener.py index 93a032bf7..d45e55080 100644 --- a/connector_oxigesti/models/product_pricelist_item/listener.py +++ b/connector_oxigesti/models/product_pricelist_item/listener.py @@ -11,7 +11,7 @@ class ProductPricelistItemListener(Component): _apply_on = "product.pricelist.item" def on_record_unlink(self, relation): - bindings = relation.oxigesti_bind_ids + bindings = relation.sudo().oxigesti_bind_ids for backend in bindings.with_context( pricelist_item_unlink=relation.id ).backend_id: