Odoo18-Base/addons/account/wizard/account_move_send_batch_wizard.py

104 lines
4.2 KiB
Python
Raw Permalink Normal View History

2025-01-06 10:57:38 +07:00
from collections import Counter
from odoo import _, api, Command, fields, models
class AccountMoveSendBatchWizard(models.TransientModel):
"""Wizard that handles the sending of multiple invoices."""
_name = 'account.move.send.batch.wizard'
_inherit = ['account.move.send']
_description = "Account Move Send Batch Wizard"
move_ids = fields.Many2many(comodel_name='account.move', required=True)
summary_data = fields.Json(compute='_compute_summary_data')
alerts = fields.Json(compute='_compute_alerts')
# -------------------------------------------------------------------------
# DEFAULTS
# -------------------------------------------------------------------------
@api.model
def default_get(self, fields_list):
# EXTENDS 'base'
results = super().default_get(fields_list)
if 'move_ids' in fields_list and 'move_ids' not in results:
move_ids = self._context.get('active_ids', [])
results['move_ids'] = [Command.set(move_ids)]
return results
# -------------------------------------------------------------------------
# COMPUTES
# -------------------------------------------------------------------------
@api.depends('move_ids')
def _compute_summary_data(self):
extra_edis = self._get_all_extra_edis()
sending_methods = dict(self.env['res.partner']._fields['invoice_sending_method'].selection)
for wizard in self:
edi_counter = Counter()
sending_method_counter = Counter()
for move in wizard.move_ids:
edi_counter += Counter([edi for edi in self._get_default_extra_edis(move)])
sending_method_counter[self._get_default_sending_method(move)] += 1
summary_data = dict()
for edi, edi_count in edi_counter.items():
summary_data[edi] = {'count': edi_count, 'label': _("by %s", extra_edis[edi]['label'])}
for sending_method, sending_method_count in sending_method_counter.items():
summary_data[sending_method] = {'count': sending_method_count, 'label': sending_methods[sending_method]}
wizard.summary_data = summary_data
@api.depends('summary_data')
def _compute_alerts(self):
for wizard in self:
moves_data = {
move: {
'sending_methods': {self._get_default_sending_method(move)},
'invoice_edi_format': self._get_default_invoice_edi_format(move),
'extra_edis': self._get_default_extra_edis(move),
}
for move in wizard.move_ids
}
wizard.alerts = self._get_alerts(wizard.move_ids, moves_data)
# -------------------------------------------------------------------------
# CONSTRAINS
# -------------------------------------------------------------------------
@api.constrains('move_ids')
def _check_move_ids_constrains(self):
for wizard in self:
self._check_move_constrains(wizard.move_ids)
# -------------------------------------------------------------------------
# ACTIONS
# -------------------------------------------------------------------------
def action_send_and_print(self, force_synchronous=False, allow_fallback_pdf=False):
""" Launch asynchronously the generation and sending of invoices."""
self.ensure_one()
if self.alerts:
self._raise_danger_alerts(self.alerts)
if force_synchronous:
self.env['account.move.send']._generate_and_send_invoices(self.move_ids, allow_fallback_pdf=allow_fallback_pdf)
return
self.move_ids.sending_data = {
'author_user_id': self.env.user.id,
'author_partner_id': self.env.user.partner_id.id,
}
self.env.ref('account.ir_cron_account_move_send')._trigger()
return {
'type': 'ir.actions.client',
'tag': 'display_notification',
'params': {
'type': 'info',
'title': _('Sending invoices'),
'message': _('Invoices are being sent in the background.'),
'next': {'type': 'ir.actions.act_window_close'},
},
}