You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
86 lines
3.2 KiB
86 lines
3.2 KiB
# -*- coding: utf-8 -*-
|
|
# Copyright (C) 2017 - Today: GRAP (http://www.grap.coop)
|
|
# @author: Sylvain LE GAL (https://twitter.com/legalsylvain)
|
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
|
|
|
|
from openerp import models, api, fields
|
|
|
|
|
|
class StockPicking(models.Model):
|
|
_inherit = 'stock.picking'
|
|
|
|
# Field Section
|
|
final_pos_order_id = fields.Many2one(
|
|
string='Final PoS Order', comodel_name='pos.order', readonly=True,
|
|
help="This picking has been canceled, because it has been replaced by"
|
|
" this PoS Order")
|
|
|
|
# Custom Section
|
|
@api.model
|
|
def _prepare_filter_for_pos(self, pos_session_id):
|
|
return [
|
|
('state', 'in', ['confirmed', 'partially_available', 'assigned']),
|
|
('invoice_state', '=', '2binvoiced'),
|
|
]
|
|
|
|
@api.model
|
|
def _prepare_fields_for_pos_list(self):
|
|
return ['name', 'partner_id', 'min_date', 'origin']
|
|
|
|
@api.model
|
|
def search_pickings_for_pos(self, query, pos_session_id):
|
|
# Get Picking Types available for PoS
|
|
picking_type_obj = self.env['stock.picking.type']
|
|
picking_types = picking_type_obj.search(
|
|
[('available_in_pos', '=', True)])
|
|
condition = self._prepare_filter_for_pos(pos_session_id) + [
|
|
('picking_type_id', 'in', picking_types.ids),
|
|
'|', '|',
|
|
('name', 'ilike', query),
|
|
('origin', 'ilike', query),
|
|
('partner_id', 'ilike', query)
|
|
]
|
|
fields = self._prepare_fields_for_pos_list()
|
|
return self.search_read(condition, fields, limit=10)
|
|
|
|
@api.model
|
|
def _prepare_pos_order(self, picking):
|
|
pickinglines = []
|
|
for line in picking.move_lines.filtered(lambda x: x.state != 'cancel'):
|
|
picking_line = {
|
|
'name': line.name,
|
|
'product_id': line.product_id.id,
|
|
'quantity': line.product_uom_qty,
|
|
}
|
|
sale_order_line =\
|
|
line.procurement_id and line.procurement_id.sale_line_id
|
|
if sale_order_line:
|
|
# Get price and discount of the order if available
|
|
picking_line['price_unit'] = sale_order_line.price_unit
|
|
picking_line['discount'] = sale_order_line.discount
|
|
pickinglines.append(picking_line)
|
|
return {
|
|
'id': picking.id,
|
|
'name': picking.name,
|
|
'partner_id': picking.partner_id.id,
|
|
'line_ids': pickinglines,
|
|
}
|
|
|
|
@api.model
|
|
def load_picking_for_pos(self, picking_id):
|
|
picking = self.browse(picking_id)
|
|
return self._prepare_pos_order(picking)
|
|
|
|
@api.multi
|
|
def update_from_origin_picking(self, origin_picking):
|
|
if origin_picking.group_id:
|
|
self.filtered(lambda p: not p.group_id).write({
|
|
'group_id': origin_picking.group_id.id})
|
|
|
|
@api.multi
|
|
def action_confirm(self):
|
|
""" Assign to same procurement group as the origin picking """
|
|
if self.env.context.get('origin_picking_id'):
|
|
self.update_from_origin_picking(
|
|
self.browse(self.env.context['origin_picking_id']))
|
|
return super(StockPicking, self).action_confirm()
|