|
@ -26,13 +26,17 @@ class BeesdooProduct(models.Model): |
|
|
|
|
|
|
|
|
# S0023 : List_price = Price HTVA, so add a suggested price |
|
|
# S0023 : List_price = Price HTVA, so add a suggested price |
|
|
list_price = fields.Float(string='exVAT Price') |
|
|
list_price = fields.Float(string='exVAT Price') |
|
|
suggested_price = fields.Float(string='Suggested Price', compute='_get_suggested_price', readOnly = True) |
|
|
|
|
|
|
|
|
suggested_price = fields.Float(string='Suggested Price', compute='_compute_cost', readOnly=True) |
|
|
|
|
|
standard_price = fields.Float(compute='_compute_cost') |
|
|
|
|
|
|
|
|
|
|
|
def _get_main_supplier_info(self): |
|
|
|
|
|
return self.seller_ids.sorted(key=lambda seller: seller.date_start, reverse=True) |
|
|
|
|
|
|
|
|
@api.one |
|
|
@api.one |
|
|
@api.depends('seller_ids', 'seller_ids.date_start') |
|
|
@api.depends('seller_ids', 'seller_ids.date_start') |
|
|
def _compute_main_seller_id(self): |
|
|
def _compute_main_seller_id(self): |
|
|
# Calcule le vendeur associé qui a la date de début la plus récente et plus petite qu’aujourd’hui |
|
|
# Calcule le vendeur associé qui a la date de début la plus récente et plus petite qu’aujourd’hui |
|
|
sellers_ids = self.seller_ids.sorted(key=lambda seller: seller.date_start, reverse=True) |
|
|
|
|
|
|
|
|
sellers_ids = self._get_main_supplier_info() # self.seller_ids.sorted(key=lambda seller: seller.date_start, reverse=True) |
|
|
self.main_seller_id = sellers_ids and sellers_ids[0].name or False |
|
|
self.main_seller_id = sellers_ids and sellers_ids[0].name or False |
|
|
|
|
|
|
|
|
@api.one |
|
|
@api.one |
|
@ -57,9 +61,14 @@ class BeesdooProduct(models.Model): |
|
|
raise UserError(_('Reference Unit and Display Unit should belong to the same category')) |
|
|
raise UserError(_('Reference Unit and Display Unit should belong to the same category')) |
|
|
|
|
|
|
|
|
@api.one |
|
|
@api.one |
|
|
@api.depends('list_price') |
|
|
|
|
|
def _get_suggested_price(self): |
|
|
|
|
|
self.suggested_price = 1000.0 |
|
|
|
|
|
|
|
|
@api.depends('seller_ids') |
|
|
|
|
|
def _compute_cost(self): |
|
|
|
|
|
suppliers = self._get_main_supplier_info() |
|
|
|
|
|
if(len(suppliers) > 0): |
|
|
|
|
|
self.standard_price = suppliers[0].price |
|
|
|
|
|
self.suggested_price = (suppliers[0].price)* (1 + suppliers[0].product_tmpl_id.categ_id.profit_margin / 100) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class BeesdooProductLabel(models.Model): |
|
|
class BeesdooProductLabel(models.Model): |
|
|
_name = "beesdoo.product.label" |
|
|
_name = "beesdoo.product.label" |
|
@ -68,3 +77,14 @@ class BeesdooProductLabel(models.Model): |
|
|
type = fields.Selection([('eco', 'Écologique'), ('local', 'Local'), ('fair', 'Équitable'), ('delivery', 'Distribution')]) |
|
|
type = fields.Selection([('eco', 'Écologique'), ('local', 'Local'), ('fair', 'Équitable'), ('delivery', 'Distribution')]) |
|
|
color_code = fields.Char() |
|
|
color_code = fields.Char() |
|
|
|
|
|
|
|
|
|
|
|
class BeesdooProductCategory(models.Model): |
|
|
|
|
|
_inherit = "product.category" |
|
|
|
|
|
|
|
|
|
|
|
profit_margin = fields.Float(default = '10.0', string = "Product Margin [%]") |
|
|
|
|
|
|
|
|
|
|
|
@api.one |
|
|
|
|
|
@api.constrains('profit_margin') |
|
|
|
|
|
def _check_margin(self): |
|
|
|
|
|
if (self.profit_margin < 0.0): |
|
|
|
|
|
raise UserError(_('Percentages for Profit Margin must > 0.')) |
|
|
|
|
|
|