mirror of
https://github.com/bringout/oca-ocb-sale.git
synced 2026-04-28 08:52:10 +02:00
19.0 vanilla
This commit is contained in:
parent
79f83631d5
commit
73afc09215
6267 changed files with 1534193 additions and 1130106 deletions
|
|
@ -4,52 +4,52 @@
|
|||
from odoo import models
|
||||
|
||||
|
||||
class ReplenishmentReport(models.AbstractModel):
|
||||
_inherit = 'report.stock.report_product_product_replenishment'
|
||||
class StockForecasted_Product_Product(models.AbstractModel):
|
||||
_inherit = 'stock.forecasted_product_product'
|
||||
|
||||
def _serialize_docs(self, docs, product_template_ids=False, product_variant_ids=False):
|
||||
res = super()._serialize_docs(docs, product_template_ids, product_variant_ids)
|
||||
res['draft_sale_orders'] = docs['draft_sale_orders'].read(fields=['id', 'name'])
|
||||
for i in range(len(docs['lines'])):
|
||||
if not docs['lines'][i]['move_out'] or not docs['lines'][i]['move_out']['picking_id'] or not docs['lines'][i]['move_out']['picking_id']['sale_id']:
|
||||
continue
|
||||
picking = docs['lines'][i]['move_out']['picking_id']
|
||||
res['lines'][i]['move_out'].update({
|
||||
'picking_id' : {
|
||||
'id' : picking.id,
|
||||
'priority' : picking.priority,
|
||||
'sale_id' : {
|
||||
'id' : picking.sale_id.id,
|
||||
'amount_untaxed' : picking.sale_id.amount_untaxed,
|
||||
'currency_id' : picking.sale_id.currency_id.read(fields=['id', 'name'])[0],
|
||||
'partner_id' : picking.sale_id.partner_id.read(fields=['id', 'name'])[0],
|
||||
def _prepare_report_line(self, quantity, move_out=None, move_in=None, replenishment_filled=True, product=False, reserved_move=False, in_transit=False, read=True):
|
||||
line = super()._prepare_report_line(quantity, move_out, move_in, replenishment_filled, product, reserved_move, in_transit, read)
|
||||
|
||||
if not move_out or not move_out.picking_id or not move_out.picking_id.sale_id:
|
||||
return line
|
||||
|
||||
picking = move_out.picking_id
|
||||
# If read is False, line['move_out'] is a stock.move record and will trigger a record update
|
||||
if read:
|
||||
line['move_out'].update({
|
||||
'picking_id': {
|
||||
'id': picking.id,
|
||||
'priority': picking.priority,
|
||||
'sale_id': {
|
||||
'id': picking.sale_id.id,
|
||||
'amount_untaxed': picking.sale_id.amount_untaxed,
|
||||
'currency_id': picking.sale_id.currency_id.read(fields=['id', 'name'])[0],
|
||||
'partner_id': picking.sale_id.partner_id.read(fields=['id', 'display_name'])[0],
|
||||
}
|
||||
}
|
||||
})
|
||||
return line
|
||||
|
||||
def _get_report_header(self, product_template_ids, product_ids, wh_location_ids):
|
||||
res = super()._get_report_header(product_template_ids, product_ids, wh_location_ids)
|
||||
domain = self._product_sale_domain(product_template_ids, product_ids)
|
||||
so_lines = self.env['sale.order.line'].sudo().search(domain).grouped('product_id')
|
||||
out_qty = {k.id: sum(v.mapped(lambda line: line.product_uom_id._compute_quantity(line.product_uom_qty, line.product_id.uom_id))) for k, v in so_lines.items()}
|
||||
self._add_product_quantities(res, product_template_ids, product_ids, 'draft_sale_qty', qty_out=out_qty)
|
||||
for product in self._get_products(product_template_ids, product_ids):
|
||||
if product not in so_lines:
|
||||
continue
|
||||
res['product'][product.id]['draft_sale_orders'] = so_lines[product].mapped("order_id").sorted(key=lambda so: so.name).read(fields=['id', 'name'])
|
||||
res['product'][product.id]['draft_sale_orders_matched'] = self.env.context.get('sale_line_to_match_id') in so_lines[product].ids
|
||||
return res
|
||||
|
||||
def _compute_draft_quantity_count(self, product_template_ids, product_variant_ids, wh_location_ids):
|
||||
res = super()._compute_draft_quantity_count(product_template_ids, product_variant_ids, wh_location_ids)
|
||||
domain = self._product_sale_domain(product_template_ids, product_variant_ids)
|
||||
so_lines = self.env['sale.order.line'].sudo().search(domain)
|
||||
out_sum = 0
|
||||
if so_lines:
|
||||
product_uom = so_lines[0].product_id.uom_id
|
||||
quantities = so_lines.mapped(lambda line: line.product_uom._compute_quantity(line.product_uom_qty, product_uom))
|
||||
out_sum = sum(quantities)
|
||||
res['draft_sale_qty'] = out_sum
|
||||
res['draft_sale_orders'] = so_lines.mapped("order_id").sorted(key=lambda so: so.name)
|
||||
res['draft_sale_orders_matched'] = self.env.context.get('sale_line_to_match_id') in so_lines.ids
|
||||
res['qty']['out'] += out_sum
|
||||
return res
|
||||
|
||||
def _product_sale_domain(self, product_template_ids, product_variant_ids):
|
||||
def _product_sale_domain(self, product_template_ids, product_ids):
|
||||
domain = [('state', 'in', ['draft', 'sent'])]
|
||||
if product_template_ids:
|
||||
domain += [('product_template_id', 'in', product_template_ids)]
|
||||
elif product_variant_ids:
|
||||
domain += [('product_id', 'in', product_variant_ids)]
|
||||
warehouse_id = self.env['stock.warehouse']._get_warehouse_id_from_context()
|
||||
elif product_ids:
|
||||
domain += [('product_id', 'in', product_ids)]
|
||||
warehouse_id = self.env.context.get('warehouse_id', False)
|
||||
if warehouse_id:
|
||||
domain += [('warehouse_id', '=', warehouse_id)]
|
||||
return domain
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue