[MIG] purchase_usability to v16
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
# Copyright 2015-2020 Akretion France (http://www.akretion.com)
|
||||
# Copyright 2015-2022 Akretion France (http://www.akretion.com)
|
||||
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||
|
||||
@@ -85,7 +85,7 @@ class PurchaseOrderLine(models.Model):
|
||||
partner_id = line.order_id.partner_id.commercial_partner_id.id
|
||||
if partner_id:
|
||||
for supplier_info in line.product_id.seller_ids:
|
||||
if supplier_info.name.id == partner_id:
|
||||
if supplier_info.partner_id.id == partner_id:
|
||||
code = supplier_info.product_code
|
||||
break
|
||||
line.product_supplier_code = code
|
||||
@@ -101,40 +101,41 @@ class PurchaseOrderLine(models.Model):
|
||||
product_lang = product_lang.with_context(display_default_code=False)
|
||||
return super()._get_product_purchase_description(product_lang)
|
||||
|
||||
@api.onchange('product_qty', 'product_uom')
|
||||
def _onchange_quantity(self):
|
||||
# TODO see how we could restore this feature
|
||||
# @api.onchange('product_qty', 'product_uom')
|
||||
# def _onchange_quantity(self):
|
||||
# When the user has manually set a price and/or planned_date
|
||||
# he is often upset when Odoo changes it when he changes the qty
|
||||
# So we add a warning...
|
||||
res = {}
|
||||
old_price = self.price_unit
|
||||
old_date_planned = self.date_planned
|
||||
super()._onchange_quantity()
|
||||
new_price = self.price_unit
|
||||
new_date_planned = self.date_planned
|
||||
prec = self.env['decimal.precision'].precision_get('Product Price')
|
||||
price_compare = float_compare(old_price, new_price, precision_digits=prec)
|
||||
if price_compare or old_date_planned != new_date_planned:
|
||||
res['warning'] = {
|
||||
'title': _('Updates'),
|
||||
'message': _(
|
||||
"Due to the update of the ordered quantity on line '%s', "
|
||||
"the following data has been updated using the supplier info "
|
||||
"of the product:"
|
||||
) % self.name
|
||||
}
|
||||
if price_compare:
|
||||
res['warning']['message'] += _(
|
||||
"\nOld price: %s\nNew price: %s") % (
|
||||
format_amount(
|
||||
self.env, old_price, self.order_id.currency_id),
|
||||
format_amount(
|
||||
self.env, new_price, self.order_id.currency_id))
|
||||
# res = {}
|
||||
# old_price = self.price_unit
|
||||
# old_date_planned = self.date_planned
|
||||
# super()._onchange_quantity()
|
||||
# new_price = self.price_unit
|
||||
# new_date_planned = self.date_planned
|
||||
# prec = self.env['decimal.precision'].precision_get('Product Price')
|
||||
# price_compare = float_compare(old_price, new_price, precision_digits=prec)
|
||||
# if price_compare or old_date_planned != new_date_planned:
|
||||
# res['warning'] = {
|
||||
# 'title': _('Updates'),
|
||||
# 'message': _(
|
||||
# "Due to the update of the ordered quantity on line '%s', "
|
||||
# "the following data has been updated using the supplier info "
|
||||
# "of the product:"
|
||||
# ) % self.name
|
||||
# }
|
||||
# if price_compare:
|
||||
# res['warning']['message'] += _(
|
||||
# "\nOld price: %s\nNew price: %s") % (
|
||||
# format_amount(
|
||||
# self.env, old_price, self.order_id.currency_id),
|
||||
# format_amount(
|
||||
# self.env, new_price, self.order_id.currency_id))
|
||||
|
||||
if old_date_planned != new_date_planned:
|
||||
res['warning']['message'] += _(
|
||||
"\nOld delivery date: %s\nNew delivery date: %s") % (
|
||||
format_datetime(self.env, old_date_planned),
|
||||
format_datetime(self.env, new_date_planned),
|
||||
)
|
||||
return res
|
||||
# if old_date_planned != new_date_planned:
|
||||
# res['warning']['message'] += _(
|
||||
# "\nOld delivery date: %s\nNew delivery date: %s") % (
|
||||
# format_datetime(self.env, old_date_planned),
|
||||
# format_datetime(self.env, new_date_planned),
|
||||
# )
|
||||
# return res
|
||||
|
||||
Reference in New Issue
Block a user