trytond-sale_margin/sale.py

95 lines
3.2 KiB
Python
Raw Normal View History

2012-07-24 11:56:39 +02:00
#This file is part sale_margin module for Tryton.
#The COPYRIGHT file at the top level of this repository contains
#the full copyright notices and license terms.
from decimal import Decimal
2012-10-16 17:10:24 +02:00
from trytond.model import fields
2012-07-24 11:56:39 +02:00
from trytond.pyson import Eval
2012-10-16 17:10:24 +02:00
from trytond.pool import Pool, PoolMeta
2012-07-24 11:56:39 +02:00
2012-10-16 17:10:24 +02:00
__all__ = ['Sale', 'SaleLine']
__metaclass__ = PoolMeta
2014-01-17 13:45:34 +01:00
2012-10-16 17:10:24 +02:00
class Sale:
__name__ = 'sale.sale'
2012-07-24 11:56:39 +02:00
margin = fields.Function(fields.Numeric('Margin',
digits=(16, Eval('currency_digits', 2),),
depends=['currency_digits'],
help='It gives profitability by calculating the difference '
'between the Unit Price and Cost Price.'),
'get_margin')
margin_cache = fields.Numeric('Margin Cache',
digits=(16, Eval('currency_digits', 2)),
readonly=True,
depends=['currency_digits'])
2012-10-16 17:10:24 +02:00
def get_margin(self, name):
2012-07-24 11:56:39 +02:00
'''
Return the margin of each sales
'''
2012-10-16 17:10:24 +02:00
Currency = Pool().get('currency.currency')
if (self.state in self._states_cached
and self.margin_cache is not None):
return self.margin_cache
margin = sum((l.margin for l in self.lines if l.type == 'line'),
Decimal(0))
return Currency.round(self.currency, margin)
2012-07-24 11:56:39 +02:00
2012-10-16 17:10:24 +02:00
@classmethod
def store_cache(cls, sales):
for sale in sales:
cls.write([sale], {
2012-07-24 11:56:39 +02:00
'untaxed_amount_cache': sale.untaxed_amount,
'tax_amount_cache': sale.tax_amount,
'total_amount_cache': sale.total_amount,
'margin_cache': sale.margin,
})
2012-10-16 17:10:24 +02:00
class SaleLine:
__name__ = 'sale.line'
2012-07-24 11:56:39 +02:00
cost_price = fields.Numeric('Cost Price', digits=(16, 4),
states={
'invisible': Eval('type') != 'line',
}, depends=['type'])
margin = fields.Function(fields.Numeric('Margin',
digits=(16, Eval('_parent_sale', {}).get('currency_digits', 2)),
states={
'invisible': ~Eval('type').in_(['line', 'subtotal']),
'readonly': ~Eval('_parent_sale'),
},
depends=['type', 'amount']), 'get_margin')
2012-07-24 11:56:39 +02:00
2013-10-04 10:57:14 +02:00
@staticmethod
def default_cost_price():
return Decimal('0.0')
@fields.depends('product')
2012-10-16 17:10:24 +02:00
def on_change_product(self):
if not self.product:
2012-07-24 11:56:39 +02:00
return {}
2012-10-16 17:10:24 +02:00
res = super(SaleLine, self).on_change_product()
res['cost_price'] = self.product.cost_price
2012-07-24 11:56:39 +02:00
return res
@fields.depends('type', 'quantity', 'cost_price', 'amount', 'unit_price',
'unit', '_parent_sale.currency')
2012-10-16 17:10:24 +02:00
def on_change_with_margin(self):
cost = Decimal(str(self.quantity or '0.0')) * \
(self.cost_price or Decimal('0.0'))
if self.amount:
return Decimal(self.amount-cost)
return Decimal('0.0')
2012-07-24 11:56:39 +02:00
2012-10-16 17:10:24 +02:00
def get_margin(self, name):
2012-07-24 11:56:39 +02:00
'''
Return the margin of each sale lines
'''
2012-10-16 17:10:24 +02:00
Currency = Pool().get('currency.currency')
if self.type == 'line':
2013-10-01 18:01:00 +02:00
cost = Decimal(str(self.quantity)) * (self.cost_price or Decimal('0.0'))
return Currency.round(self.sale.currency, self.amount - cost)
2012-10-16 17:10:24 +02:00
else:
return Decimal('0.0')