You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

53 lines
1.8 KiB

  1. # -*- coding: utf-8 -*-
  2. # Copyright 2018 Camptocamp SA
  3. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
  4. from odoo import models, fields, api, _
  5. from odoo.exceptions import ValidationError
  6. class AccountBankStatementLineReconciliationWizard(models.TransientModel):
  7. _name = "account.bank.statement.line.reconciliation.wizard"
  8. statement_line_ids = fields.Many2many(
  9. string='Current values',
  10. comodel_name='account.bank.statement.line',
  11. compute='_compute_statement_line_ids',
  12. )
  13. new_statement_line_id = fields.Many2one(
  14. string='New value',
  15. comodel_name='account.bank.statement.line',
  16. )
  17. def _account_move_ids(self):
  18. ids = self._context.get('active_ids')
  19. account_move_ids = self.env['account.move']
  20. if ids:
  21. account_move_ids = account_move_ids.browse(ids)
  22. journal_ids = account_move_ids.mapped('journal_id')
  23. if len(account_move_ids) > 1 and len(journal_ids) > 1:
  24. msg = _("Please only select Journal entries "
  25. "that belongs to the same bank journal")
  26. raise ValidationError(msg)
  27. return account_move_ids
  28. def _compute_statement_line_ids(self):
  29. for record in self:
  30. account_move_ids = record._account_move_ids()
  31. record.statement_line_ids = [
  32. (6, 0, account_move_ids.mapped('statement_line_id').ids),
  33. ]
  34. @api.multi
  35. def set_new_statement_line_value(self):
  36. account_move_ids = self._account_move_ids()
  37. account_move_ids.write({
  38. 'statement_line_id': self.new_statement_line_id.id,
  39. })
  40. account_move_ids.mapped("line_ids").write({
  41. 'statement_id': self.new_statement_line_id.statement_id.id,
  42. })
  43. return {}