summaryrefslogtreecommitdiff
path: root/addons/repair/wizard
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/repair/wizard
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/repair/wizard')
-rw-r--r--addons/repair/wizard/__init__.py5
-rw-r--r--addons/repair/wizard/repair_make_invoice.py34
-rw-r--r--addons/repair/wizard/repair_make_invoice_views.xml33
-rw-r--r--addons/repair/wizard/stock_warn_insufficient_qty.py18
-rw-r--r--addons/repair/wizard/stock_warn_insufficient_qty_views.xml13
5 files changed, 103 insertions, 0 deletions
diff --git a/addons/repair/wizard/__init__.py b/addons/repair/wizard/__init__.py
new file mode 100644
index 00000000..42410e54
--- /dev/null
+++ b/addons/repair/wizard/__init__.py
@@ -0,0 +1,5 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from . import repair_make_invoice
+from . import stock_warn_insufficient_qty
diff --git a/addons/repair/wizard/repair_make_invoice.py b/addons/repair/wizard/repair_make_invoice.py
new file mode 100644
index 00000000..0556257d
--- /dev/null
+++ b/addons/repair/wizard/repair_make_invoice.py
@@ -0,0 +1,34 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo import api, fields, models
+
+
+class MakeInvoice(models.TransientModel):
+ _name = 'repair.order.make_invoice'
+ _description = 'Create Mass Invoice (repair)'
+
+ group = fields.Boolean('Group by partner invoice address')
+
+ def make_invoices(self):
+ if not self._context.get('active_ids'):
+ return {'type': 'ir.actions.act_window_close'}
+ new_invoice = {}
+ for wizard in self:
+ repairs = self.env['repair.order'].browse(self._context['active_ids'])
+ new_invoice = repairs._create_invoices(group=wizard.group)
+
+ # We have to udpate the state of the given repairs, otherwise they remain 'to be invoiced'.
+ # Note that this will trigger another call to the method '_create_invoices',
+ # but that second call will not do anything, since the repairs are already invoiced.
+ repairs.action_repair_invoice_create()
+ return {
+ 'domain': [('id', 'in', list(new_invoice.values()))],
+ 'name': 'Invoices',
+ 'view_mode': 'tree,form',
+ 'res_model': 'account.move',
+ 'view_id': False,
+ 'views': [(self.env.ref('account.view_move_tree').id, 'tree'), (self.env.ref('account.view_move_form').id, 'form')],
+ 'context': "{'move_type':'out_invoice'}",
+ 'type': 'ir.actions.act_window'
+ }
diff --git a/addons/repair/wizard/repair_make_invoice_views.xml b/addons/repair/wizard/repair_make_invoice_views.xml
new file mode 100644
index 00000000..4b42f3f9
--- /dev/null
+++ b/addons/repair/wizard/repair_make_invoice_views.xml
@@ -0,0 +1,33 @@
+<?xml version="1.0" encoding="utf-8"?>
+<odoo>
+ <data>
+
+ <!-- Make Invoice -->
+
+ <record id="view_make_invoice" model="ir.ui.view">
+ <field name="name">Make Invoice</field>
+ <field name="model">repair.order.make_invoice</field>
+ <field name="arch" type="xml">
+ <form string="Create invoices">
+ <group string="Do you really want to create the invoice(s)?">
+ <field name="group"/>
+ </group>
+ <footer>
+ <button name="make_invoices" string="Create Invoice" type="object" class="btn-primary"/>
+ <button string="Cancel" class="btn-secondary" special="cancel" />
+ </footer>
+ </form>
+ </field>
+ </record>
+
+ <record id="act_repair_invoice" model="ir.actions.act_window">
+ <field name="name">Create invoices</field>
+ <field name="res_model">repair.order.make_invoice</field>
+ <field name="view_mode">form</field>
+ <field name="target">new</field>
+ <field name="binding_model_id" ref="model_repair_order"/>
+ <field name="binding_view_types">list</field>
+ </record>
+
+ </data>
+</odoo>
diff --git a/addons/repair/wizard/stock_warn_insufficient_qty.py b/addons/repair/wizard/stock_warn_insufficient_qty.py
new file mode 100644
index 00000000..73f63fa0
--- /dev/null
+++ b/addons/repair/wizard/stock_warn_insufficient_qty.py
@@ -0,0 +1,18 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo import fields, models
+
+class StockWarnInsufficientQtyRepair(models.TransientModel):
+ _name = 'stock.warn.insufficient.qty.repair'
+ _inherit = 'stock.warn.insufficient.qty'
+ _description = 'Warn Insufficient Repair Quantity'
+
+ repair_id = fields.Many2one('repair.order', string='Repair')
+
+ def _get_reference_document_company_id(self):
+ return self.repair_id.company_id
+
+ def action_done(self):
+ self.ensure_one()
+ return self.repair_id.action_repair_confirm()
diff --git a/addons/repair/wizard/stock_warn_insufficient_qty_views.xml b/addons/repair/wizard/stock_warn_insufficient_qty_views.xml
new file mode 100644
index 00000000..949828c0
--- /dev/null
+++ b/addons/repair/wizard/stock_warn_insufficient_qty_views.xml
@@ -0,0 +1,13 @@
+<?xml version="1.0" encoding="utf-8"?>
+<odoo>
+ <record id="stock_warn_insufficient_qty_repair_form_view" model="ir.ui.view">
+ <field name="name">stock.warn.insufficient.qty.repair</field>
+ <field name="model">stock.warn.insufficient.qty.repair</field>
+ <field name="inherit_id" ref="stock.stock_warn_insufficient_qty_form_view"/>
+ <field name="arch" type="xml">
+ <xpath expr="//div[@name='description']" position="after">
+ Do you confirm you want to repair <strong><field name="quantity" readonly="True"/></strong><field name="product_uom_name" readonly="True" class="mx-1"/>from location <strong><field name="location_id" readonly="True"/></strong>? This may lead to inconsistencies in your inventory.
+ </xpath>
+ </field>
+ </record>
+</odoo>