You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

60 lines
2.0 KiB

# Copyright (C) 2017 - Today: GRAP (http://www.grap.coop)
# @author: Sylvain LE GAL (https://twitter.com/legalsylvain)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo import api, fields, models
import odoo.addons.decimal_precision as dp
class PosOrderLine(models.Model):
_inherit = 'pos.order.line'
# Columns Section
margin = fields.Float(
string='Margin',
compute='_compute_multi_margin',
store=True,
digits=dp.get_precision('Product Price'),
)
margin_percent = fields.Float(
string='Margin (%)',
compute='_compute_multi_margin',
store=True,
digits=dp.get_precision('Product Price'),
)
purchase_price = fields.Float(
string='Cost Price',
compute='_compute_multi_margin',
store=True,
digits=dp.get_precision('Product Price'),
)
# Compute Section
@api.multi
@api.depends('product_id', 'qty', 'price_subtotal')
def _compute_multi_margin(self):
for line in self.filtered('product_id'):
purchase_price = self._get_purchase_price(line)
margin = line.price_subtotal - (purchase_price * line.qty)
line.update({
'purchase_price': purchase_price,
'margin': margin,
'margin_percent': line.price_subtotal and (
margin / line.price_subtotal * 100.0),
})
@api.model
def _get_purchase_price(self, line):
# We call _get_purchase_price from sale_margin module, to reuse
# computation that handles multi currencies context and UoM
SaleOrderLine = self.env['sale.order.line']
# if used in combination with module which does add the uom_id to line
uom = hasattr(line, 'uom_id') and line.uom_id\
or line.product_id.uom_id
return SaleOrderLine._get_purchase_price(
line.order_id.pricelist_id, line.product_id, uom,
line.order_id.date_order)['purchase_price']