1、产品模型、制造订单模型、工单模型,添加人工编程字段;2、放开工单扫描绑定Rfid的检验功能;3、bfm下单创建产品添加人工报价字段内容;4、优化CNC程序用刀检验库区是否有刀的流程;
This commit is contained in:
@@ -1,4 +1,6 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
import logging
|
||||
|
||||
from datetime import timedelta
|
||||
from odoo import SUPERUSER_ID
|
||||
from odoo import fields, models, api
|
||||
@@ -191,7 +193,7 @@ class CAMWorkOrderProgramKnifePlan(models.Model):
|
||||
machine_table_name_id = fields.Many2one('maintenance.equipment', string='机床名称',
|
||||
domain="[('production_line_id', '=', production_line_id)]")
|
||||
machine_table_name = fields.Char(string='机台号', readonly=True, related='machine_table_name_id.name')
|
||||
cutter_spacing_code_id = fields.Many2one('maintenance.equipment.tool', string='刀位号', required=True,
|
||||
cutter_spacing_code_id = fields.Many2one('maintenance.equipment.tool', string='刀位号',
|
||||
domain="[('equipment_id', '=', machine_table_name_id)]")
|
||||
whether_standard_knife = fields.Boolean(string='是否标准刀', default=True)
|
||||
need_knife_time = fields.Datetime(string='用刀时间', readonly=False)
|
||||
@@ -201,19 +203,20 @@ class CAMWorkOrderProgramKnifePlan(models.Model):
|
||||
|
||||
barcode_id = fields.Many2one('stock.lot', string='功能刀具序列号',
|
||||
domain=[('product_id.name', '=', '功能刀具')])
|
||||
functional_tool_name = fields.Char(string='功能刀具名称', compute='_compute_functional_tool_name')
|
||||
functional_tool_type_id = fields.Many2one('sf.functional.cutting.tool.model', string='功能刀具类型', readonly=False)
|
||||
tool_groups_id = fields.Many2one('sf.tool.groups', '刀具组')
|
||||
diameter = fields.Integer(string='刀具直径(mm)', readonly=False)
|
||||
tool_included_angle = fields.Float(string='刀尖R角(mm)', readonly=False)
|
||||
tool_loading_length = fields.Float(string='总长度(mm)', readonly=False)
|
||||
functional_tool_name = fields.Char(string='功能刀具名称', readonly=True)
|
||||
functional_tool_type_id = fields.Many2one('sf.functional.cutting.tool.model', string='功能刀具类型',
|
||||
compute='_compute_tool_number', store=True)
|
||||
tool_groups_id = fields.Many2one('sf.tool.groups', '刀具组', compute='_compute_tool_number', store=True)
|
||||
diameter = fields.Integer(string='刀具直径(mm)', compute='_compute_tool_number', store=True)
|
||||
tool_included_angle = fields.Float(string='刀尖R角(mm)', compute='_compute_tool_number', store=True)
|
||||
tool_loading_length = fields.Float(string='总长度(mm)', compute='_compute_tool_number', store=True)
|
||||
extension_length = fields.Float(string='伸出长(mm)')
|
||||
effective_length = fields.Float(string='有效长(mm)')
|
||||
new_former = fields.Selection([('0', '新'), ('1', '旧')], string='新/旧', readonly=False, default='0')
|
||||
coarse_middle_thin = fields.Selection([("1", "粗"), ('2', '中'), ('3', '精')], default='3',
|
||||
string='粗/中/精', readonly=False)
|
||||
L_D = fields.Float(string='L/D值', readonly=False)
|
||||
clearance_length = fields.Float(string='避空长(mm)', readonly=False)
|
||||
clearance_length = fields.Float(string='避空长(mm)', compute='_compute_tool_number', store=True)
|
||||
required_cutting_time = fields.Integer(string='需切削时长', readonly=False)
|
||||
process_type = fields.Char('加工类型')
|
||||
margin_x_y = fields.Float('余量_X/Y')
|
||||
@@ -229,15 +232,24 @@ class CAMWorkOrderProgramKnifePlan(models.Model):
|
||||
|
||||
active = fields.Boolean(string='已归档', default=True)
|
||||
|
||||
@api.depends('diameter', 'tool_included_angle', 'tool_groups_id')
|
||||
def _compute_functional_tool_name(self):
|
||||
for obj in self:
|
||||
if obj.tool_groups_id:
|
||||
obj.functional_tool_name = '%s-D%sR%s' % (
|
||||
obj.tool_groups_id.name, obj.diameter,
|
||||
obj.tool_included_angle)
|
||||
@api.depends('functional_tool_name')
|
||||
def _compute_tool_number(self):
|
||||
for item in self:
|
||||
inventory = self.env['sf.tool.inventory'].sudo().search([('name', '=', item.functional_tool_name)])
|
||||
if inventory:
|
||||
item.functional_tool_type_id = inventory.functional_cutting_tool_model_id.id
|
||||
item.tool_groups_id = inventory.tool_groups_id.id
|
||||
item.diameter = int(inventory.diameter)
|
||||
item.tool_included_angle = inventory.angle
|
||||
item.tool_loading_length = inventory.tool_length
|
||||
item.clearance_length = inventory.blade_length
|
||||
else:
|
||||
obj.functional_tool_name = None
|
||||
item.functional_tool_type_id = False
|
||||
item.tool_groups_id = False
|
||||
item.diameter = 0
|
||||
item.tool_included_angle = 0
|
||||
item.tool_loading_length = 0
|
||||
item.clearance_length = 0
|
||||
|
||||
@api.model
|
||||
def _read_group_names(self, categories, domain, order):
|
||||
@@ -311,10 +323,9 @@ class CAMWorkOrderProgramKnifePlan(models.Model):
|
||||
根据传入的工单信息,查询是否有需要的功能刀具,如果没有则生成CAM工单程序用刀计划
|
||||
"""
|
||||
status = False
|
||||
if cnc_processing.functional_tool_type_id and cnc_processing.cutting_tool_name:
|
||||
if cnc_processing.cutting_tool_name:
|
||||
functional_tools = self.env['sf.real.time.distribution.of.functional.tools'].sudo().search(
|
||||
[('sf_cutting_tool_type_id', '=', cnc_processing.functional_tool_type_id.id),
|
||||
('name', '=', cnc_processing.cutting_tool_name)])
|
||||
[('name', '=', cnc_processing.cutting_tool_name)])
|
||||
if functional_tools:
|
||||
for functional_tool in functional_tools:
|
||||
if functional_tool.on_tool_stock_num == 0:
|
||||
@@ -327,7 +338,6 @@ class CAMWorkOrderProgramKnifePlan(models.Model):
|
||||
'name': cnc_processing.workorder_id.production_id.name,
|
||||
'cam_procedure_code': cnc_processing.program_name,
|
||||
'filename': cnc_processing.cnc_id.name,
|
||||
'functional_tool_type_id': cnc_processing.functional_tool_type_id.id,
|
||||
'functional_tool_name': cnc_processing.cutting_tool_name,
|
||||
'cam_cutter_spacing_code': cnc_processing.cutting_tool_no,
|
||||
'process_type': cnc_processing.processing_type,
|
||||
@@ -338,8 +348,11 @@ class CAMWorkOrderProgramKnifePlan(models.Model):
|
||||
'shank_model': cnc_processing.cutting_tool_handle_type,
|
||||
'estimated_processing_time': cnc_processing.estimated_processing_time,
|
||||
})
|
||||
logging.info('CAM工单程序用刀计划创建成功!!!')
|
||||
# 创建装刀请求
|
||||
knife_plan.apply_for_tooling()
|
||||
else:
|
||||
logging.info('功能刀具【%s】满足CNC用刀需求!!!')
|
||||
|
||||
|
||||
class FunctionalToolAssembly(models.Model):
|
||||
|
||||
@@ -36,6 +36,7 @@ class CNCprocessing(models.Model):
|
||||
obj = super(CNCprocessing, self).create(vals)
|
||||
# 调用CAM工单程序用刀计划创建方法
|
||||
self.env['sf.cam.work.order.program.knife.plan'].create_cam_work_plan(obj)
|
||||
logging.info('成功调用CAM工单程序用刀计划创建方法!!!')
|
||||
return obj
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user