mirror of
https://github.com/ForgeFlow/stock-rma.git
synced 2025-01-21 12:57:49 +02:00
init branch
This commit is contained in:
committed by
JasminSForgeFlow
parent
14401983a8
commit
eaea056686
233
rma/wizards/rma_make_picking.py
Normal file
233
rma/wizards/rma_make_picking.py
Normal file
@@ -0,0 +1,233 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# © 2017 Eficent Business and IT Consulting Services S.L.
|
||||
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html)
|
||||
|
||||
import time
|
||||
from openerp import models, fields, exceptions, api, _
|
||||
from openerp.exceptions import ValidationError
|
||||
from openerp.tools import DEFAULT_SERVER_DATETIME_FORMAT as DT_FORMAT
|
||||
import openerp.addons.decimal_precision as dp
|
||||
|
||||
|
||||
class RmaMakePicking(models.TransientModel):
|
||||
_name = 'rma_make_picking.wizard'
|
||||
_description = 'Wizard to create pickings from rma lines'
|
||||
|
||||
@api.returns('rma.order.line')
|
||||
def _prepare_item(self, line):
|
||||
values = {'product_id': line.product_id.id,
|
||||
'product_qty': line.product_qty,
|
||||
'uom_id': line.uom_id.id,
|
||||
'qty_to_receive': line.qty_to_receive,
|
||||
'qty_to_deliver': line.qty_to_deliver,
|
||||
'line_id': line.id,
|
||||
'rma_id': line.rma_id.id,
|
||||
'wiz_id': self.env.context['active_id'],
|
||||
}
|
||||
return values
|
||||
|
||||
@api.model
|
||||
def default_get(self, fields):
|
||||
"""Default values for wizard, if there is more than one supplier on
|
||||
lines the supplier field is empty otherwise is the unique line
|
||||
supplier.
|
||||
"""
|
||||
res = super(RmaMakePicking, self).default_get(fields)
|
||||
rma_line_obj = self.env['rma.order.line']
|
||||
rma_line_ids = self.env.context['active_ids'] or []
|
||||
active_model = self.env.context['active_model']
|
||||
|
||||
if not rma_line_ids:
|
||||
return res
|
||||
assert active_model == 'rma.order.line', \
|
||||
'Bad context propagation'
|
||||
|
||||
items = []
|
||||
lines = rma_line_obj.browse(rma_line_ids)
|
||||
if len(lines.mapped('partner_id')) > 1:
|
||||
raise exceptions.Warning(
|
||||
_('Only RMA lines from the same partner can be processed at '
|
||||
'the same time'))
|
||||
for line in lines:
|
||||
items.append([0, 0, self._prepare_item(line)])
|
||||
res['item_ids'] = items
|
||||
return res
|
||||
|
||||
item_ids = fields.One2many(
|
||||
'rma_make_picking.wizard.item',
|
||||
'wiz_id', string='Items')
|
||||
|
||||
def find_procurement_group(self, item):
|
||||
return self.env['procurement.group'].search([('rma_id', '=',
|
||||
item.line_id.rma_id.id)])
|
||||
|
||||
def _get_procurement_group_data(self, item):
|
||||
group_data = {
|
||||
'name': item.line_id.rma_id.name,
|
||||
'rma_id': item.line_id.rma_id.id,
|
||||
}
|
||||
return group_data
|
||||
|
||||
@api.model
|
||||
def _get_address(self, item):
|
||||
if item.line_id.delivery_address_id:
|
||||
delivery_address = item.line_id.delivery_address_id or \
|
||||
item.line_id.partner_id
|
||||
elif item.line_id.customer_to_supplier:
|
||||
delivery_address = item.line_id.supplier_address_id
|
||||
else:
|
||||
raise exceptions.Warning('Unknown delivery address')
|
||||
return delivery_address
|
||||
|
||||
def _get_address_location(self, delivery_address_id, type):
|
||||
if type == 'supplier':
|
||||
return delivery_address_id.property_stock_supplier
|
||||
elif type == 'customer':
|
||||
return delivery_address_id.property_stock_customer
|
||||
|
||||
@api.model
|
||||
def _get_procurement_data(self, item, group, qty, picking_type):
|
||||
line = item.line_id
|
||||
delivery_address_id = self._get_address(item)
|
||||
if picking_type == 'incoming':
|
||||
if line.customer_to_supplier:
|
||||
location = self._get_address_location(
|
||||
delivery_address_id, 'supplier')
|
||||
else:
|
||||
location = line.location_id
|
||||
warehouse = line.in_warehouse_id
|
||||
route = line.in_route_id
|
||||
else:
|
||||
location = self._get_address_location(delivery_address_id,
|
||||
line.rma_id.type)
|
||||
warehouse = line.out_warehouse_id
|
||||
route = line.out_route_id
|
||||
if not route:
|
||||
raise exceptions.Warning("No route specified")
|
||||
if not warehouse:
|
||||
raise exceptions.Warning("No warehouse specified")
|
||||
procurement_data = {
|
||||
'name': line.rma_id.name,
|
||||
'group_id': group.id,
|
||||
'origin': line.rma_id.name,
|
||||
'warehouse_id': warehouse.id,
|
||||
'date_planned': time.strftime(DT_FORMAT),
|
||||
'product_id': item.product_id.id,
|
||||
'product_qty': qty,
|
||||
'partner_dest_id': delivery_address_id.id,
|
||||
'product_uom': line.product_id.product_tmpl_id.uom_id.id,
|
||||
'location_id': location.id,
|
||||
'rma_line_id': line.id,
|
||||
'route_ids': [(4, route.id)]
|
||||
}
|
||||
return procurement_data
|
||||
|
||||
@api.model
|
||||
def _create_procurement(self, item, picking_type):
|
||||
group = self.find_procurement_group(item)
|
||||
if not group:
|
||||
procurement_group = self._get_procurement_group_data(item)
|
||||
group = self.env['procurement.group'].create(procurement_group)
|
||||
if picking_type == 'incoming':
|
||||
qty = item.qty_to_receive
|
||||
else:
|
||||
qty = item.qty_to_deliver
|
||||
procurement_data = self._get_procurement_data(
|
||||
item, group, qty, picking_type)
|
||||
# create picking
|
||||
procurement = self.env['procurement.order'].create(procurement_data)
|
||||
procurement.run()
|
||||
return procurement.id
|
||||
|
||||
@api.multi
|
||||
def _create_picking(self):
|
||||
"""Method called when the user clicks on create picking"""
|
||||
picking_type = self.env.context.get('picking_type')
|
||||
procurement_list = []
|
||||
for item in self.item_ids:
|
||||
line = item.line_id
|
||||
if line.state != 'approved':
|
||||
raise exceptions.Warning(
|
||||
_('RMA %s is not approved') %
|
||||
line.rma_id.name)
|
||||
if line.receipt_policy == 'no' and picking_type == \
|
||||
'incoming':
|
||||
raise exceptions.Warning(
|
||||
_('No shipments needed for this operation'))
|
||||
if line.delivery_policy == 'no' and picking_type == \
|
||||
'outgoing':
|
||||
raise exceptions.Warning(
|
||||
_('No deliveries needed for this operation'))
|
||||
procurement = self._create_procurement(item, picking_type)
|
||||
procurement_list.append(procurement)
|
||||
procurements = self.env['procurement.order'].browse(procurement_list)
|
||||
return procurements
|
||||
|
||||
@api.model
|
||||
def _get_action(self, pickings, procurements):
|
||||
if pickings:
|
||||
action = procurements.do_view_pickings()
|
||||
else:
|
||||
action = self.env.ref(
|
||||
'procurement.procurement_order_action_exceptions')
|
||||
action = action.read()[0]
|
||||
# choose the view_mode accordingly
|
||||
procurement_ids = procurements.ids
|
||||
if len(procurement_ids) != 1:
|
||||
action['domain'] = "[('id', 'in', " + \
|
||||
str(procurement_ids) + ")]"
|
||||
elif len(procurements) == 1:
|
||||
res = self.env.ref('procurement.procurement_form_view',
|
||||
False)
|
||||
action['views'] = [(res and res.id or False, 'form')]
|
||||
action['res_id'] = procurement_ids[0]
|
||||
return action
|
||||
|
||||
@api.multi
|
||||
def action_create_picking(self):
|
||||
procurements = self._create_picking()
|
||||
groups = []
|
||||
for proc in procurements:
|
||||
if proc.group_id:
|
||||
groups.append(proc.group_id.id)
|
||||
if len(groups):
|
||||
pickings =self.env['stock.picking'].search(
|
||||
[('group_id', 'in', groups)])
|
||||
|
||||
action = self._get_action(pickings, procurements)
|
||||
return action
|
||||
|
||||
@api.multi
|
||||
def action_cancel(self):
|
||||
return {'type': 'ir.actions.act_window_close'}
|
||||
|
||||
|
||||
class RmaMakePickingItem(models.TransientModel):
|
||||
_name = "rma_make_picking.wizard.item"
|
||||
_description = "Items to receive"
|
||||
|
||||
wiz_id = fields.Many2one(
|
||||
'rma_make_picking.wizard',
|
||||
string='Wizard', required=True)
|
||||
line_id = fields.Many2one('rma.order.line',
|
||||
string='RMA order Line',
|
||||
readonly=True,
|
||||
ondelete='cascade')
|
||||
rma_id = fields.Many2one('rma.order',
|
||||
related='line_id.rma_id',
|
||||
string='RMA',
|
||||
readonly=True)
|
||||
product_id = fields.Many2one('product.product', string='Product',
|
||||
readonly=True)
|
||||
product_qty = fields.Float(
|
||||
related='line_id.product_qty',
|
||||
string='Quantity Ordered', copy=False,
|
||||
digits=dp.get_precision('Product Unit of Measure'), readonly=True)
|
||||
qty_to_receive = fields.Float(
|
||||
string='Quantity to Receive',
|
||||
digits=dp.get_precision('Product Unit of Measure'))
|
||||
qty_to_deliver = fields.Float(
|
||||
string='Quantity To Deliver',
|
||||
digits=dp.get_precision('Product Unit of Measure'))
|
||||
uom_id = fields.Many2one('product.uom', string='Unit of Measure',
|
||||
readonly=True)
|
||||
Reference in New Issue
Block a user