'product_moves_out' : fields.one2many('stock.move.memory.out', 'wizard_id', 'Moves'),
'product_moves_in' : fields.one2many('stock.move.memory.in', 'wizard_id', 'Moves'),
}
-
+
def get_picking_type(self, cr, uid, picking, context=None):
picking_type = picking.type
for move in picking.move_lines:
else:
picking_type = 'out'
return picking_type
-
+
def default_get(self, cr, uid, fields, context=None):
""" To get default values for the object.
@param self: The object pointer.
"""
if context is None:
context = {}
-
+
pick_obj = self.pool.get('stock.picking')
res = super(stock_partial_picking, self).default_get(cr, uid, fields, context=context)
picking_ids = context.get('active_ids', [])
if 'date' in fields:
res.update({'date': time.strftime('%Y-%m-%d %H:%M:%S')})
return res
-
+
def fields_view_get(self, cr, uid, view_id=None, view_type='form', context=None, toolbar=False, submenu=False):
result = super(stock_partial_picking, self).fields_view_get(cr, uid, view_id, view_type, context, toolbar, submenu)
-
+
pick_obj = self.pool.get('stock.picking')
picking_ids = context.get('active_ids', False)
for pick in pick_obj.browse(cr, uid, picking_ids, context=context):
picking_type = self.get_picking_type(cr, uid, pick, context=context)
-
+
_moves_arch_lst = """<form string="%s">
<field name="date" invisible="1"/>
<separator colspan="4" string="%s"/>
# add field related to picking type only
_moves_fields.update({
- 'product_moves_' + picking_type: {'relation': 'stock.move.memory.'+picking_type, 'type' : 'one2many', 'string' : 'Product Moves'},
+ 'product_moves_' + picking_type: {'relation': 'stock.move.memory.'+picking_type, 'type' : 'one2many', 'string' : 'Product Moves'},
})
_moves_arch_lst += """
result['fields'] = _moves_fields
return result
- def __create_partial_picking_memory(self, picking, pick_type):
+ def __create_partial_picking_memory(self, move, pick_type):
move_memory = {
- 'product_id' : picking.product_id.id,
- 'quantity' : picking.product_qty,
- 'product_uom' : picking.product_uom.id,
- 'prodlot_id' : picking.prodlot_id.id,
- 'move_id' : picking.id,
+ 'product_id' : move.product_id.id,
+ 'quantity' : move.product_qty,
+ 'product_uom' : move.product_uom.id,
+ 'prodlot_id' : move.prodlot_id.id,
+ 'move_id' : move.id,
}
-
+
if pick_type == 'in':
move_memory.update({
- 'cost' : picking.product_id.standard_price,
- 'currency' : picking.product_id.company_id and picking.product_id.company_id.currency_id.id or False,
+ 'cost' : picking.product_id.standard_price,
+ 'currency' : picking.product_id.company_id and picking.product_id.company_id.currency_id.id or False,
})
return move_memory
@return: A dictionary which of fields with values.
"""
pick_obj = self.pool.get('stock.picking')
-
+
picking_ids = context.get('active_ids', False)
partial = self.browse(cr, uid, ids[0], context=context)
partial_datas = {
picking_type = self.get_picking_type(cr, uid, pick, context=context)
moves_list = picking_type == 'in' and partial.product_moves_in or partial.product_moves_out
+ #Adding a check whether any move has been removed
+ if len(moves_list) < len(pick.move_lines):
+ raise osv.except_osv(_('Processing Error'),\
+ _('You cannot remove any move while validating the picking, rather you can set the quantity as zero!'))
+
+ #Adding a check whether any move has been added
+ if len(moves_list) > len(pick.move_lines):
+ raise osv.except_osv(_('Processing Error'),\
+ _('You cannot add any new move while validating the picking, rather you can split the lines prior to validation!'))
+
for move in moves_list:
+
+ #Adding a check whether any line has been added with new qty
+ if not move.move_id:
+ raise osv.except_osv(_('Processing Error'),\
+ _('You cannot add any new move while validating the picking, rather you can split the lines prior to validation!'))
+
partial_datas['move%s' % (move.move_id.id)] = {
- 'product_id': move.id,
- 'product_qty': move.quantity,
- 'product_uom': move.product_uom.id,
- 'prodlot_id': move.prodlot_id.id,
+ 'product_id': move.product_id.id,
+ 'product_qty': move.quantity,
+ 'product_uom': move.product_uom.id,
+ 'prodlot_id': move.prodlot_id.id,
}
if (picking_type == 'in') and (move.product_id.cost_method == 'average'):
partial_datas['move%s' % (move.move_id.id)].update({
- 'product_price' : move.cost,
- 'product_currency': move.currency.id,
+ 'product_price' : move.cost,
+ 'product_currency': move.currency.id,
})
pick_obj.do_partial(cr, uid, picking_ids, partial_datas, context=context)
return {'type': 'ir.actions.act_window_close'}