diff --git a/__manifest__.py b/__manifest__.py index c667b65761cf8890be7339c24c5e89c3bf389243..a2b45d0a48c3b2a6264664e485dca90c10fc1cc4 100755 --- a/__manifest__.py +++ b/__manifest__.py @@ -21,6 +21,7 @@ "views/scop_bordereau_cg.xml", "views/scop_cotisation_cg.xml", "wizard/scop_cotisation_cg_wizard.xml", + "wizard/scop_bordereau_validate_confirm_view.xml", "report/report_scop_bordereau.xml", ] } diff --git a/views/scop_bordereau_cg.xml b/views/scop_bordereau_cg.xml index 305e8aba441525703eca839694853c04569f6438..f181f44310d7a7b58bff86e261f64869dc9a129d 100644 --- a/views/scop_bordereau_cg.xml +++ b/views/scop_bordereau_cg.xml @@ -4,19 +4,6 @@ <odoo> <data> - <!-- Ajoute l'action "valider le bordereau" dans le menu du modèle --> - <record id="validate_bordereau_action_server" model="ir.actions.server"> - <field name="name">Valider le(s) bordereau(x)</field> - <field name="type">ir.actions.server</field> - <field name="model_id" ref="model_scop_bordereau"/> - <field name="binding_model_id" ref="model_scop_bordereau"/> - <field name="state">code</field> - <field name="code"> - if records: - action = records.validate_bordereau() - </field> - </record> - <!-- Ajoute l'action "Mettre à jour les cotisations" dans le menu du modèle --> <record id="action_bordereau_update_cotiz_action" model="ir.actions.server"> <field name="name">Mettre à jour les cotisations</field> diff --git a/wizard/__init__.py b/wizard/__init__.py index 240a8250fa859454a1e1e6dbbe7a87ca4357d8d3..9efc5371364cc48842f254862fb283319b6e68ef 100644 --- a/wizard/__init__.py +++ b/wizard/__init__.py @@ -2,4 +2,5 @@ # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). from . import account_invoice_refund +from . import scop_bordereau_validate_confirm from . import scop_cotisation_cg_wizard diff --git a/wizard/scop_bordereau_validate_confirm.py b/wizard/scop_bordereau_validate_confirm.py new file mode 100644 index 0000000000000000000000000000000000000000..cb04cf02929b4ce6801d6b5be790492891da7f1f --- /dev/null +++ b/wizard/scop_bordereau_validate_confirm.py @@ -0,0 +1,26 @@ +# © 2021 Le Filament (<http://www.le-filament.com>) +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html) + +from odoo import models, api, _ +from odoo.exceptions import UserError + + +class ScopBordereauValidate(models.TransientModel): + """ + This wizard will validate the all the selected bordereaux + """ + + _name = "scop.bordereau.validate" + _description = "Valider les bordereaux sélectionnés" + + @api.multi + def bordereau_confirm(self): + context = dict(self._context or {}) + active_ids = context.get('active_ids', []) or [] + + for record in self.env['scop.bordereau'].browse(active_ids): + if record.state != 'new': + raise UserError(_("Impossible de valider un bordereau qui " + "n'est pas à l'état de brouillon")) + record.validate_bordereau() + return {'type': 'ir.actions.act_window_close'} diff --git a/wizard/scop_bordereau_validate_confirm_view.xml b/wizard/scop_bordereau_validate_confirm_view.xml new file mode 100644 index 0000000000000000000000000000000000000000..ad2d0461c3c2e39ef09ce510783ecc3e1e48868e --- /dev/null +++ b/wizard/scop_bordereau_validate_confirm_view.xml @@ -0,0 +1,31 @@ +<?xml version="1.0"?> +<!-- Copyright 2021 Le Filament + License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). --> + +<odoo> + <data> + + <record id="account_invoice_validate_view" model="ir.ui.view"> + <field name="name">scop.bordereau.validate.form</field> + <field name="model">scop.bordereau.validate</field> + <field name="arch" type="xml"> + <form string="Confirm Draft Invoices"> + <p class="oe_grey"> + Une fois les bordereaux validés, vous ne pourrez plus les remettre en brouillon ! + </p> + <footer> + <button string="Valider" name="bordereau_confirm" type="object" default_focus="1" class="btn-primary"/> + <button string="Annuler" class="btn-secondary" special="cancel"/> + </footer> + </form> + </field> + </record> + + <act_window id="action_scop_bordereau_validate" + multi="True" + name="Valider le(s) bordereau(x)" + res_model="scop.bordereau.validate" src_model="scop.bordereau" + view_mode="form" target="new" view_type="form" /> + + </data> +</odoo>