You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							206 lines
						
					
					
						
							8.3 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							206 lines
						
					
					
						
							8.3 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| from datetime import datetime | |
| 
 | |
| from odoo import models, fields, api, _ | |
| from odoo.exceptions import ValidationError | |
| 
 | |
| 
 | |
| class MRPOrder(models.Model): | |
|     _name = 'mrp.order' | |
|     _description = "Manufacturing Order" | |
|     _inherit = ["mail.thread", "mail.activity.mixin"] | |
| 
 | |
|     @api.model | |
|     def _get_default_location_src_id(self): | |
|         location = False | |
|         company_id = self.env.context.get('default_company_id', | |
|                                           self.env.company.id) | |
|         if self.env.context.get('default_picking_type_id'): | |
|             location = self.env['stock.picking.type'].browse(self.env.context[ | |
|                                                                  'default_picking_type_id']).default_location_src_id | |
|         if not location: | |
|             location = self.env['stock.warehouse'].search( | |
|                 [('company_id', '=', company_id)], limit=1).lot_stock_id | |
|         return location and location.id or False | |
| 
 | |
|     location_src_id = fields.Many2one('stock.location', | |
|                                       default=_get_default_location_src_id,) | |
| 
 | |
|     product_id = fields.Many2one('product.product', string="Product", required=True, domain="""[ | |
|             ('type', 'in', ['product', 'consu']),'|',('company_id', '=', False), | |
|             ('company_id', '=', company_id)]""") | |
|     name = fields.Char( | |
|         'Reference', copy=False, readonly=True, default=lambda x: _('New')) | |
|     product_qty = fields.Float(string="Quantity To Manufacture", default=1.0, tracking=True) | |
|     user_id = fields.Many2one('res.users', 'Responsible', default=lambda self: self.env.user, | |
|                               states={'done': [('readonly', True)]}) | |
|     company_id = fields.Many2one('res.company', 'Company', default=lambda self: self.env.company, | |
|                                  index=True, required=True) | |
|     # mrp_bom_ids = fields.One2many('simple.mrp.bom', 'mrp_id') | |
|     uom_id = fields.Many2one('uom.uom', 'Product Unit of Measure', required=True) | |
|     uom_categ_id = fields.Many2one(related='product_id.uom_id.category_id') | |
|     date_planned = fields.Datetime('Scheduled Date', copy=False, default=fields.Datetime.now, | |
|                                    help="Date at which production start.", index=True, required=True) | |
| 
 | |
|     bom_id = fields.Many2one('simple.mrp.bom', string="Bills of Materials") | |
|     line_ids = fields.One2many('mrp.order.line', 'mrp_id', string="Components") | |
| 
 | |
|     stock_line_ids = fields.One2many('stock.move', 'mrp_id', 'Products') | |
|     stock_move_id = fields.Many2one('stock.move') | |
| 
 | |
|     state = fields.Selection([ | |
|         ('draft', 'Draft'), | |
|         ('confirmed', 'Confirmed'), | |
|         ('done', 'Done'), | |
|         ('cancel', 'Cancelled')], string='State', | |
|         copy=False, index=True, readonly=True, | |
|         store=True, tracking=True, default='draft') | |
| 
 | |
|     @api.onchange('product_id') | |
|     def onchange_product_id(self): | |
|         """ Update the Uom for the product """ | |
|         self.uom_id = self.product_id.uom_id.id | |
|         bom_id = self.env['simple.mrp.bom'].search([ | |
|             ('product_id', '=', self.product_id.id) | |
|         ], limit=1) | |
|         if self.product_id: | |
|             self.bom_id = bom_id or False | |
|             # return {'domain': {'bom_id': [('product_id', '=', self.product_id.id)],}} | |
| 
 | |
|     @api.onchange('uom_id') | |
|     def _onchange_uom_id(self): | |
|         """ Update the Uom for the product """ | |
|         multiple = 1 | |
|         if self.uom_id.uom_type == 'bigger': | |
|             multiple = self.uom_id.factor_inv | |
|         elif self.uom_id.uom_type == 'smaller': | |
|             multiple = 1/self.uom_id.factor | |
|         self.stock_line_ids = False | |
|         self.line_ids = False | |
|         vals = [] | |
|         for rec in self.bom_id.line_ids: | |
|             vals.append((0, 0, { | |
|                 'product_id': rec.product_id.id, | |
|                 'product_qty': rec.product_qty * self.product_qty * multiple, | |
|                 'uom_id': rec.uom_id.id, | |
|             })) | |
|         self.line_ids = vals | |
|         val = [] | |
|         destination = self.env.ref('simple_mrp_order.location_simple_mrp') | |
|         for line in self.bom_id.line_ids: | |
|             val.append((0, 0, { | |
|                 'product_id': line.product_id.id, | |
|                 'product_uom_qty': line.product_qty * self.product_qty * multiple, | |
|                 'name': line.product_id.name, | |
|                 'company_id': self.company_id.id, | |
|                 'location_id': self.location_src_id.id, | |
|                 'location_dest_id': destination.id, | |
|                 'product_uom': line.uom_id.id, | |
|                 'state': 'draft', | |
|                 'product_uom_category_id': line.uom_id.category_id, | |
|             })) | |
|         self.stock_line_ids = val | |
| 
 | |
|     @api.model | |
|     def create(self, vals): | |
|         if "name" not in vals or vals["name"] == _("New"): | |
|             vals["name"] = self.env["ir.sequence"].next_by_code( | |
|                 "mrp.order" | |
|             ) or _("New") | |
|         return super().create(vals) | |
| 
 | |
|     @api.onchange('bom_id', 'product_qty') | |
|     def onchange_bom_id(self): | |
|         """ Update the Components for the MRP Order """ | |
|         self.line_ids = False | |
|         self.stock_line_ids = False | |
|         self.product_id = self.bom_id.product_id.id | |
|         vals = [] | |
|         for line in self.bom_id.line_ids: | |
|             vals.append((0, 0, { | |
|                 'product_id': line.product_id.id, | |
|                 'product_qty': line.product_qty * self.product_qty, | |
|                 'uom_id': line.uom_id.id, | |
|             })) | |
|         val = [] | |
|         destination = self.env.ref('simple_mrp_order.location_simple_mrp') | |
|         for line in self.bom_id.line_ids: | |
|             val.append((0, 0, { | |
|                 'product_id': line.product_id.id, | |
|                 'product_uom_qty': line.product_qty * self.product_qty, | |
|                 'name': line.product_id.name, | |
|                 'company_id': self.company_id.id, | |
|                 'location_id': self.location_src_id.id, | |
|                 'location_dest_id': destination.id, | |
|                 'product_uom': line.uom_id.id, | |
|                 'state': 'draft', | |
|                 'product_uom_category_id': line.uom_id.category_id, | |
|             })) | |
|         self.stock_line_ids = val | |
|         self.line_ids = vals | |
|         if self.bom_id: | |
|             self.uom_id.category_id=self.uom_categ_id.id | |
|             # return {'domain': {'uom_id': [('category_id', '=', self.uom_categ_id.id)],}} | |
| 
 | |
|     def action_confirm(self): | |
|         for line in self.stock_line_ids: | |
|             if line.product_qty > line.product_id.qty_available and line.product_id.type == 'product': | |
|                 raise ValidationError('Only %s quantity available for %s' % | |
|                               (str(line.product_id.qty_available), | |
|                                str(line.product_id.name))) | |
|         self.write({ | |
|             'state': 'confirmed' | |
|         }) | |
| 
 | |
|     def action_done(self): | |
|         self.write({ | |
|             'state': 'done' | |
|         }) | |
|         for move in self.stock_line_ids: | |
|             move._action_confirm() | |
|             move._action_assign() | |
|             move.move_line_ids.write({'qty_done': move.product_uom_qty}) | |
|             move._action_done() | |
|         source = self.env.ref('simple_mrp_order.location_simple_mrp') | |
|         move_id = self.env['stock.move'].create({ | |
|                 'product_id': self.product_id.id, | |
|                 'product_uom_qty': self.product_qty, | |
|                 'name': self.product_id.name, | |
|                 'company_id': self.company_id.id, | |
|                 'location_id': source.id, | |
|                 'location_dest_id': self.location_src_id.id, | |
|                 'product_uom': self.uom_id.id, | |
|                 'state': 'draft', | |
|                 'product_uom_category_id': self.uom_id.category_id, | |
|                 'origin': self.name | |
|         }) | |
|         move_id._action_confirm() | |
|         move_id._action_assign() | |
|         move_id.move_line_ids.write({'qty_done': move_id.product_uom_qty}) | |
|         move_id._action_done() | |
|         self.stock_move_id = move_id | |
| 
 | |
|     def action_cancel(self): | |
|         self.write({ | |
|             'state': 'cancel' | |
|         }) | |
| 
 | |
|     def action_view_move(self): | |
|         ids = [stock.id for stock in self.stock_line_ids] | |
|         ids.append(self.stock_move_id.id) | |
|         return { | |
|             'type': 'ir.actions.act_window', | |
|             'res_model': 'stock.move', | |
|             'domain': [('id', 'in', ids)], | |
|             'name': _("Product Stock Move"), | |
|             'target': 'current', | |
|             'view_mode': 'tree', | |
|         } | |
| 
 | |
| 
 | |
| class MRPLine(models.Model): | |
|     _inherit = 'stock.move' | |
| 
 | |
|     mrp_id = fields.Many2one('mrp.order') | |
| 
 | |
| 
 | |
| 
 |