purchase_mrp/report/mrp_report_mo_overview.py

89 lines
4.5 KiB
Python

# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
from odoo import fields, models
class ReportMoOverview(models.AbstractModel):
_inherit = 'report.mrp.report_mo_overview'
def _get_extra_replenishments(self, product):
res = super()._get_extra_replenishments(product)
domain = [('state', 'in', ['draft', 'sent', 'to approve']), ('product_id', '=', product.id)]
warehouse_id = self.env.context.get('warehouse', False)
if warehouse_id:
domain += [('order_id.picking_type_id.warehouse_id', '=', warehouse_id)]
po_lines = self.env['purchase.order.line'].search(domain, order='date_planned, id')
for po_line in po_lines:
line_qty = po_line.product_qty
for move in po_line.move_dest_ids:
linked_production = self.env['stock.move'].browse(move._rollup_move_dests()).raw_material_production_id
# Only create specific lines for moves directly linked to a manufacturing order
if not linked_production:
continue
prod_qty = min(line_qty, move.product_uom._compute_quantity(move.product_uom_qty, po_line.product_uom))
res.append(self._format_extra_replenishment(po_line, prod_qty, linked_production.id))
line_qty -= prod_qty
if line_qty:
res.append(self._format_extra_replenishment(po_line, line_qty))
return res
def _format_extra_replenishment(self, po_line, quantity, production_id=False):
po = po_line.order_id
price = po_line.taxes_id.with_context(round=False).compute_all(
po_line.price_unit, currency=po.currency_id, quantity=quantity, product=po_line.product_id, partner=po.partner_id
)['total_void']
return {
'_name': 'purchase.order',
'id': po.id,
'cost': price,
'quantity': quantity,
'uom': po_line.product_uom,
'production_id': production_id
}
def _get_replenishment_receipt(self, doc_in, components):
res = super()._get_replenishment_receipt(doc_in, components)
if doc_in._name == 'purchase.order':
if doc_in.state != 'purchase':
return self._format_receipt_date('estimated', doc_in.date_planned)
in_pickings = doc_in.picking_ids.filtered(lambda p: p.state not in ('done', 'cancel'))
planned_date = max(in_pickings.mapped('scheduled_date')) if in_pickings else doc_in.date_planned
return self._format_receipt_date('expected', planned_date)
return res
def _get_resupply_data(self, rules, rules_delay, quantity, uom_id, product, production):
res = super()._get_resupply_data(rules, rules_delay, quantity, uom_id, product, production)
if any(rule for rule in rules if rule.action == 'buy' and product.seller_ids):
supplier = product._select_seller(quantity=quantity, uom_id=product.uom_id)
if supplier:
return {
'delay': supplier.delay + rules_delay,
'cost': supplier.price * uom_id._compute_quantity(quantity, supplier.product_uom),
'currency': supplier.currency_id,
}
return res
def _is_doc_in_done(self, doc_in):
if doc_in._name == 'purchase.order':
return doc_in.state == 'purchase' and all(move.state in ('done', 'cancel') for move in doc_in.order_line.move_ids)
return super()._is_doc_in_done(doc_in)
def _get_origin(self, move):
if move.purchase_line_id:
return move.purchase_line_id.order_id
return super()._get_origin(move)
def _get_replenishment_mo_cost(self, product, quantity, uom_id, currency, move_in=False):
if move_in and move_in.purchase_line_id:
po_line = move_in.purchase_line_id
po = po_line.order_id
price = po_line.taxes_id.with_context(round=False).compute_all(
po_line.price_unit, currency=po.currency_id, quantity=uom_id._compute_quantity(quantity, move_in.purchase_line_id.product_uom),
product=po_line.product_id, partner=po.partner_id
)['total_void']
price = po_line.currency_id._convert(price, currency, (move_in.company_id or self.env.company), fields.Date.today())
return currency.round(price)
return super()._get_replenishment_mo_cost(product, quantity, uom_id, currency, move_in)