批量处理工艺调整
This commit is contained in:
@@ -17,11 +17,41 @@ class ProductionTechnologyReAdjustWizard(models.TransientModel):
|
||||
domain = [('origin', '=', self.origin), ('state', '=', 'confirmed')]
|
||||
else:
|
||||
domain = [('id', '=', self.production_id.id)]
|
||||
technology_designs = self.production_id.technology_design_ids
|
||||
productions = self.env['mrp.production'].search(domain)
|
||||
workorders_values = []
|
||||
for item in productions:
|
||||
for production_my in productions:
|
||||
# 该制造订单的其他同一销售订单的制造订单的工艺设计处理
|
||||
if production_my != self.production_id:
|
||||
for td_other in production_my.technology_design_ids:
|
||||
for td_main in technology_designs:
|
||||
route_other = production_my.technology_design_ids.filtered(
|
||||
lambda td: td.route_id.id == td_main.route_id.id)
|
||||
if not route_other:
|
||||
production_my.write({'technology_design_ids': [(0, 0, {
|
||||
'route_id': td_main.route_id.id,
|
||||
'process_parameters_id': False if td_main.process_parameters_id is False else
|
||||
self.env[
|
||||
'sf.production.process.parameter'].search(
|
||||
[('id', '=', td_main.process_parameters_id.id)]).id,
|
||||
'sequence': td_main.sequence})]})
|
||||
else:
|
||||
if td_main.route_id == td_other.route_id:
|
||||
if td_main.route_id.routing_type == '表面工艺':
|
||||
display_name = td_main.process_parameters_id.display_name
|
||||
else:
|
||||
display_name = td_main.route_id.display_name
|
||||
if (td_main.panel is not False and td_main.panel == td_other.panel) or (
|
||||
display_name == td_other.display_name):
|
||||
if td_main.sequence != td_other.sequence:
|
||||
td_other.write({'sequence': td_main.sequence})
|
||||
logging.info(td_main.route_id.name)
|
||||
logging.info(td_main.sequence)
|
||||
logging.info(td_other.route_id.name)
|
||||
logging.info(td_other.sequence)
|
||||
|
||||
special_design = self.env['sf.technology.design'].sudo().search(
|
||||
[('routing_tag', '=', 'special'), ('production_id', '=', item.id),
|
||||
[('routing_tag', '=', 'special'), ('production_id', '=', production_my.id),
|
||||
('is_auto', '=', False), ('active', 'in', [True, False])])
|
||||
for special in special_design:
|
||||
if special.active is False:
|
||||
@@ -42,7 +72,12 @@ class ProductionTechnologyReAdjustWizard(models.TransientModel):
|
||||
if line.product_id.server_product_process_parameters_id == workorder.surface_technics_parameters_id:
|
||||
purchase_order.write({'state': 'cancel'})
|
||||
else:
|
||||
workorder = self.env['mrp.workorder'].search([('name', '=', special.route_id.display_name)])
|
||||
if special.route_id.routing_type == '表面工艺':
|
||||
display_name = special.process_parameters_id.display_name
|
||||
else:
|
||||
display_name = special.route_id.display_name
|
||||
workorder = self.env['mrp.workorder'].search(
|
||||
[('name', '=', display_name), ('production_id', '=', special.production_id.id)])
|
||||
if not workorder:
|
||||
if special.route_id.routing_type == '表面工艺':
|
||||
product_production_process = self.env['product.template'].search(
|
||||
@@ -57,10 +92,16 @@ class ProductionTechnologyReAdjustWizard(models.TransientModel):
|
||||
else:
|
||||
workorders_values.append(
|
||||
self.env['mrp.workorder'].json_workorder_str(special.production_id, special))
|
||||
if workorders_values:
|
||||
productions.write({'workorder_ids': workorders_values})
|
||||
productions.get_subcontract_pick()
|
||||
productions._reset_work_order_sequence()
|
||||
special.production_id.write({'workorder_ids': workorders_values})
|
||||
special.production_id.get_subcontract_pick()
|
||||
special.production_id._reset_work_order_sequence()
|
||||
workorders_values = []
|
||||
else:
|
||||
if len(workorder.blocked_by_workorder_ids) > 1:
|
||||
if workorder.sequence == 1:
|
||||
workorder.blocked_by_workorder_ids = None
|
||||
else:
|
||||
workorder.blocked_by_workorder_ids = blocked_by_workorder_ids[0]
|
||||
for item in productions:
|
||||
workorder = item.workorder_ids.filtered(lambda wo: wo.state not in ('cancel')).sorted(
|
||||
key=lambda a: a.sequence)
|
||||
|
||||
@@ -18,8 +18,24 @@ class ProductionTechnologyWizard(models.TransientModel):
|
||||
domain = [('origin', '=', self.origin)]
|
||||
else:
|
||||
domain = [('id', '=', self.production_id.id)]
|
||||
technology_designs = self.production_id.technology_design_ids
|
||||
productions = self.env['mrp.production'].search(domain)
|
||||
for production in productions:
|
||||
if production != self.production_id:
|
||||
for td_other in production.technology_design_ids:
|
||||
for td_main in technology_designs:
|
||||
route_other = production.technology_design_ids.filtered(
|
||||
lambda td: td.route_id.id == td_main.route_id.id)
|
||||
if not route_other:
|
||||
production.write({'technology_design_ids': [(0, 0, {
|
||||
'route_id': td_main.route_id.id,
|
||||
'process_parameters_id': False if td_main.process_parameters_id is False else self.env[
|
||||
'sf.production.process.parameter'].search(
|
||||
[('id', '=', td_main.process_parameters_id.id)]).id,
|
||||
'sequence': td_main.sequence})]})
|
||||
else:
|
||||
if td_main.sequence != td_other.sequence:
|
||||
td_other.sequence = td_main.sequence
|
||||
special = production.technology_design_ids.filtered(
|
||||
lambda td: td.is_auto is False and td.process_parameters_id is not False)
|
||||
if special:
|
||||
@@ -28,4 +44,5 @@ class ProductionTechnologyWizard(models.TransientModel):
|
||||
for item in productions:
|
||||
workorder = item.workorder_ids.filtered(lambda wo: wo.state not in ('cancel')).sorted(
|
||||
key=lambda a: a.sequence)
|
||||
workorder[0].state = 'waiting'
|
||||
if workorder[0].state in ['pending']:
|
||||
workorder[0].state = 'waiting'
|
||||
|
||||
Reference in New Issue
Block a user