summaryrefslogtreecommitdiff
path: root/addons/mrp/wizard/mrp_consumption_warning.py
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/mrp/wizard/mrp_consumption_warning.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/mrp/wizard/mrp_consumption_warning.py')
-rw-r--r--addons/mrp/wizard/mrp_consumption_warning.py60
1 files changed, 60 insertions, 0 deletions
diff --git a/addons/mrp/wizard/mrp_consumption_warning.py b/addons/mrp/wizard/mrp_consumption_warning.py
new file mode 100644
index 00000000..bae87759
--- /dev/null
+++ b/addons/mrp/wizard/mrp_consumption_warning.py
@@ -0,0 +1,60 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo import fields, models, api
+
+
+class MrpConsumptionWarning(models.TransientModel):
+ _name = 'mrp.consumption.warning'
+ _description = "Wizard in case of consumption in warning/strict and more component has been used for a MO (related to the bom)"
+
+ mrp_production_ids = fields.Many2many('mrp.production')
+ mrp_production_count = fields.Integer(compute="_compute_mrp_production_count")
+
+ consumption = fields.Selection([
+ ('flexible', 'Allowed'),
+ ('warning', 'Allowed with warning'),
+ ('strict', 'Blocked')], compute="_compute_consumption")
+ mrp_consumption_warning_line_ids = fields.One2many('mrp.consumption.warning.line', 'mrp_consumption_warning_id')
+
+ @api.depends("mrp_production_ids")
+ def _compute_mrp_production_count(self):
+ for wizard in self:
+ wizard.mrp_production_count = len(wizard.mrp_production_ids)
+
+ @api.depends("mrp_consumption_warning_line_ids.consumption")
+ def _compute_consumption(self):
+ for wizard in self:
+ consumption_map = set(wizard.mrp_consumption_warning_line_ids.mapped("consumption"))
+ wizard.consumption = "strict" in consumption_map and "strict" or "warning" in consumption_map and "warning" or "flexible"
+
+ def action_confirm(self):
+ action_from_do_finish = False
+ if self.env.context.get('from_workorder'):
+ if self.env.context.get('active_model') == 'mrp.workorder':
+ action_from_do_finish = self.env['mrp.workorder'].browse(self.env.context.get('active_id')).do_finish()
+ action_from_mark_done = self.mrp_production_ids.with_context(skip_consumption=True).button_mark_done()
+ return action_from_do_finish or action_from_mark_done
+
+ def action_cancel(self):
+ if self.env.context.get('from_workorder') and len(self.mrp_production_ids) == 1:
+ return {
+ 'type': 'ir.actions.act_window',
+ 'res_model': 'mrp.production',
+ 'views': [[self.env.ref('mrp.mrp_production_form_view').id, 'form']],
+ 'res_id': self.mrp_production_ids.id,
+ 'target': 'main',
+ }
+
+class MrpConsumptionWarningLine(models.TransientModel):
+ _name = 'mrp.consumption.warning.line'
+ _description = "Line of issue consumption"
+
+ mrp_consumption_warning_id = fields.Many2one('mrp.consumption.warning', "Parent Wizard", readonly=True, required=True, ondelete="cascade")
+ mrp_production_id = fields.Many2one('mrp.production', "Manufacturing Order", readonly=True, required=True, ondelete="cascade")
+ consumption = fields.Selection(related="mrp_production_id.consumption")
+
+ product_id = fields.Many2one('product.product', "Product", readonly=True, required=True)
+ product_uom_id = fields.Many2one('uom.uom', "Unit of Measure", related="product_id.uom_id", readonly=True)
+ product_consumed_qty_uom = fields.Float("Consumed", readonly=True)
+ product_expected_qty_uom = fields.Float("To Consume", readonly=True)