diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/repair/wizard | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/repair/wizard')
| -rw-r--r-- | addons/repair/wizard/__init__.py | 5 | ||||
| -rw-r--r-- | addons/repair/wizard/repair_make_invoice.py | 34 | ||||
| -rw-r--r-- | addons/repair/wizard/repair_make_invoice_views.xml | 33 | ||||
| -rw-r--r-- | addons/repair/wizard/stock_warn_insufficient_qty.py | 18 | ||||
| -rw-r--r-- | addons/repair/wizard/stock_warn_insufficient_qty_views.xml | 13 |
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> |
