mirror of
https://github.com/OCA/contract.git
synced 2025-02-13 17:57:24 +02:00
[ADD] contract_price_revision: new module to update contract prices easily
This commit is contained in:
2
contract_price_revision/models/__init__.py
Normal file
2
contract_price_revision/models/__init__.py
Normal file
@@ -0,0 +1,2 @@
|
||||
from . import account_analytic_account
|
||||
from . import account_analytic_invoice_line
|
||||
17
contract_price_revision/models/account_analytic_account.py
Normal file
17
contract_price_revision/models/account_analytic_account.py
Normal file
@@ -0,0 +1,17 @@
|
||||
# Copyright 2019 Tecnativa <vicent.cubells@tecnativa.com>
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||
from odoo import api, models
|
||||
|
||||
|
||||
class AccountAnalyticAccount(models.Model):
|
||||
_inherit = "account.analytic.account"
|
||||
|
||||
@api.model
|
||||
def _prepare_invoice_line(self, line, invoice_id):
|
||||
line_obj = self.env['account.invoice.line']
|
||||
invoice = self.env['account.invoice'].browse(invoice_id)
|
||||
# Line with automatic price are not taken into account
|
||||
if (line.date_start and invoice.date_invoice < line.date_start) or \
|
||||
(line.date_end and invoice.date_invoice > line.date_end):
|
||||
return line_obj
|
||||
return super()._prepare_invoice_line(line, invoice_id)
|
||||
@@ -0,0 +1,39 @@
|
||||
# Copyright 2019 Tecnativa <vicent.cubells@tecnativa.com>
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||
from odoo import api, fields, models
|
||||
import odoo.addons.decimal_precision as dp
|
||||
|
||||
|
||||
class AccountAnalyticINvoiceLine(models.Model):
|
||||
_inherit = "account.analytic.invoice.line"
|
||||
|
||||
date_start = fields.Date(
|
||||
string='Start Date',
|
||||
)
|
||||
date_end = fields.Date(
|
||||
string='End Date',
|
||||
)
|
||||
previous_revision_id = fields.Many2one(
|
||||
comodel_name='account.analytic.invoice.line',
|
||||
string='Previous revision',
|
||||
help='Relation with previous revision',
|
||||
)
|
||||
previous_price = fields.Float(
|
||||
related='previous_revision_id.price_unit',
|
||||
readonly=True,
|
||||
)
|
||||
variation_percent = fields.Float(
|
||||
compute='_compute_variation_percent',
|
||||
store=True,
|
||||
digits=dp.get_precision('Product Price'),
|
||||
string='Variation %',
|
||||
)
|
||||
|
||||
@api.multi
|
||||
@api.depends('price_unit', 'previous_revision_id.price_unit')
|
||||
def _compute_variation_percent(self):
|
||||
for line in self:
|
||||
if not (line.price_unit and line.previous_price):
|
||||
continue
|
||||
line.variation_percent = (
|
||||
(line.price_unit / line.previous_price - 1) * 100)
|
||||
Reference in New Issue
Block a user