优化销售订单确认方法

This commit is contained in:
jinling.yang
2024-07-24 16:57:50 +08:00
parent c2c8d63848
commit 121861863f
2 changed files with 26 additions and 22 deletions

View File

@@ -14,6 +14,25 @@ class StatusChange(models.Model):
def action_confirm(self): def action_confirm(self):
# 在原有方法执行前记录日志和执行其他操作 # 在原有方法执行前记录日志和执行其他操作
logging.info('函数已经执行=============') logging.info('函数已经执行=============')
for order in self.order_lines:
for item in order.product_template_id.model_process_parameters_ids:
server_product = self.env['product.template'].search(
[('server_product_process_parameters_id', '=', item.surface_technics_parameters_id.id),
('detailed_type', '=', 'service')])
logging.info('server_product:%s' % server_product.name)
if server_product:
order_line_ids.append((0, 0, {
'product_id': server_product.product_variant_id.id,
'product_qty': 1,
'product_uom': server_product.uom_id.id
}))
self.env['purchase.order'].sudo().create({
'partner_id': server_product.seller_ids.partner_id.id,
'origin': record.production_id.name,
'state': 'draft',
'order_line': order_line_ids,
})
# 使用super()来调用原始方法(在本例中为'sale.order'模型的'action_confirm'方法) # 使用super()来调用原始方法(在本例中为'sale.order'模型的'action_confirm'方法)
res = super(StatusChange, self).action_confirm() res = super(StatusChange, self).action_confirm()

View File

@@ -989,28 +989,13 @@ class ResMrpWorkOrder(models.Model):
picking_out = record.env['stock.move.line'].search( picking_out = record.env['stock.move.line'].search(
[('picking_id', '=', record.picking_ids[0].id)]) [('picking_id', '=', record.picking_ids[0].id)])
logging.info('picking_out:%s' % picking_out.picking_id.name) logging.info('picking_out:%s' % picking_out.picking_id.name)
if picking_out: # if picking_out:
order_line_ids = [] # order_line_ids = []
logging.info('surface_technics_parameters_id:%s' % record.surface_technics_parameters_id.name) # logging.info('surface_technics_parameters_id:%s' % record.surface_technics_parameters_id.name)
server_product = self.env['product.template'].search( #
[('server_product_process_parameters_id', '=', record.surface_technics_parameters_id.id), # else:
('detailed_type', '=', 'service')]) # raise UserError(
logging.info('server_product:%s' % server_product.name) # '请先在产品中配置表面工艺为%s相关的外协服务产品' % item.surface_technics_parameters_id.name)
if server_product:
order_line_ids.append((0, 0, {
'product_id': server_product.product_variant_id.id,
'product_qty': 1,
'product_uom': server_product.uom_id.id
}))
self.env['purchase.order'].sudo().create({
'partner_id': server_product.seller_ids.partner_id.id,
'origin': record.production_id.name,
'state': 'draft',
'order_line': order_line_ids,
})
else:
raise UserError(
'请先在产品中配置表面工艺为%s相关的外协服务产品' % item.surface_technics_parameters_id.name)
tem_date_planned_finished = record.date_planned_finished tem_date_planned_finished = record.date_planned_finished
tem_date_finished = record.date_finished tem_date_finished = record.date_finished
logging.info('routing_type:%s' % record.routing_type) logging.info('routing_type:%s' % record.routing_type)