71 lines
3.2 KiB
Python
71 lines
3.2 KiB
Python
|
# -*- coding: utf-8 -*-
|
||
|
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||
|
|
||
|
from odoo import api, fields, models
|
||
|
|
||
|
|
||
|
class ProductTemplate(models.Model):
|
||
|
_inherit = "product.template"
|
||
|
|
||
|
bom_ids = fields.One2many('mrp.bom', 'product_tmpl_id', 'Bill of Materials')
|
||
|
bom_count = fields.Integer('# Bill of Material', compute='_compute_bom_count')
|
||
|
mo_count = fields.Integer('# Manufacturing Orders', compute='_compute_mo_count')
|
||
|
produce_delay = fields.Float(
|
||
|
'Manufacturing Lead Time', default=0.0,
|
||
|
help="Average delay in days to produce this product. In the case of multi-level BOM, the manufacturing lead times of the components will be added.")
|
||
|
|
||
|
def _compute_bom_count(self):
|
||
|
read_group_res = self.env['mrp.bom'].read_group([('product_tmpl_id', 'in', self.ids)], ['product_tmpl_id'], ['product_tmpl_id'])
|
||
|
mapped_data = dict([(data['product_tmpl_id'][0], data['product_tmpl_id_count']) for data in read_group_res])
|
||
|
for product in self:
|
||
|
product.bom_count = mapped_data.get(product.id, 0)
|
||
|
|
||
|
@api.one
|
||
|
def _compute_mo_count(self):
|
||
|
# TDE FIXME: directly use a read_group
|
||
|
self.mo_count = sum(self.mapped('product_variant_ids').mapped('mo_count'))
|
||
|
|
||
|
@api.multi
|
||
|
def action_view_mos(self):
|
||
|
product_ids = self.mapped('product_variant_ids').ids
|
||
|
action = self.env.ref('mrp.act_product_mrp_production').read()[0]
|
||
|
action['domain'] = [('product_id', 'in', product_ids)]
|
||
|
action['context'] = {}
|
||
|
return action
|
||
|
|
||
|
|
||
|
class ProductProduct(models.Model):
|
||
|
_inherit = "product.product"
|
||
|
|
||
|
bom_count = fields.Integer('# Bill of Material', compute='_compute_bom_count')
|
||
|
mo_count = fields.Integer('# Manufacturing Orders', compute='_compute_mo_count')
|
||
|
|
||
|
def _compute_bom_count(self):
|
||
|
read_group_res = self.env['mrp.bom'].read_group([('product_id', 'in', self.ids)], ['product_id'], ['product_id'])
|
||
|
mapped_data = dict([(data['product_id'][0], data['product_id_count']) for data in read_group_res])
|
||
|
for product in self:
|
||
|
if product.product_tmpl_id.product_variant_count == 1:
|
||
|
bom_count = mapped_data.get(product.id, product.product_tmpl_id.bom_count)
|
||
|
else:
|
||
|
bom_count = mapped_data.get(product.id, 0)
|
||
|
product.bom_count = bom_count
|
||
|
|
||
|
|
||
|
def _compute_mo_count(self):
|
||
|
read_group_res = self.env['mrp.production'].read_group([('product_id', 'in', self.ids)], ['product_id'], ['product_id'])
|
||
|
mapped_data = dict([(data['product_id'][0], data['product_id_count']) for data in read_group_res])
|
||
|
for product in self:
|
||
|
product.mo_count = mapped_data.get(product.id, 0)
|
||
|
|
||
|
@api.multi
|
||
|
def action_view_bom(self):
|
||
|
action = self.env.ref('mrp.product_open_bom').read()[0]
|
||
|
template_ids = self.mapped('product_tmpl_id').ids
|
||
|
# bom specific to this variant or global to template
|
||
|
action['context'] = {
|
||
|
'default_product_tmpl_id': template_ids[0],
|
||
|
'default_product_id': self.ids[0],
|
||
|
}
|
||
|
action['domain'] = ['|', ('product_id', 'in', [self.ids]), '&', ('product_id', '=', False), ('product_tmpl_id', 'in', template_ids)]
|
||
|
return action
|