表面工艺确认回退再重新确认调拨单报错问题
This commit is contained in:
@@ -657,52 +657,59 @@ class StockPicking(models.Model):
|
|||||||
if move_out:
|
if move_out:
|
||||||
workorder = move_out.subcontract_workorder_id
|
workorder = move_out.subcontract_workorder_id
|
||||||
workorder.button_start()
|
workorder.button_start()
|
||||||
|
# if self.location_id.name == '成品存货区' and self.location_dest_id == '客户':
|
||||||
|
# sale_id = self.env['sale.order'].sudo().search(
|
||||||
|
# [('name', '=', self.origin)])
|
||||||
|
# if sale_id:
|
||||||
|
# sale_id.write({'state':'delivered'})
|
||||||
return res
|
return res
|
||||||
|
|
||||||
# 创建 外协出库入单
|
# 创建 外协出库入单
|
||||||
def create_outcontract_picking(self, workorders, item, sorted_workorders):
|
def create_outcontract_picking(self, workorders, item, sorted_workorders):
|
||||||
for workorder in workorders:
|
for workorder in workorders:
|
||||||
if workorder.move_subcontract_workorder_ids:
|
if workorder.move_subcontract_workorder_ids:
|
||||||
workorder.move_subcontract_workorder_ids.write({'state': 'waiting'})
|
workorder.move_subcontract_workorder_ids.write({'state': 'cancel'})
|
||||||
workorder.move_subcontract_workorder_ids.picking_id.write({'state': 'waiting'})
|
workorder.move_subcontract_workorder_ids.picking_id.write({'state': 'cancel'})
|
||||||
|
# 创建一个新的补货组
|
||||||
|
procurement_group_id = self.env['procurement.group'].create({
|
||||||
|
'name': workorder.name,
|
||||||
|
'partner_id': self.partner_id.id,
|
||||||
|
})
|
||||||
|
move_dest_id = False
|
||||||
|
# 如果当前工单是是制造订单的最后一个工艺外协工单
|
||||||
|
if workorder == next((workorder for workorder in reversed(sorted_workorders) if workorder.is_subcontract), None):
|
||||||
|
move_dest_id = item.move_raw_ids[0].id
|
||||||
else:
|
else:
|
||||||
# 创建一个新的补货组
|
# 从sorted_workorders中找到上一工单的move
|
||||||
procurement_group_id = self.env['procurement.group'].create({
|
if len(sorted_workorders) > 1:
|
||||||
'name': workorder.name,
|
move_dest_id = sorted_workorders[sorted_workorders.index(workorder)+1].move_subcontract_workorder_ids[1].id
|
||||||
'partner_id': self.partner_id.id,
|
new_picking = True
|
||||||
})
|
outcontract_picking_type_in = self.env.ref(
|
||||||
move_dest_id = False
|
'sf_manufacturing.outcontract_picking_in').id,
|
||||||
# 如果当前工单是是制造订单的最后一个工艺外协工单
|
outcontract_picking_type_out = self.env.ref(
|
||||||
if workorder == next((workorder for workorder in reversed(item.workorder_ids) if workorder.is_subcontract), None):
|
'sf_manufacturing.outcontract_picking_out').id,
|
||||||
move_dest_id = item.move_raw_ids[0].id
|
moves_in = self.env['stock.move'].sudo().create(
|
||||||
else:
|
self.env['stock.move']._get_stock_move_values_Res(item, outcontract_picking_type_in,
|
||||||
# 从sorted_workorders中找到上一工单的move
|
procurement_group_id.id, move_dest_id))
|
||||||
if len(sorted_workorders) > 1:
|
picking_in = self.create(
|
||||||
move_dest_id = sorted_workorders[sorted_workorders.index(workorder)+1].move_subcontract_workorder_ids[1].id
|
moves_in._get_new_picking_values_Res(item, workorder, 'WH/OCIN/'))
|
||||||
new_picking = True
|
# pick_ids.append(picking_in.id)
|
||||||
outcontract_picking_type_in = self.env.ref(
|
moves_in.write(
|
||||||
'sf_manufacturing.outcontract_picking_in').id,
|
{'picking_id': picking_in.id, 'state': 'waiting'})
|
||||||
outcontract_picking_type_out = self.env.ref(
|
moves_in._assign_picking_post_process(new=new_picking)
|
||||||
'sf_manufacturing.outcontract_picking_out').id,
|
moves_out = self.env['stock.move'].sudo().create(
|
||||||
moves_in = self.env['stock.move'].sudo().create(
|
self.env['stock.move']._get_stock_move_values_Res(item, outcontract_picking_type_out,
|
||||||
self.env['stock.move']._get_stock_move_values_Res(item, outcontract_picking_type_in,
|
procurement_group_id.id, moves_in.id))
|
||||||
procurement_group_id.id, move_dest_id))
|
workorder.write({'move_subcontract_workorder_ids': [(6, 0, [moves_in.id, moves_out.id])]})
|
||||||
picking_in = self.create(
|
picking_out = self.create(
|
||||||
moves_in._get_new_picking_values_Res(item, workorder, 'WH/OCIN/'))
|
moves_out._get_new_picking_values_Res(item, workorder, 'WH/OCOUT/'))
|
||||||
# pick_ids.append(picking_in.id)
|
# pick_ids.append(picking_out.id)
|
||||||
moves_in.write(
|
moves_out.write(
|
||||||
{'picking_id': picking_in.id, 'state': 'waiting'})
|
{'picking_id': picking_out.id, 'state': 'waiting'})
|
||||||
moves_in._assign_picking_post_process(new=new_picking)
|
moves_out._assign_picking_post_process(new=new_picking)
|
||||||
moves_out = self.env['stock.move'].sudo().create(
|
|
||||||
self.env['stock.move']._get_stock_move_values_Res(item, outcontract_picking_type_out,
|
|
||||||
procurement_group_id.id, moves_in.id))
|
|
||||||
workorder.write({'move_subcontract_workorder_ids': [(6, 0, [moves_in.id, moves_out.id])]})
|
|
||||||
picking_out = self.create(
|
|
||||||
moves_out._get_new_picking_values_Res(item, workorder, 'WH/OCOUT/'))
|
|
||||||
# pick_ids.append(picking_out.id)
|
|
||||||
moves_out.write(
|
|
||||||
{'picking_id': picking_out.id, 'state': 'waiting'})
|
|
||||||
moves_out._assign_picking_post_process(new=new_picking)
|
|
||||||
|
|
||||||
@api.depends('move_type', 'immediate_transfer', 'move_ids.state', 'move_ids.picking_id')
|
@api.depends('move_type', 'immediate_transfer', 'move_ids.state', 'move_ids.picking_id')
|
||||||
def _compute_state(self):
|
def _compute_state(self):
|
||||||
|
|||||||
Reference in New Issue
Block a user