2
0

Included PR #828 Fix computation of depreciation lines when having multiple assets in invoice

This commit is contained in:
Maxence Groine 2019-05-24 08:48:58 +02:00 committed by Rodrigo
parent 08907b0b1d
commit 9ff14512da
3 changed files with 23 additions and 15 deletions

View File

@ -72,19 +72,26 @@ class AccountAssetLine(models.Model):
dlines = dlines.filtered(lambda l: l.type == 'depreciate') dlines = dlines.filtered(lambda l: l.type == 'depreciate')
dlines = dlines.sorted(key=lambda l: l.line_date) dlines = dlines.sorted(key=lambda l: l.line_date)
for i, dl in enumerate(dlines): # Group depreciation lines per asset
if i == 0: asset_ids = dlines.mapped('asset_id')
depreciation_base = dl.depreciation_base grouped_dlines = []
depreciated_value = dl.previous_id \ for asset in asset_ids:
and (depreciation_base - dl.previous_id.remaining_value) \ grouped_dlines.append(
or 0.0 dlines.filtered(lambda l: l.asset_id.id == asset.id))
remaining_value = \
depreciation_base - depreciated_value - dl.amount for dlines in grouped_dlines:
else: for i, dl in enumerate(dlines):
depreciated_value += dl.previous_id.amount if i == 0:
remaining_value -= dl.amount depreciation_base = dl.depreciation_base
dl.depreciated_value = depreciated_value tmp = depreciation_base - dl.previous_id.remaining_value
dl.remaining_value = remaining_value depreciated_value = dl.previous_id and tmp or 0.0
remaining_value = \
depreciation_base - depreciated_value - dl.amount
else:
depreciated_value += dl.previous_id.amount
remaining_value -= dl.amount
dl.depreciated_value = depreciated_value
dl.remaining_value = remaining_value
@api.depends('move_id') @api.depends('move_id')
@api.multi @api.multi

View File

@ -5,4 +5,5 @@
- Stéphane Bidoul (Acsone) - Stéphane Bidoul (Acsone)
- Adrien Peiffer (Acsone) - Adrien Peiffer (Acsone)
- Akim Juillerat <akim.juillerat@camptocamp.com> - Akim Juillerat <akim.juillerat@camptocamp.com>
- Henrik Norlin (Apps2GROW) - Henrik Norlin (Apps2GROW)
- Maxence Groine <mgroine@fiefmanage.ch>

View File

@ -101,7 +101,7 @@ class TestAssetManagement(SavepointCase):
'account_id': cls.account_payable.id, 'account_id': cls.account_payable.id,
'price_unit': 20000.00, 'price_unit': 20000.00,
'quantity': 1, 'quantity': 1,
'product_id': cls.product_id}) 'product_id': cls.product.id})
cls.invoice_2 = cls.account_invoice.create({ cls.invoice_2 = cls.account_invoice.create({
'partner_id': cls.partner.id, 'partner_id': cls.partner.id,