summaryrefslogtreecommitdiff
path: root/addons/mrp/models/stock_scrap.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/models/stock_scrap.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/mrp/models/stock_scrap.py')
-rw-r--r--addons/mrp/models/stock_scrap.py36
1 files changed, 36 insertions, 0 deletions
diff --git a/addons/mrp/models/stock_scrap.py b/addons/mrp/models/stock_scrap.py
new file mode 100644
index 00000000..bec0bf27
--- /dev/null
+++ b/addons/mrp/models/stock_scrap.py
@@ -0,0 +1,36 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo import api, fields, models
+
+
+class StockScrap(models.Model):
+ _inherit = 'stock.scrap'
+
+ production_id = fields.Many2one(
+ 'mrp.production', 'Manufacturing Order',
+ states={'done': [('readonly', True)]}, check_company=True)
+ workorder_id = fields.Many2one(
+ 'mrp.workorder', 'Work Order',
+ states={'done': [('readonly', True)]},
+ help='Not to restrict or prefer quants, but informative.', check_company=True)
+
+ @api.onchange('workorder_id')
+ def _onchange_workorder_id(self):
+ if self.workorder_id:
+ self.location_id = self.workorder_id.production_id.location_src_id.id
+
+ @api.onchange('production_id')
+ def _onchange_production_id(self):
+ if self.production_id:
+ self.location_id = self.production_id.move_raw_ids.filtered(lambda x: x.state not in ('done', 'cancel')) and self.production_id.location_src_id.id or self.production_id.location_dest_id.id
+
+ def _prepare_move_values(self):
+ vals = super(StockScrap, self)._prepare_move_values()
+ if self.production_id:
+ vals['origin'] = vals['origin'] or self.production_id.name
+ if self.product_id in self.production_id.move_finished_ids.mapped('product_id'):
+ vals.update({'production_id': self.production_id.id})
+ else:
+ vals.update({'raw_material_production_id': self.production_id.id})
+ return vals