mirror of
https://github.com/ForgeFlow/stock-rma.git
synced 2025-01-21 12:57:49 +02:00
[IMP] rma: use rma user in tests [FIX] rma_account: move_line_id field string [IMP] rma, rma_account, rma_sale, rma_purchase: tests for stock valuation [FIX] account_move_line_rma_order_line: minor lint, make auto-install [IMP] rma_account_unreconciled: use manager user in test
53 lines
1.6 KiB
Python
53 lines
1.6 KiB
Python
# Copyright 2022 ForgeFlow S.L.
|
|
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html)
|
|
|
|
from odoo import models
|
|
|
|
|
|
class StockRule(models.Model):
|
|
_inherit = "stock.rule"
|
|
|
|
def _get_stock_move_values(
|
|
self,
|
|
product_id,
|
|
product_qty,
|
|
product_uom,
|
|
location_id,
|
|
name,
|
|
origin,
|
|
company_id,
|
|
values,
|
|
):
|
|
res = super(StockRule, self)._get_stock_move_values(
|
|
product_id,
|
|
product_qty,
|
|
product_uom,
|
|
location_id,
|
|
name,
|
|
origin,
|
|
company_id,
|
|
values,
|
|
)
|
|
if "rma_line_id" in values:
|
|
line = values.get("rma_line_id")
|
|
if line.reference_move_id:
|
|
return res
|
|
if line.sale_line_id:
|
|
moves = line.sale_line_id.move_ids
|
|
if moves:
|
|
# TODO: Should we be smart in the choice of the move?
|
|
layers = moves.mapped("stock_valuation_layer_ids")
|
|
if layers:
|
|
cost = layers[-1].unit_cost
|
|
res["price_unit"] = cost
|
|
elif line.account_move_line_id:
|
|
sale_lines = line.account_move_line_id.sale_line_ids
|
|
moves = sale_lines.mapped("move_ids")
|
|
if moves:
|
|
layers = moves.mapped("stock_valuation_layer_ids")
|
|
if layers:
|
|
cost = layers[-1].unit_cost
|
|
# TODO: Should we be smart in the choice of the move?
|
|
res["price_unit"] = cost
|
|
return res
|