X-Git-Url: http://git.inspyration.org/?a=blobdiff_plain;f=addons%2Fstock%2Fwizard%2Fstock_partial_picking.py;h=421bcae10ba028c61b2f990336f6db42bfebc8cb;hb=f3168065b638490802cfef78362e568587aa69f6;hp=b657e6639f5254ae770d49045fae3b27be83bfd5;hpb=a7789b208351348ffed62e4f3c88c45013992026;p=odoo%2Fodoo.git diff --git a/addons/stock/wizard/stock_partial_picking.py b/addons/stock/wizard/stock_partial_picking.py index b657e66..421bcae 100644 --- a/addons/stock/wizard/stock_partial_picking.py +++ b/addons/stock/wizard/stock_partial_picking.py @@ -33,51 +33,75 @@ class stock_partial_picking(osv.osv_memory): 'product_moves_in' : fields.one2many('stock.move.memory.in', 'wizard_id', 'Moves'), } - def __is_in(self,cr, uid, pick_ids): - """ - @return: True if one of the moves has as picking type 'in' + def get_picking_type(self, cr, uid, picking, context=None): + picking_type = picking.type + for move in picking.move_lines: + if picking.type == 'in' and move.product_id.cost_method == 'average': + picking_type = 'in' + break + 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. + @param cr: A database cursor + @param uid: ID of the user currently logged in + @param fields: List of fields for which we want default values + @param context: A standard dictionary + @return: A dictionary which of fields with values. """ - if not pick_ids: - return False - + if context is None: + context = {} + pick_obj = self.pool.get('stock.picking') - pick_ids = pick_obj.search(cr, uid, [('id','in',pick_ids)]) - - - for pick in pick_obj.browse(cr, uid, pick_ids): - for move in pick.move_lines: - if pick.type == 'in' and move.product_id.cost_method == 'average': - return True - return False - - def __get_picking_type(self, cr, uid, pick_ids): - if self.__is_in(cr, uid, pick_ids): - return "product_moves_in" - else: - return "product_moves_out" + res = super(stock_partial_picking, self).default_get(cr, uid, fields, context=context) + picking_ids = context.get('active_ids', []) + if not picking_ids: + return res - def view_init(self, cr, uid, fields_list, context=None): - res = super(stock_partial_picking, self).view_init(cr, uid, fields_list, context=context) + result = [] + for pick in pick_obj.browse(cr, uid, picking_ids, context=context): + pick_type = self.get_picking_type(cr, uid, pick, context=context) + for m in pick.move_lines: + if m.state in ('done', 'cancel'): + continue + result.append(self.__create_partial_picking_memory(m, pick_type)) + + if 'product_moves_in' in fields: + res.update({'product_moves_in': result}) + if 'product_moves_out' in fields: + res.update({'product_moves_out': result}) + 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) + + 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) - picking_type = self.__get_picking_type(cr, uid, picking_ids) + + if not picking_ids: + # not called through an action (e.g. buildbot), return the default. + return result + + 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 = """
- """ % (_('Process Document'), _('Products'), picking_type) + """ % (_('Process Document'), _('Products'), "product_moves_" + picking_type) _moves_fields = result['fields'] + + # add field related to picking type only _moves_fields.update({ - 'product_moves_in' : {'relation': 'stock.move.memory.in', 'type' : 'one2many', 'string' : 'Product Moves'}, - 'product_moves_out' : {'relation': 'stock.move.memory.out', 'type' : 'one2many', 'string' : 'Product Moves'} + 'product_moves_' + picking_type: {'relation': 'stock.move.memory.'+picking_type, 'type' : 'one2many', 'string' : 'Product Moves'}, }) - + _moves_arch_lst += """