2018-01-16 11:28:15 +05:30
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
2018-01-16 02:34:37 -08:00
|
|
|
from flectra import models, fields, api, _
|
|
|
|
from flectra.tools import float_round
|
2018-01-16 11:28:15 +05:30
|
|
|
|
|
|
|
|
|
|
|
class AccountCashRounding(models.Model):
|
|
|
|
"""
|
|
|
|
In some countries, we need to be able to make appear on an invoice a rounding line, appearing there only because the
|
|
|
|
smallest coinage has been removed from the circulation. For example, in Switerzland invoices have to be rounded to
|
|
|
|
0.05 CHF because coins of 0.01 CHF and 0.02 CHF aren't used anymore.
|
|
|
|
see https://en.wikipedia.org/wiki/Cash_rounding for more details.
|
|
|
|
"""
|
|
|
|
_name = 'account.cash.rounding'
|
|
|
|
_description = 'Account Rounding'
|
|
|
|
|
|
|
|
name = fields.Char(string='Name', translate=True, required=True)
|
|
|
|
rounding = fields.Float(string='Rounding Precision', required=True,
|
|
|
|
help='Represent the non-zero value smallest coinage (for example, 0.05).')
|
|
|
|
strategy = fields.Selection([('biggest_tax', 'Modify tax amount'), ('add_invoice_line', 'Add a rounding line')],
|
|
|
|
string='Rounding Strategy', default='add_invoice_line', required=True,
|
|
|
|
help='Specify which way will be used to round the invoice amount to the rounding precision')
|
|
|
|
account_id = fields.Many2one('account.account', string='Account')
|
|
|
|
rounding_method = fields.Selection(string='Rounding Method', required=True,
|
|
|
|
selection=[('UP', 'UP'), ('DOWN', 'DOWN'), ('HALF-UP', 'HALF-UP')],
|
|
|
|
default='HALF-UP', help='The tie-breaking rule used for float rounding operations')
|
|
|
|
|
|
|
|
@api.multi
|
|
|
|
def round(self, amount):
|
|
|
|
"""Compute the rounding on the amount passed as parameter.
|
|
|
|
|
|
|
|
:param amount: the amount to round
|
|
|
|
:return: the rounded amount depending the rounding value and the rounding method
|
|
|
|
"""
|
|
|
|
return float_round(amount, precision_rounding=self.rounding, rounding_method=self.rounding_method)
|
|
|
|
|
|
|
|
@api.multi
|
|
|
|
def compute_difference(self, currency, amount):
|
|
|
|
"""Compute the difference between the base_amount and the amount after rounding.
|
|
|
|
For example, base_amount=23.91, after rounding=24.00, the result will be 0.09.
|
|
|
|
|
|
|
|
:param currency: The currency.
|
|
|
|
:param amount: The amount
|
|
|
|
:return: round(difference)
|
|
|
|
"""
|
|
|
|
difference = self.round(amount) - amount
|
|
|
|
return currency.round(difference)
|