82 lines
3.9 KiB
Python
82 lines
3.9 KiB
Python
|
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||
|
|
||
|
from odoo import api, fields, models
|
||
|
from odoo.tools.sql import column_exists, create_column
|
||
|
|
||
|
|
||
|
class StockRoute(models.Model):
|
||
|
_inherit = "stock.route"
|
||
|
|
||
|
shipping_selectable = fields.Boolean("Applicable on Shipping Methods")
|
||
|
|
||
|
|
||
|
class StockMove(models.Model):
|
||
|
_inherit = 'stock.move'
|
||
|
|
||
|
def _auto_init(self):
|
||
|
if not column_exists(self.env.cr, "stock_move", "weight"):
|
||
|
# In case of a big database with a lot of stock moves, the RAM gets exhausted
|
||
|
# To prevent a process from being killed We create the column 'weight' manually
|
||
|
# Then we do the computation in a query by multiplying product weight with qty
|
||
|
create_column(self.env.cr, "stock_move", "weight", "numeric")
|
||
|
self.env.cr.execute("""
|
||
|
UPDATE stock_move move
|
||
|
SET weight = move.product_qty * product.weight
|
||
|
FROM product_product product
|
||
|
WHERE move.product_id = product.id
|
||
|
AND move.state != 'cancel'
|
||
|
""")
|
||
|
return super()._auto_init()
|
||
|
|
||
|
weight = fields.Float(compute='_cal_move_weight', digits='Stock Weight', store=True, compute_sudo=True)
|
||
|
|
||
|
@api.depends('product_id', 'product_uom_qty', 'product_uom')
|
||
|
def _cal_move_weight(self):
|
||
|
moves_with_weight = self.filtered(lambda moves: moves.product_id.weight > 0.00)
|
||
|
for move in moves_with_weight:
|
||
|
move.weight = (move.product_qty * move.product_id.weight)
|
||
|
(self - moves_with_weight).weight = 0
|
||
|
|
||
|
def _get_new_picking_values(self):
|
||
|
vals = super(StockMove, self)._get_new_picking_values()
|
||
|
carrier_id = self.group_id.sale_id.carrier_id.id
|
||
|
vals['carrier_id'] = any(rule.propagate_carrier for rule in self.rule_id) and carrier_id
|
||
|
return vals
|
||
|
|
||
|
def _key_assign_picking(self):
|
||
|
keys = super(StockMove, self)._key_assign_picking()
|
||
|
return keys + (self.sale_line_id.order_id.carrier_id,)
|
||
|
|
||
|
class StockMoveLine(models.Model):
|
||
|
_inherit = 'stock.move.line'
|
||
|
|
||
|
sale_price = fields.Float(compute='_compute_sale_price')
|
||
|
destination_country_code = fields.Char(related='picking_id.destination_country_code')
|
||
|
carrier_id = fields.Many2one(related='picking_id.carrier_id', store=True) # need to be stored for the groupby in `stock_move_line_view_search_delivery`
|
||
|
|
||
|
@api.depends('quantity', 'product_uom_id', 'product_id', 'move_id.sale_line_id', 'move_id.sale_line_id.price_reduce_taxinc', 'move_id.sale_line_id.product_uom')
|
||
|
def _compute_sale_price(self):
|
||
|
for move_line in self:
|
||
|
if move_line.move_id.sale_line_id:
|
||
|
unit_price = move_line.move_id.sale_line_id.price_reduce_taxinc
|
||
|
qty = move_line.product_uom_id._compute_quantity(move_line.quantity, move_line.move_id.sale_line_id.product_uom)
|
||
|
else:
|
||
|
unit_price = move_line.product_id.list_price
|
||
|
qty = move_line.product_uom_id._compute_quantity(move_line.quantity, move_line.product_id.uom_id)
|
||
|
move_line.sale_price = unit_price * qty
|
||
|
super(StockMoveLine, self)._compute_sale_price()
|
||
|
|
||
|
def _get_aggregated_product_quantities(self, **kwargs):
|
||
|
"""Returns dictionary of products and corresponding values of interest + hs_code
|
||
|
|
||
|
Unfortunately because we are working with aggregated data, we have to loop through the
|
||
|
aggregation to add more values to each datum. This extension adds on the hs_code value.
|
||
|
|
||
|
returns: dictionary {same_key_as_super: {same_values_as_super, hs_code}, ...}
|
||
|
"""
|
||
|
aggregated_move_lines = super()._get_aggregated_product_quantities(**kwargs)
|
||
|
for aggregated_move_line in aggregated_move_lines:
|
||
|
hs_code = aggregated_move_lines[aggregated_move_line]['product'].product_tmpl_id.hs_code
|
||
|
aggregated_move_lines[aggregated_move_line]['hs_code'] = hs_code
|
||
|
return aggregated_move_lines
|