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>