2
0

[ADD][account_asset_management] Add check on account move line

This commit is contained in:
Adrien Peiffer (ACSONE) 2015-06-02 11:57:59 +02:00 committed by Rodrigo
parent 16d05b1397
commit 08c4e9d457

View File

@ -29,6 +29,10 @@ _logger = logging.getLogger(__name__)
# List of move's fields that can't be modified if move is linked # List of move's fields that can't be modified if move is linked
# with a depreciation line # with a depreciation line
FIELDS_AFFECTS_ASSET_MOVE = set(['period_id', 'journal_id', 'date']) FIELDS_AFFECTS_ASSET_MOVE = set(['period_id', 'journal_id', 'date'])
# List of move line's fields that can't be modified if move is linked
# with a depreciation line
FIELDS_AFFECTS_ASSET_MOVE_LINE = \
set(['credit', 'debit', 'account_id', 'journal_id', 'date'])
class account_move(orm.Model): class account_move(orm.Model):
@ -128,6 +132,13 @@ class account_move_line(orm.Model):
def write(self, cr, uid, ids, vals, def write(self, cr, uid, ids, vals,
context=None, check=True, update_check=True): context=None, check=True, update_check=True):
for move_line in self.browse(cr, uid, ids, context=context):
if move_line.asset_id.id:
if set(vals).intersection(FIELDS_AFFECTS_ASSET_MOVE_LINE):
raise orm.except_orm(
_('Error!'),
_("You cannot change an accounting item "
"linked to an asset depreciation line."))
if vals.get('asset_id'): if vals.get('asset_id'):
raise orm.except_orm( raise orm.except_orm(
_('Error!'), _('Error!'),