From 1a69567fdf7f197fa0f72b51c360a6cf980098d8 Mon Sep 17 00:00:00 2001 From: Mourad Date: Tue, 23 Mar 2021 17:03:52 +0100 Subject: [PATCH] [FIX] compute price error if product not set --- sale_usability/models/sale_order.py | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/sale_usability/models/sale_order.py b/sale_usability/models/sale_order.py index 2073f7c..93a72d9 100644 --- a/sale_usability/models/sale_order.py +++ b/sale_usability/models/sale_order.py @@ -75,14 +75,16 @@ class SaleOrderLine(models.Model): res = {} old_price = self.price_unit super().product_uom_change() - product_context = dict(self.env.context, - partner_id=self.order_id.partner_id.id, - date=self.order_id.date_order, - uom=self.product_uom.id) - price, rule_id = self.order_id.pricelist_id.with_context( - product_context).get_product_price_rule(self.product_id, self.product_uom_qty or 1.0, self.order_id.partner_id) - pricelist_item = PricelistItem.browse(rule_id) new_price = self.price_unit + pricelist_item = PricelistItem.browse(False) + if self.product_id: + product_context = dict(self.env.context, + partner_id=self.order_id.partner_id.id, + date=self.order_id.date_order, + uom=self.product_uom.id) + price, rule_id = self.order_id.pricelist_id.with_context( + product_context).get_product_price_rule(self.product_id, self.product_uom_qty or 1.0, self.order_id.partner_id) + pricelist_item = PricelistItem.browse(rule_id) prec = self.env['decimal.precision'].precision_get('Product Price') if pricelist_item.base != 'supplierinfo' and float_compare(old_price, new_price, precision_digits=prec): pricelist = self.order_id.pricelist_id