diff --git a/sf_base/__manifest__.py b/sf_base/__manifest__.py index 60077453..71af29bc 100644 --- a/sf_base/__manifest__.py +++ b/sf_base/__manifest__.py @@ -19,8 +19,8 @@ 'views/fixture_view.xml', 'views/functional_fixture_view.xml', 'views/menu_view.xml', - "views/tool_views.xml", - "views/tool_menu.xml", + 'views/tool_views.xml', + 'views/tool_menu.xml', 'views/menu_fixture_view.xml', ], diff --git a/sf_base/models/tool_base.py b/sf_base/models/tool_base.py deleted file mode 100644 index 24a39ecc..00000000 --- a/sf_base/models/tool_base.py +++ /dev/null @@ -1,304 +0,0 @@ -# -*- coding: utf-8 -*- -import logging - -from odoo import fields, models, api -# from odoo.exceptions import UserError -# # from odoo.addons import sf_base, sf_common -# from datetime import datetime - - -# 功能刀具物料 -class CuttingToolMaterial(models.Model): - _name = 'sf.cutting.tool.material' - _description = '刀具物料' - - code = fields.Char('编码') - name = fields.Char('名称') - remark = fields.Char('备注') - active = fields.Boolean('有效', default=True) - - -# 功能刀具 -class FunctionalCuttingTool(models.Model): - _name = 'sf.functional.cutting.tool' - _description = '功能刀具' - - code = fields.Char('编码') - name = fields.Char('名称') - functional_model_number = fields.Many2one('sf.functional.cutting.tool.model', string='功能刀具类型') - integral_model_number = fields.Many2one('sf.integral.cutting.tool', string='整体式刀具型号') - blade_model_number = fields.Many2one('sf.blade', string='刀片型号') - cutterbar_model_number = fields.Many2one('sf.cutter.bar', string='刀杆型号') - cutterpad_model_number = fields.Many2one('sf.cutter.pad', string='刀盘型号') - handle_model_number = fields.Many2one('sf.handle', string='刀柄型号') - chuck_model_number = fields.Many2one('sf.chuck', string='夹头型号') - diameter = fields.Float('直径(mm)') - tool_grade = fields.Selection([('1', 'P1'), ('2', 'P2'), ('3', 'P3'), ('4', 'P4'), ('5', 'P5'), ('6', 'P6')], - string='刀具等级') - machining_accuracy = fields.Float('加工精度(mm)') - tool_length = fields.Float('装刀长') - blade_number = fields.Integer('刃数') - integral_blade_length = fields.Float('整体刃长(mm)') - effective_blade_length = fields.Float('有效刃长(mm)') - max_life = fields.Float('最大寿命值') - is_standard = fields.Boolean('是否标准刀') - applicable_range = fields.Char('适用范围') - image = fields.Binary('图片') - active = fields.Boolean('有效', default=True) - - -# 功能刀具类型 -class FunctionalCuttingToolModel(models.Model): - _name = 'sf.functional.cutting.tool.model' - _description = '功能刀具类型' - - name = fields.Char('名称') - code = fields.Char('编码') - remark = fields.Char('备注') - active = fields.Boolean('有效', default=True) - - -# 整体式刀具 -class IntegralCuttingTool(models.Model): - _name = 'sf.integral.cutting.tool' - _description = '整体式刀具' - - code = fields.Char('编码') - name = fields.Char('型号名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - # 整体式刀具类型字段,关联整体式刀具类型对象 - integral_model_number = fields.Many2one('sf.integral.cutting.tool.model', '整体式刀具类型') - # 增加品牌、总长度(mm)、柄部长度(mm)、刃部长度(mm)、直径(mm)、刃数、前角(°)、后角(°)、主偏角(°)、材料型号、配对螺母(mm)、适用夹头型号、适用范围、图片、创建人、创建时间等字段 - brand = fields.Many2one('sf.machine.brand', '品牌', domain="[('tag_ids.name', 'ilike', '刀具')]") - total_length = fields.Float('总长度(mm)') - shank_length = fields.Float('柄部长度(mm)') - blade_length = fields.Float('刃部长度(mm)') - diameter = fields.Float('直径(mm)') - blade_number = fields.Integer('刃数') - front_angle = fields.Float('前角(°)') - rear_angle = fields.Float('后角(°)') - main_included_angle = fields.Float('主偏角(°)') - material_model = fields.Many2one('sf.materials.model', '材料型号') - nut = fields.Float('配对螺母(mm)') - # 适用夹头型号可以多选 - chuck_model = fields.Many2many('sf.chuck', string='适用夹头型号') - scope = fields.Char('适用范围') - image = fields.Binary('图片') - active = fields.Boolean('有效', default=True) - - -# 整体式刀具类型 -class IntegralCuttingToolModel(models.Model): - _name = 'sf.integral.cutting.tool.model' - _description = '整体式刀具类型' - - code = fields.Char('编码') - name = fields.Char('名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - remark = fields.Char('备注') - - -# 刀片 -class Blade(models.Model): - _name = 'sf.blade' - _description = '刀片' - - code = fields.Char('编码') - name = fields.Char('型号名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - # 刀片类型字段,关联刀片类型对象 - blade_model_number = fields.Many2one('sf.blade.model', '刀片类型') - # 编码、型号名称、刀片类型、品牌、长度L(mm)、宽度D(mm)、高度T(mm)、顶角(°)、前角(°)、后角(°)、主偏角(°)、R角(°)、材料型号、加工硬度、配对螺母(mm)、适用刀杆/刀盘型号、刀尖半径(mm)、图片、创建人、创建时间字段 - brand = fields.Many2one('sf.machine.brand', '品牌', ) - length = fields.Float('长度L(mm)') - width = fields.Float('宽度D(mm)') - height = fields.Float('高度T(mm)') - top_angle = fields.Float('顶角(°)') - front_angle = fields.Float('前角(°)') - rear_angle = fields.Float('后角(°)') - main_included_angle = fields.Float('主偏角(°)') - r_angle = fields.Float('R角(°)') - material_model = fields.Many2one('sf.materials.model', '材料型号') - hardness = fields.Char('加工硬度') - nut = fields.Float('配对螺母(mm)') - # 适用刀杆型号可以多选 - cutter_bar = fields.Many2many('sf.cutter.bar', string='适用刀杆型号') - # 适用刀盘型号可以多选 - cutter_pad = fields.Many2many('sf.cutter.pad', string='适用刀盘型号') - radius = fields.Float('刀尖半径(mm)') - image = fields.Binary('图片') - - -# 刀片类型 -class BladeModel(models.Model): - _name = 'sf.blade.model' - _description = '刀片类型' - - code = fields.Char('编码') - name = fields.Char('名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - # 刀片类型字段,关联刀片对象 - blade_ids = fields.One2many('sf.blade', 'blade_model_number', '刀片类型') - remark = fields.Char('备注') - - -# 刀杆 -class CutterBar(models.Model): - _name = 'sf.cutter.bar' - _description = '刀杆' - - code = fields.Char('编码') - name = fields.Char('型号名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - # 刀杆类型字段,关联刀杆类型对象 - cutter_bar_model_number = fields.Many2one('sf.cutter.bar.model', '刀杆类型') - # 品牌、C柄径(mm)、L总长(mm)、材料型号、刃数、D刃径(mm)、适用刀片型号、配对扳手(mm)、配备螺丝(mm)、刀尖圆角半径、精度等级、硬度(°)、适用范围、图片、创建人、创建时间 - brand = fields.Many2one('sf.machine.brand', '品牌') - c_diameter = fields.Float('C柄径(mm)') - total_length = fields.Float('L总长(mm)') - material_model = fields.Many2one('sf.materials.model', '材料型号') - blade_number = fields.Integer('刃数') - d_diameter = fields.Float('D刃径(mm)') - blade = fields.Many2many('sf.blade', string='适用刀片型号') - wrench = fields.Float('配对扳手(mm)') - screw = fields.Float('配备螺丝(mm)') - radius = fields.Float('刀尖圆角半径') - accuracy = fields.Char('精度等级') - hardness = fields.Char('硬度(°)') - scope = fields.Char('适用范围') - image = fields.Binary('图片') - - -# 刀杆类型 -class CutterBarModel(models.Model): - _name = 'sf.cutter.bar.model' - _description = '刀杆类型' - - code = fields.Char('编码') - name = fields.Char('名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - remark = fields.Char('备注') - - -# 刀盘 -class CutterPad(models.Model): - _name = 'sf.cutter.pad' - _description = '刀盘' - - code = fields.Char('编码') - name = fields.Char('型号名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - # 刀盘类型字段,关联刀盘类型对象 - cutter_pad_model_number = fields.Many2one('sf.cutter.pad.model', '刀盘类型') - # 增加品牌、C柄径(mm)、L总长(mm)、材料型号、刃数、D刃径(mm)、适用刀片型号、配对扳手(mm)、配备螺丝(mm)、刀尖圆角半径、精度等级、硬度(°)、适用范围、图片、创建人、创建时间 - brand = fields.Many2one('sf.machine.brand', '品牌') - c_diameter = fields.Float('C柄径(mm)') - total_length = fields.Float('L总长(mm)') - material_model = fields.Many2one('sf.materials.model', '材料型号') - blade_number = fields.Integer('刃数') - d_diameter = fields.Float('D刃径(mm)') - blade = fields.Many2many('sf.blade', string='适用刀片型号') - wrench = fields.Float('配对扳手(mm)') - screw = fields.Float('配备螺丝(mm)') - radius = fields.Float('刀尖圆角半径') - accuracy = fields.Char('精度等级') - hardness = fields.Char('硬度(°)') - scope = fields.Char('适用范围') - image = fields.Binary('图片') - - -# 刀盘类型 -class CutterPadModel(models.Model): - _name = 'sf.cutter.pad.model' - _description = '刀盘类型' - - code = fields.Char('编码') - name = fields.Char('名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - remark = fields.Char('备注') - - -# 刀柄 -class Handle(models.Model): - _name = 'sf.handle' - _description = '刀柄' - - code = fields.Char('编码') - name = fields.Char('型号名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - # 刀柄类型字段,关联刀柄类型对象 - handle_model_number = fields.Many2one('sf.handle.model', '刀柄类型') - # 增加、刀柄类型、品牌、L(mm)、L1(mm)、D1(mm)、重量(kg)、材料型号、本体精度(mm)、配对螺母(mm)、适用夹头型号、夹持范围(mm)、检测精度、检测硬度、标准转速、图片、创建人、创建时间 - brand = fields.Many2one('sf.machine.brand', '品牌') - length = fields.Float('L(mm)') - length1 = fields.Float('L1(mm)') - diameter1 = fields.Float('D1(mm)') - weight = fields.Float('重量(kg)') - material_model = fields.Many2one('sf.materials.model', '材料型号') - body_accuracy = fields.Float('本体精度(mm)') - nut = fields.Float('配对螺母(mm)') - chuck_model = fields.Many2many('sf.chuck.model', string='适用夹头型号') - clamping_range = fields.Float('夹持范围(mm)') - detection_accuracy = fields.Float('检测精度') - detection_hardness = fields.Char('检测硬度') - standard_speed = fields.Float('标准转速') - image = fields.Binary('图片') - - -# 刀柄类型 -class HandleModel(models.Model): - _name = 'sf.handle.model' - _description = '刀柄类型' - - code = fields.Char('编码') - name = fields.Char('名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - remark = fields.Char('备注') - - -# 夹头对象(夹头型号对象) -class Chuck(models.Model): - _name = 'sf.chuck' - _description = '夹头' - _rec_name = 'code' - - code = fields.Char('编码') - name = fields.Char('型号名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - # 夹头类型字段,关联夹头类型对象 - chuck_model_number = fields.Many2one('sf.chuck.model', '夹头类型') - # 增加品牌、精度(mm)、外径(mm)、内径(mm)、高度(mm)、材料型号、配对螺母(mm)、适用刀柄型号、夹持范围(mm)、特性、图片、创建人、创建时间 - brand = fields.Many2one('sf.machine.brand', '品牌') - accuracy = fields.Float('精度(mm)') - diameter = fields.Float('外径(mm)') - inner_diameter = fields.Float('内径(mm)') - height = fields.Float('高度(mm)') - material_model = fields.Many2one('sf.materials.model', '材料型号') - nut = fields.Float('配对螺母(mm)') - handle_model = fields.Many2many('sf.handle.model', string='适用刀柄型号') - clamping_range = fields.Float('夹持范围(mm)') - feature = fields.Char('特性') - image = fields.Binary('图片') - - -# 夹头类型 -class ChuckModel(models.Model): - _name = 'sf.chuck.model' - _description = '夹头类型' - - code = fields.Char('编码') - name = fields.Char('名称') - # 关联刀具物料 - cutting_tool_material = fields.Many2one('sf.cutting.tool.material', '刀具物料') - remark = fields.Char('备注') diff --git a/sf_base/models/tool_base_new.py b/sf_base/models/tool_base_new.py index c0f84ed9..b4660948 100644 --- a/sf_base/models/tool_base_new.py +++ b/sf_base/models/tool_base_new.py @@ -103,6 +103,14 @@ class CuttingToolType(models.Model): remark = fields.Char('备注') active = fields.Boolean('有效', default=True) + def _get_ids(self, cutting_tool_type_code): + cutting_tool_type_ids = [] + for item in cutting_tool_type_code: + cutting_tool_type = self.search([('code', '=', item)]) + if cutting_tool_type: + cutting_tool_type_ids.append(cutting_tool_type.id) + return [(6, 0, cutting_tool_type_ids)] + # 刀具标准库 class CuttingToolModel(models.Model): @@ -148,13 +156,28 @@ class CuttingToolModel(models.Model): '适合冷却液', domain=[('type', '=', '冷却液')]) compaction_way_ids = fields.Many2many('maintenance.equipment.image', 'compaction_way_library_rel', '压紧方式', domain=[('type', '=', '压紧方式')]) - basic_parameters_ids = fields.One2many('sf.tool.materials.basic.parameters', - 'standard_library_id', string='基本参数') + integral_tool_basic_parameters_ids = fields.One2many('sf.tool.materials.basic.parameters', + 'standard_library_id', string='整体式刀具基本参数') + blade_basic_parameters_ids = fields.One2many('sf.tool.materials.basic.parameters', + 'standard_library_id', string='刀片基本参数') + cutter_bar_basic_parameters_ids = fields.One2many('sf.tool.materials.basic.parameters', + 'standard_library_id', string='刀杆基本参数') + cutter_head_basic_parameters_ids = fields.One2many('sf.tool.materials.basic.parameters', + 'standard_library_id', string='刀盘基本参数') + knife_handle_basic_parameters_ids = fields.One2many('sf.tool.materials.basic.parameters', + 'standard_library_id', string='刀柄基本参数') + chuck_basic_parameters_ids = fields.One2many('sf.tool.materials.basic.parameters', + 'standard_library_id', string='夹头基本参数') cutting_speed_ids = fields.One2many('sf.cutting.speed', 'standard_library_id', string='切削速度Vc') - feed_per_tooth_ids = fields.One2many('sf.feed.per.tooth', 'standard_library_id', '每齿走刀量fz') - + feed_per_tooth_ids = fields.One2many('sf.feed.per.tooth', 'standard_library_id', '每齿走刀量fz', + domain=[('cutting_speed', '!=', False)]) + feed_per_tooth_ids_2 = fields.One2many('sf.feed.per.tooth', 'standard_library_id', '每齿走刀量fz', + domain=[('machining_method', '!=', False)]) + feed_per_tooth_ids_3 = fields.One2many('sf.feed.per.tooth', 'standard_library_id', '每齿走刀量fz', + domain=[('cutting_speed', '!=', False)]) + feed_per_tooth_ids_4 = fields.One2many('sf.feed.per.tooth', 'standard_library_id', '每齿走刀量fz', + domain=[('machining_method', '!=', False)]) material_model_id = fields.Many2one('sf.materials.model', '材料型号') - nut = fields.Float('配对螺母(mm)') # 适用夹头型号可以多选 chuck_ids = fields.Many2many( 'sf.cutting.tool.type', @@ -163,8 +186,6 @@ class CuttingToolModel(models.Model): column2='model_id_2', domain="[('cutting_tool_material_id.name', '=', '夹头')]", string='适用夹头型号') - - working_hardness = fields.Char('加工硬度(hrc)') cutter_bar_ids = fields.Many2many( 'sf.cutting.tool.type', relation='cutting_tool_type_library_cutter_bar_rel', @@ -182,7 +203,6 @@ class CuttingToolModel(models.Model): string='适用刀盘型号' # 使用空列表作为默认值 ) # 刀杆/参数 - blade_diameter = fields.Float('刃径(mm)') blade_ids = fields.Many2many( 'sf.cutting.tool.type', relation='cutting_tool_type_library_pad_blade_rel', @@ -202,8 +222,8 @@ class CuttingToolModel(models.Model): active = fields.Boolean('有效', default=True) is_cloud = fields.Boolean('云端数据', default=False) - def get_cutter_bar_ids(self): - return self.cutter_bar_ids + # def get_cutter_bar_ids(self): + # return self.cutter_bar_ids class MaintenanceStandardImage(models.Model): @@ -219,6 +239,14 @@ class MaintenanceStandardImage(models.Model): string='特征') equipment_id = fields.Many2many('maintenance.equipment', 'image_id', string='设备') + def _get_ids(self, name_arr): + ability_feature_ids = [] + for item in name_arr: + ability_feature = self.search([('name', '=', item)]) + if ability_feature: + ability_feature_ids.append(ability_feature.id) + return [(6, 0, ability_feature_ids)] + @api.model def name_search(self, name='', args=None, operator='ilike', limit=100): # 调用父类的name_search方法,获取原始的结果列表 diff --git a/sf_base/models/tool_other_features.py b/sf_base/models/tool_other_features.py index 97bb0645..b4f8b191 100644 --- a/sf_base/models/tool_other_features.py +++ b/sf_base/models/tool_other_features.py @@ -113,6 +113,7 @@ class ToolMaterialsBasicParameters(models.Model): weight = fields.Char('重量(kg)', size=20) clamping_length = fields.Char('夹持长度(mm)', size=20) clamping_tolerance = fields.Char('夹持公差(mm)', size=20) + cooling_jacket = fields.Char('适用冷却套型号', size=50) handle_ids = fields.Many2many( 'sf.cutting.tool.type', relation='basic_param_chuck_handle_rel', @@ -122,25 +123,33 @@ class ToolMaterialsBasicParameters(models.Model): string='适用刀柄型号' ) - def _json_basic_param(self, obj): - basic_param_str = [0, '', { + def _json_integral_tool_basic_param(self, obj): + integral_tool_basic_param_str = (0, '', { 'code': obj['code'], + 'cutting_tool_type': obj['cutting_tool_type'], 'total_length': obj['total_length'], + 'blade_diameter': obj['blade_diameter'], + 'blade_length': obj['blade_length'], 'blade_number': obj['blade_number'], - 'neck_diameter': obj['neck_diameter'], 'neck_length': obj['neck_length'], + 'neck_diameter': obj['neck_diameter'], 'handle_diameter': obj['handle_diameter'], 'handle_length': obj['handle_length'], 'blade_tip_diameter': obj['blade_tip_diameter'], 'blade_tip_working_size': obj['blade_tip_working_size'], 'blade_tip_taper': obj['blade_tip_taper'], - 'blade_diameter': obj['blade_diameter'], - 'blade_length': obj['blade_length'], 'blade_helix_angle': obj['blade_helix_angle'], 'blade_width': obj['blade_width'], 'blade_depth': obj['blade_depth'], 'pitch': obj['pitch'], 'cutting_depth': obj['cutting_depth'], + }) + return integral_tool_basic_param_str + + def _json_blade_basic_param(self, obj): + blade_basic_param_str = (0, '', { + 'code': obj['code'], + 'cutting_tool_type': obj['cutting_tool_type'], 'length': obj['length'], 'thickness': obj['thickness'], 'width': obj['width'], @@ -149,9 +158,12 @@ class ToolMaterialsBasicParameters(models.Model): 'blade_tip_circular_arc_radius': obj['blade_tip_circular_arc_radius'], 'inscribed_circle_diameter': obj['inscribed_circle_diameter'], 'install_aperture_diameter': obj['install_aperture_diameter'], + 'pitch': obj['pitch'], 'chip_breaker_groove': obj['chip_breaker_groove'], 'blade_teeth_model': obj['bladed_teeth_model'], 'blade_blade_number': obj['blade_blade_number'], + 'cutting_depth': obj['cutting_depth'], + 'blade_width': obj['blade_width'], 'main_included_angle': obj['main_included_angle'], 'top_angle': obj['top_angle'], 'blade_tip_dip_angle': obj['blade_tip_dip_angle'], @@ -161,22 +173,68 @@ class ToolMaterialsBasicParameters(models.Model): 'blade_tip_height_tolerance': obj['blade_tip_height_tolerance'], 'inscribed_circle_tolerance': obj['inscribed_circle_tolerance'], 'thickness_tolerance': obj['thickness_tolerance'], + }) + return blade_basic_param_str + + def _json_cutter_arbor_basic_param(self, obj): + cutter_arbor_basic_param_str = (0, '', { + 'code': obj['code'], + 'cutting_tool_type': obj['cutting_tool_type'], 'height': obj['height'], + 'width': obj['width'], + 'blade_height': obj['blade_height'], + 'total_length': obj['total_length'], + 'blade_width': obj['blade_width'], + 'blade_length': obj['blade_length'], 'blade_height': obj['blade_height'], 'cutter_arbor_diameter': obj['cutter_arbor_diameter'], + 'main_included_angle': obj['main_included_angle'], + 'relief_angle': obj['relief_angle'], + 'cutting_depth': obj['cutting_depth'], 'min_machining_aperture': obj['min_machining_aperture'], 'install_blade_tip_num': obj['install_blade_tip_num'], 'cutting_blade_model': obj['cutting_blade_model'], 'cooling_hole': obj['cooling_hole'], 'locating_slot_code': obj['locating_slot_code'], 'installing_structure': obj['installing_structure'], + 'blade_ids': [(6, 0, [])] if not obj.get('blade_codes') else self.evn['sf.cutting.tool.type']._get_ids( + obj['blade_codes']), 'tool_shim': obj['tool_shim'], 'cotter_pin': obj['cotter_pin'], 'pressing_plate': obj['pressing_plate'], 'screw': obj['screw'], 'spanner': obj['spanner'], + }) + return cutter_arbor_basic_param_str + + def _json_cutter_head_basic_param(self, obj): + cutter_head_basic_param_str = (0, '', { + 'code': obj['code'], + 'cutting_tool_type': obj['cutting_tool_type'], + 'install_blade_tip_num': obj['install_blade_tip_num'], + 'blade_diameter': obj['blade_diameter'], 'cutter_head_diameter': obj['cutter_head_diameter'], 'interface_diameter': obj['interface_diameter'], + 'total_length': obj['total_length'], + 'blade_length': obj['blade_length'], + 'cutting_depth': obj['cutting_depth'], + 'main_included_angle': obj['main_included_angle'], + 'installing_structure': obj['installing_structure'], + 'blade_ids': [(6, 0, [])] if not obj.get('blade_codes') else self.evn['sf.cutting.tool.type']._get_ids( + obj['blade_codes']), + 'screw': obj['screw'], + 'spanner': obj['spanner'], + 'cutting_blade_model': obj['cutting_blade_model'], + 'cooling_hole': obj['cooling_hole'], + 'locating_slot_code': obj['locating_slot_code'], + }) + return cutter_head_basic_param_str + + def _json_knife_handle_basic_param(self, obj): + knife_handle_basic_param_str = (0, '', { + 'code': obj['code'], + 'cutting_tool_type': obj['cutting_tool_type'], + 'total_length': obj['total_length'], 'flange_shank_length': obj['flange_shank_length'], 'handle_external_diameter': obj['handle_external_diameter'], 'handle_inside_diameter': obj['handle_inside_diameter'], @@ -190,23 +248,40 @@ class ToolMaterialsBasicParameters(models.Model): 'max_rotate_speed': obj['max_rotate_speed'], 'diameter_slip_accuracy': obj['diameter_slip_accuracy'], 'cooling_model': obj['cooling_model'], - 'is_rough_machining': obj['is_rough_machining'], - 'is_finish_machining': obj['is_finish_machining'], - 'is_quick_cutting': obj['is_quick_cutting'], - 'is_drill_hole': obj['is_drill_hole'], - 'is_safe_lock': obj['is_safe_lock'], + 'is_rough_machining': obj['whether_rough_machining'], + 'is_finish_machining': obj['whether_finish_machining'], + 'is_quick_cutting': obj['whether_quick_cutting'], + 'is_drill_hole': obj['whether_drill_hole'], + 'is_safe_lock': obj['whether_safe_lock'], + 'screw': obj['screw'], + 'spanner': obj['spanner'], + }) + return knife_handle_basic_param_str + + def _json_chuck_basic_param(self, obj): + chuck_basic_param_str = (0, '', { + 'code': obj['code'], + 'cutting_tool_type': obj['cutting_tool_type'], 'er_size_model': obj['er_size_model'], + 'min_clamping_diameter': obj['min_clamping_diameter'], + 'max_clamping_diameter': obj['max_clamping_diameter'], 'outer_diameter': obj['outer_diameter'], 'inner_diameter': obj['inner_diameter'], 'run_out_accuracy': obj['run_out_accuracy'], + 'total_length': obj['total_length'], + 'taper': obj['taper'], + 'run_out_accuracy': obj['run_out_accuracy'], 'top_diameter': obj['top_diameter'], 'weight': obj['weight'], + 'clamping_mode': obj['clamping_mode'], 'clamping_length': obj['clamping_length'], 'clamping_tolerance': obj['clamping_tolerance'], - 'handle_ids': obj['weight'], - 'blade_ids': obj['clamping_length'], - }] - return basic_param_str + 'max_load_capacity': obj['max_load_capacity'], + 'handle_ids': [(6, 0, [])] if not obj.get( + 'handle_codes') else self.evn['sf.cutting.tool.type']._get_ids(obj['handle_codes']), + 'cooling_jacket': obj['cooling_jacket'], + }) + return chuck_basic_param_str class CuttingSpeed(models.Model): @@ -215,11 +290,13 @@ class CuttingSpeed(models.Model): # product_template_id = fields.Many2one('product.template', string='产品') standard_library_id = fields.Many2one('sf.cutting_tool.standard.library', string='标准库') - execution_standard_id = fields.Char('执行标准') + execution_standard_id = fields.Many2one('sf.international.standards', string='执行标准', store=True) material_code = fields.Char('材料代号') - material_name = fields.Char('材料名称') + material_id = fields.Many2one('sf.materials.model', '材料名称', + domain="[('standards_id', '=', execution_standard_id)]") + slope_milling_angle = fields.Integer('坡铣角度(°)') material_grade = fields.Char('材料牌号') - tensile_strength = fields.Float('拉伸强度 (N/mm²)') + tensile_strength = fields.Char('拉伸强度 (N/mm²)') hardness = fields.Float('硬度(HRC)') cutting_speed_n1 = fields.Char('径向切宽 ae=100%D1 ap=1*D1 切削速度Vc') cutting_speed_n2 = fields.Char('径向切宽 ae=50%D1 ap=1.5*D1 切削速度Vc') @@ -231,10 +308,11 @@ class CuttingSpeed(models.Model): application = fields.Selection([('主应用', '主应用'), ('次应用', '次应用')], '主/次应用') def _json_cutting_speed(self, obj): - cutting_speed_str = [0, '', { - 'execution_standard_id': obj['execution_standard_id'], + cutting_speed_str = (0, '', { + 'execution_standard_id': self.env['sf.international.standards'].search( + [('code', '=', obj['execution_standard_code'])]).id, 'material_code': obj['material_code'], - 'material_name': obj['material_name'], + 'material_id': self.env['sf.materials.model'].search([('materials_no', '=', obj['material_name_code'])]).id, 'material_grade': obj['material_grade'], 'tensile_strength': obj['tensile_strength'], 'hardness': obj['hardness'], @@ -246,36 +324,57 @@ class CuttingSpeed(models.Model): 'rough_machining': obj['rough_machining'], 'precision_machining': obj['precision_machining'], 'application': obj['application'], - }] + }) return cutting_speed_str class FeedPerTooth(models.Model): _name = 'sf.feed.per.tooth' _description = '每齿走刀量fz' + _order = 'machining_method desc, blade_diameter, materials_type_id' # product_template_id = fields.Many2one('product.template', string='产品') standard_library_id = fields.Many2one('sf.cutting_tool.standard.library', string='标准库') - cutting_speed = fields.Char('径向切宽 ae(mm)') machining_method = fields.Selection([('直铣', '直铣'), ('坡铣', '坡铣')], string='加工方式') materials_type_id = fields.Many2one('sf.materials.model', string='材料型号') - # blade_diameter = fields.Float('刃部直径D1(mm)', readonly=True, - # related='product_template_id.cutting_tool_blade_diameter') + blade_diameter = fields.Char('刃部直径(mm)', readonly=True) feed_per_tooth = fields.Char('每齿走刀量 (mm/z)') - unit = fields.Char('单位', default='fz') def _json_feed_per_tooth(self, obj): - feed_per_tooth_str = [0, '', { + feed_per_tooth_str = (0, '', { 'cutting_speed': obj['cutting_speed'], - 'machining_method': obj['machining_method'], - 'materials_type_id': obj['materials_type_id'], - # 'blade_diameter': obj['blade_diameter'], + 'blade_diameter': obj['blade_diameter'], 'feed_per_tooth': obj['feed_per_tooth'], - 'unit': obj['unit'], - }] + }) return feed_per_tooth_str + def _json_feed_per_tooth_2(self, obj): + feed_per_tooth_2_str = (0, '', { + 'machining_method': obj['machining_method'], + 'materials_type_id': self.env['sf.materials.model'].search( + [('materials_no', '=', obj['materials_type_code'])]).id, + 'blade_diameter': obj['blade_diameter'], + 'feed_per_tooth': obj['feed_per_tooth'], + }) + return feed_per_tooth_2_str + + def _json_feed_per_tooth_3(self, obj): + feed_per_tooth_3_str = (0, '', { + 'cutting_speed': obj['cutting_speed'], + 'feed_per_tooth': obj['feed_per_tooth'], + }) + return feed_per_tooth_3_str + + def _json_feed_per_tooth_4(self, obj): + feed_per_tooth_4_str = (0, '', { + 'machining_method': obj['machining_method'], + 'materials_type_id': self.env['sf.materials.model'].search( + [('materials_no', '=', obj['materials_type_code'])]).id, + 'feed_per_tooth': obj['feed_per_tooth'], + }) + return feed_per_tooth_4_str + # @api.depends('product_template_id') # def _compute_product_template_id(self): # if self.product_template_id is not None: diff --git a/sf_base/views/tool_views.xml b/sf_base/views/tool_views.xml index ed561325..bc1c9605 100644 --- a/sf_base/views/tool_views.xml +++ b/sf_base/views/tool_views.xml @@ -249,65 +249,227 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -360,16 +522,16 @@ - - + + maintenance.equipment.image.tree maintenance.equipment.image - + - + @@ -397,5 +559,4 @@ - diff --git a/sf_maintenance/views/maintenance_views.xml b/sf_maintenance/views/maintenance_views.xml index 9ab34c2f..ac3775e0 100644 --- a/sf_maintenance/views/maintenance_views.xml +++ b/sf_maintenance/views/maintenance_views.xml @@ -1135,51 +1135,5 @@ -<<<<<<< HEAD -======= - - maintenance.equipment.image.tree - maintenance.equipment.image - - - - - - - - - - - - - - maintenance.equipment.image.search - maintenance.equipment.image - - - - - - - - - - 能力特征库 - maintenance.equipment.image - tree - [] - - - ->>>>>>> 9b5a0162ff1f972a9e99e09624b98c13150b64d9 - \ No newline at end of file diff --git a/sf_manufacturing/__manifest__.py b/sf_manufacturing/__manifest__.py index e2be4958..9800bf5d 100644 --- a/sf_manufacturing/__manifest__.py +++ b/sf_manufacturing/__manifest__.py @@ -21,7 +21,6 @@ 'views/production_line_view.xml', 'views/mrp_workcenter_views.xml', 'views/mrp_workorder_view.xml', - 'views/tool_other_features_view.xml', 'views/model_type_view.xml', 'views/sf_maintenance_equipment.xml', # 'views/kanban_change.xml' diff --git a/sf_manufacturing/models/tool_other_features.py b/sf_manufacturing/models/tool_other_features.py deleted file mode 100644 index 569b7f9f..00000000 --- a/sf_manufacturing/models/tool_other_features.py +++ /dev/null @@ -1,282 +0,0 @@ -from odoo import fields, models, api - - -class ToolMaterialsBasicParameters(models.Model): - _name = 'sf.tool.materials.basic.parameters' - _description = '刀具物料基本参数' - - standard_library_id = fields.Many2one('sf.cutting_tool.standard.library', string='刀具标准库') - cutting_tool_type = fields.Char(related='cutting_tool_model_id.cutting_tool_type', string='刀具物料类型', - store=True) - # cutting_tool_type_1 = fields.Char(related='cutting_tool_type', string='类型', store=True) - - # 整体式刀具参数 - code = fields.Char('物料号', size=50) - total_length = fields.Char('总长度(mm)', size=20) - blade_number = fields.Selection( - [('2', '2'), ('3', '3'), ('4', '4'), ('5', '5'), ('6', '6'), ('7', '7'), ('8', '8')], - string='刃数(个)') - neck_diameter = fields.Char('颈部直径(mm)', size=20) - neck_length = fields.Char('颈部长度(mm)', size=20) - handle_diameter = fields.Char('柄部直径(mm)', size=20) - handle_length = fields.Char('柄部长度(mm)', size=20) - blade_tip_diameter = fields.Char('刀尖直径(mm)', size=20) - blade_tip_working_size = fields.Char('刀尖处理尺寸(R半径mm/倒角)', size=20) - blade_tip_taper = fields.Integer('刀尖锥度(°)') - blade_diameter = fields.Char('刃部直径(mm)', size=20) - blade_length = fields.Char('刃部长度(mm)', size=20) - blade_helix_angle = fields.Integer('刃部螺旋角(°)') - blade_width = fields.Char('刃部宽度(mm)', size=20) - blade_depth = fields.Char('刃部深度(mm)', size=20) - pitch = fields.Char('牙距(mm)', size=20) - cutting_depth = fields.Char('切削深度(mm)', size=20) - # 刀片参数 - length = fields.Char('长度(mm)', size=20) - thickness = fields.Char('厚度(mm)', size=20) - width = fields.Char('宽度(mm)', size=20) - cutting_blade_length = fields.Char('切削刃长(mm)', size=20) - relief_angle = fields.Integer('后角(°)') - blade_tip_circular_arc_radius = fields.Char('刀尖圆弧半径(mm)', size=20) - inscribed_circle_diameter = fields.Char('内接圆直径(mm)', size=20) - install_aperture_diameter = fields.Char('安装孔直径(mm)', size=20) - chip_breaker_groove = fields.Selection([('无', '无'), ('单面', '单面'), ('双面', '双面')], - string='有无断屑槽') - blade_teeth_model = fields.Selection( - [('V牙型', 'V牙型'), ('米制全牙型', '米制全牙型'), ('美制全牙型', '美制全牙型'), - ('惠氏全牙型', '惠氏全牙型'), ('BSPT全牙型', 'BSPT全牙型'), ('NPT全牙型', 'NPT全牙型'), - ('UNJ全牙型', 'UNJ全牙型'), ('DIN405圆牙型', 'DIN405圆牙型'), ('ACME梯形', 'ACME梯形'), - ('石油管螺纹刀片', '石油管螺纹刀片'), ('矮牙ACME梯形', '矮牙ACME梯形'), - ('Trapeze30° 103', 'Trapeze30° 103')], string='刀片牙型') - blade_blade_number = fields.Selection([('1', '1'), ('2', '2'), ('3', '3'), ('4', '4'), ('5', '5'), ('6', '6'), - ('7', '7'), ('8', '8'), ('9', '9'), ('10', '10')], - string='刀片的刃数(个)') - main_included_angle = fields.Integer('主偏角(°)') - top_angle = fields.Integer('顶角(°)') - blade_tip_dip_angle = fields.Integer('刀尖倾角(°)') - side_cutting_edge_angle = fields.Integer('侧切削角(°)') - thread_model = fields.Selection([('外螺纹', '外螺纹'), ('内螺纹', '内螺纹')], string='螺纹类型') - thread_num = fields.Char('每英寸螺纹数(TPI)', size=20) - blade_tip_height_tolerance = fields.Char('刀尖高度公差(mm)', size=20) - inscribed_circle_tolerance = fields.Char('内接圆公差(mm)', size=20) - thickness_tolerance = fields.Char('厚度公差(mm)', size=20) - # 刀杆参数 - height = fields.Char('高度(mm)', size=20) - blade_height = fields.Char('刃部高度(mm)', size=20) - cutter_arbor_diameter = fields.Char('刀杆直径(mm)', size=20) - min_machining_aperture = fields.Char('最小加工孔径(mm)', size=20) - install_blade_tip_num = fields.Char('可装刀片数/齿数(个)', size=20) - cutting_blade_model = fields.Char('切削类型', size=20) - cooling_hole = fields.Selection([('有', '有'), ('无', '无')], string='有无冷却孔') - locating_slot_code = fields.Char('定位槽代号', size=20) - installing_structure = fields.Char('安装结构', size=20) - blade_ids = fields.Many2many( - 'sf.cutting.tool.type', - relation='cutting_tool_type_library_pad_blade_rel', - column1='model_id_1', - column2='model_id_2', - domain="[('cutting_tool_material_id.name', '=', '刀片')]", - string='适配刀片型号' # 使用空列表作为默认值 - ) - tool_shim = fields.Char('适配刀垫型号', size=50) - cotter_pin = fields.Char('适配销钉型号', size=50) - pressing_plate = fields.Char('适配压板型号', size=50) - screw = fields.Char('适配螺钉型号', size=50) - spanner = fields.Char('适配扳手型号', size=50) - # 刀盘参数 - cutter_head_diameter = fields.Char('刀盘直径(mm)', size=20) - interface_diameter = fields.Char('接口直径(mm)', size=20) - # 刀柄参数 - flange_shank_length = fields.Char('法兰柄长(mm)', size=20) - handle_external_diameter = fields.Char('柄部外径(mm)', size=20) - handle_inside_diameter = fields.Char('柄部内径(mm)', size=20) - min_clamping_diameter = fields.Char('最小夹持直径(mm)', size=20) - max_clamping_diameter = fields.Char('最大夹持直径(mm)', size=20) - clamping_mode = fields.Char('夹持方式', size=20) - max_load_capacity = fields.Char('最大负载能力(kg)', size=20) - taper = fields.Integer('锥度(°)') - tool_changing_time = fields.Integer('换刀时间(s)') - standard_rotate_speed = fields.Char('标准转速(n/min)', size=20) - max_rotate_speed = fields.Char('最大转速(n/min)', size=20) - diameter_slip_accuracy = fields.Char('径跳精度(mm)', size=20) - cooling_model = fields.Char('冷却类型', size=20) - is_rough_machining = fields.Selection([('是', '是'), ('否', '否')], string='是否可粗加工') - is_finish_machining = fields.Selection([('是', '是'), ('否', '否')], string='是否可精加工') - is_quick_cutting = fields.Selection([('是', '是'), ('否', '否')], string='是否可高速切削') - is_drill_hole = fields.Selection([('是', '是'), ('否', '否')], string='是否可钻孔') - is_safe_lock = fields.Selection([('是', '是'), ('否', '否')], string='有无安全锁') - # 夹头参数 - er_size_model = fields.Char('ER尺寸型号', size=20) - outer_diameter = fields.Char('外径(mm)', size=20) - inner_diameter = fields.Char('内径(mm)', size=20) - run_out_accuracy = fields.Char('跳动精度(mm)', size=20) - top_diameter = fields.Char('顶部直径(mm)', size=20) - weight = fields.Char('重量(kg)', size=20) - clamping_length = fields.Char('夹持长度(mm)', size=20) - clamping_tolerance = fields.Char('夹持公差(mm)', size=20) - handle_ids = fields.Many2many( - 'sf.cutting.tool.type', - relation='cutting_tool_type_library_chuck_handle_rel', - column1='model_id_1', - column2='model_id_2', - domain="[('cutting_tool_material_id.name', '=', '刀柄')]", - string='适用刀柄型号' - ) - - def _json_basic_param(self, obj): - basic_param_str = [0, '', { - 'code': obj['code'], - 'total_length': obj['total_length'], - 'blade_number': obj['blade_number'], - 'neck_diameter': obj['neck_diameter'], - 'neck_length': obj['neck_length'], - 'handle_diameter': obj['handle_diameter'], - 'handle_length': obj['handle_length'], - 'blade_tip_diameter': obj['blade_tip_diameter'], - 'blade_tip_working_size': obj['blade_tip_working_size'], - 'blade_tip_taper': obj['blade_tip_taper'], - 'blade_diameter': obj['blade_diameter'], - 'blade_length': obj['blade_length'], - 'blade_helix_angle': obj['blade_helix_angle'], - 'blade_width': obj['blade_width'], - 'blade_depth': obj['blade_depth'], - 'pitch': obj['pitch'], - 'cutting_depth': obj['cutting_depth'], - 'length': obj['length'], - 'thickness': obj['thickness'], - 'width': obj['width'], - 'cutting_blade_length': obj['cutting_blade_length'], - 'relief_angle': obj['relief_angle'], - 'blade_tip_circular_arc_radius': obj['blade_tip_circular_arc_radius'], - 'inscribed_circle_diameter': obj['inscribed_circle_diameter'], - 'install_aperture_diameter': obj['install_aperture_diameter'], - 'chip_breaker_groove': obj['chip_breaker_groove'], - 'blade_teeth_model': obj['bladed_teeth_model'], - 'blade_blade_number': obj['blade_blade_number'], - 'main_included_angle': obj['main_included_angle'], - 'top_angle': obj['top_angle'], - 'blade_tip_dip_angle': obj['blade_tip_dip_angle'], - 'side_cutting_edge_angle': obj['side_cutting_edge_angle'], - 'thread_model': obj['thread_model'], - 'thread_num': obj['thread_num'], - 'blade_tip_height_tolerance': obj['blade_tip_height_tolerance'], - 'inscribed_circle_tolerance': obj['inscribed_circle_tolerance'], - 'thickness_tolerance': obj['thickness_tolerance'], - 'height': obj['height'], - 'blade_height': obj['blade_height'], - 'cutter_arbor_diameter': obj['cutter_arbor_diameter'], - 'min_machining_aperture': obj['min_machining_aperture'], - 'install_blade_tip_num': obj['install_blade_tip_num'], - 'cutting_blade_model': obj['cutting_blade_model'], - 'cooling_hole': obj['cooling_hole'], - 'locating_slot_code': obj['locating_slot_code'], - 'installing_structure': obj['installing_structure'], - 'tool_shim': obj['tool_shim'], - 'cotter_pin': obj['cotter_pin'], - 'pressing_plate': obj['pressing_plate'], - 'screw': obj['screw'], - 'spanner': obj['spanner'], - 'cutter_head_diameter': obj['cutter_head_diameter'], - 'interface_diameter': obj['interface_diameter'], - 'flange_shank_length': obj['flange_shank_length'], - 'handle_external_diameter': obj['handle_external_diameter'], - 'handle_inside_diameter': obj['handle_inside_diameter'], - 'min_clamping_diameter': obj['min_clamping_diameter'], - 'max_clamping_diameter': obj['max_clamping_diameter'], - 'clamping_mode': obj['clamping_mode'], - 'max_load_capacity': obj['max_load_capacity'], - 'taper': obj['taper'], - 'tool_changing_time': obj['tool_changing_time'], - 'standard_rotate_speed': obj['standard_rotate_speed'], - 'max_rotate_speed': obj['max_rotate_speed'], - 'diameter_slip_accuracy': obj['diameter_slip_accuracy'], - 'cooling_model': obj['cooling_model'], - 'is_rough_machining': obj['is_rough_machining'], - 'is_finish_machining': obj['is_finish_machining'], - 'is_quick_cutting': obj['is_quick_cutting'], - 'is_drill_hole': obj['is_drill_hole'], - 'is_safe_lock': obj['is_safe_lock'], - 'er_size_model': obj['er_size_model'], - 'outer_diameter': obj['outer_diameter'], - 'inner_diameter': obj['inner_diameter'], - 'run_out_accuracy': obj['run_out_accuracy'], - 'top_diameter': obj['top_diameter'], - 'weight': obj['weight'], - 'clamping_length': obj['clamping_length'], - 'clamping_tolerance': obj['clamping_tolerance'], - 'handle_ids': obj['weight'], - 'blade_ids': obj['clamping_length'], - }] - return basic_param_str - - -class CuttingSpeed(models.Model): - _name = 'sf.cutting.speed' - _description = '切削速度Vc' - - product_template_id = fields.Many2one('product.template', string='产品') - standard_library_id = fields.Many2one('sf.cutting_tool.standard.library', string='标准库') - execution_standard_id = fields.Char('执行标准') - material_code = fields.Char('材料代号') - material_name = fields.Char('材料名称') - material_grade = fields.Char('材料牌号') - tensile_strength = fields.Float('拉伸强度 (N/mm²)') - hardness = fields.Float('硬度(HRC)') - cutting_speed_n1 = fields.Char('径向切宽 ae=100%D1 ap=1*D1 切削速度Vc') - cutting_speed_n2 = fields.Char('径向切宽 ae=50%D1 ap=1.5*D1 切削速度Vc') - cutting_speed_n3 = fields.Char('径向切宽 ae=25%D1 ap=L1max 切削速度Vc') - cutting_speed_n4 = fields.Char('径向切宽 ae=15%D1 ap=L1max 切削速度Vc') - cutting_speed_n5 = fields.Char('径向切宽 ae=5%D1 ap=L1max 切削速度Vc') - rough_machining = fields.Char('粗加工 Vc(m/min)') - precision_machining = fields.Char('精加工 Vc(m/min)') - application = fields.Selection([('主应用', '主应用'), ('次应用', '次应用')], '主/次应用') - - def _json_cutting_speed(self, obj): - cutting_speed_str = [0, '', { - 'execution_standard_id': obj['execution_standard_id'], - 'material_code': obj['material_code'], - 'material_name': obj['material_name'], - 'material_grade': obj['material_grade'], - 'tensile_strength': obj['tensile_strength'], - 'hardness': obj['hardness'], - 'cutting_speed_n1': obj['cutting_speed_n1'], - 'cutting_speed_n2': obj['cutting_speed_n2'], - 'cutting_speed_n3': obj['cutting_speed_n3'], - 'cutting_speed_n4': obj['cutting_speed_n4'], - 'cutting_speed_n5': obj['cutting_speed_n5'], - 'rough_machining': obj['rough_machining'], - 'precision_machining': obj['precision_machining'], - 'application': obj['application'], - }] - return cutting_speed_str - - -class FeedPerTooth(models.Model): - _name = 'sf.feed.per.tooth' - _description = '每齿走刀量fz' - - product_template_id = fields.Many2one('product.template', string='产品') - standard_library_id = fields.Many2one('sf.cutting_tool.standard.library', string='标准库') - - cutting_speed = fields.Char('径向切宽 ae(mm)') - machining_method = fields.Selection([('直铣', '直铣'), ('坡铣', '坡铣')], string='加工方式') - materials_type_id = fields.Many2one('sf.materials.model', string='材料型号') - blade_diameter = fields.Float('刃部直径D1(mm)', readonly=True, - related='product_template_id.cutting_tool_blade_diameter') - feed_per_tooth = fields.Char('每齿走刀量 (mm/z)') - unit = fields.Char('单位', default='fz') - - def _json_feed_per_tooth(self, obj): - feed_per_tooth_str = [0, '', { - 'cutting_speed': obj['cutting_speed'], - 'machining_method': obj['machining_method'], - 'materials_type_id': obj['materials_type_id'], - 'blade_diameter': obj['blade_diameter'], - 'feed_per_tooth': obj['feed_per_tooth'], - 'unit': obj['unit'], - }] - return feed_per_tooth_str - - # @api.depends('product_template_id') - # def _compute_product_template_id(self): - # if self.product_template_id is not None: - # self.blade_diameter = self.product_template_id.cutting_tool_blade_diameter diff --git a/sf_manufacturing/views/tool_other_features_view.xml b/sf_manufacturing/views/tool_other_features_view.xml deleted file mode 100644 index 63eafb44..00000000 --- a/sf_manufacturing/views/tool_other_features_view.xml +++ /dev/null @@ -1,58 +0,0 @@ - - - - - 切削速度Vc - sf.cutting.speed - - - - - - - - - - - - - - - - - - - - - - - 切削速度Vc - ir.actions.act_window - sf.cutting.speed - tree - - - - - - 每齿走刀量fz - sf.feed.per.tooth - - - - - - - - - - - - - - 每齿走刀量fz - ir.actions.act_window - sf.feed.per.tooth - tree - - \ No newline at end of file diff --git a/sf_mrs_connect/models/res_config_setting.py b/sf_mrs_connect/models/res_config_setting.py index 4b306a4b..549e3ce1 100644 --- a/sf_mrs_connect/models/res_config_setting.py +++ b/sf_mrs_connect/models/res_config_setting.py @@ -22,48 +22,49 @@ class ResConfigSettings(models.TransientModel): def sf_all_sync(self): try: self.env['sf.production.materials'].sync_all_production_materials() - _logger.info("同步资源库材料") + _logger.info("同步资源库材料完成") self.env['sf.materials.model'].sync_all_materials_model() - _logger.info("同步资源库材料型号") + _logger.info("同步资源库材料型号完成") self.env['sf.international.standards'].sync_all_mrs_international_standards() _logger.info("同步资源库国际标准完成") self.env['material.apply'].sync_all_material_apply() _logger.info("同步资源库材料应用完成") self.env['sf.production.process.category'].sync_all_production_process_category() - _logger.info("同步资源库表面工艺类别") + _logger.info("同步资源库表面工艺类别完成") self.env['sf.production.process'].sync_all_production_process() - _logger.info("同步资源库表面工艺") + _logger.info("同步资源库表面工艺完成") # self.env['sf.processing.technology'].sync_all_processing_technology() # _logger.info("同步资源库加工工艺") self.env['sf.machine.brand.tags'].sync_all_machine_brand_tags() - _logger.info("同步资源库品牌类别") + _logger.info("同步资源库品牌类别完成") self.env['sf.machine.brand'].sync_all_machine_brand() - _logger.info("同步资源库品牌") + _logger.info("同步资源库品牌完成") self.env['sf.machine.control_system'].sync_all_machine_control_system() - _logger.info("同步资源库控制系统") + _logger.info("同步资源库控制系统完成") self.env['sf.machine_tool.category'].sync_all_machine_tool_category() - _logger.info("同步资源库机床类型") + _logger.info("同步资源库机床类型完成") self.env['sf.production.process.parameter'].sync_all_production_process_parameter() - _logger.info("同步刀具物料") + _logger.info("同步刀具物料完成") self.env['sf.cutting.tool.material'].sync_all_cutting_tool_material() - _logger.info("同步刀具类型") + _logger.info("同步刀具类型完成") self.env['sf.cutting.tool.type'].sync_all_tool_type() _logger.info("同步所有刀具型号完成") self.env['sf.functional.cutting.tool.model'].sync_all_functional_cutting_tool_model() - _logger.info("同步夹具物料") + _logger.info("同步夹具物料完成") self.env['sf.fixture.material'].sync_all_fixture_material() - _logger.info("同步联装类型") + _logger.info("同步联装类型完成") self.env['sf.multi_mounting.type'].sync_all_multi_mounting_type() - _logger.info("同步夹具型号") + _logger.info("同步夹具型号完成") self.env['sf.fixture.model'].sync_all_fixture_model() - _logger.info("同步功能夹具类型") + _logger.info("同步功能夹具类型完成") self.env['sf.functional.fixture.type'].sync_all_functional_fixture_type() + _logger.info("同步功能夹具类型完成") self.env['sf.machine_tool.type'].sync_all_machine_tool_type() _logger.info("同步资源库机床型号完成") + self.env['maintenance.equipment.image'].sync_all_maintenance_equipment_image() + _logger.info("同步能力特征库完成") self.env['sf.cutting_tool.standard.library'].sync_all_cutting_tool_standard_library() _logger.info("同步刀具标准库完成") - self.env['maintenance.equipment.image'].sync_all_maintenance_equipment_image() - _logger.info("同步能力特征库") except Exception as e: _logger.info("捕获错误信息:%s" % e) raise ValidationError("数据错误导致同步失败,请联系管理员") diff --git a/sf_mrs_connect/models/sync_common.py b/sf_mrs_connect/models/sync_common.py index 8aaefa83..6a9b0964 100644 --- a/sf_mrs_connect/models/sync_common.py +++ b/sf_mrs_connect/models/sync_common.py @@ -56,12 +56,12 @@ class MrStaticResourceDataSync(models.Model): logging.info("刀具物料已每日同步成功") self.env['sf.cutting.tool.type'].sync_tool_type_yesterday() logging.info("刀具类型已每日同步成功") - self.env['sf.cutting_tool.standard.library'].sync_cutting_tool_standard_library_yesterday() - logging.info("刀具标准库已每日同步成功") self.env['sf.functional.cutting.tool.model'].sync_functional_cutting_tool_model_yesterday() logging.info("功能刀具类型已每日同步成功") self.env['maintenance.equipment.image'].sync_maintenance_equipment_image_yesterday() logging.info("能力特征库已每日同步成功") + self.env['sf.cutting_tool.standard.library'].sync_cutting_tool_standard_library_yesterday() + logging.info("刀具标准库已每日同步成功") except Exception as e: logging.info("捕获错误信息:%s" % e) raise ValidationError("数据错误导致同步失败,请联系管理员") @@ -75,11 +75,9 @@ class sfProductionMaterials(models.Model): # 定时同步每日材料 def sync_production_materials_yesterday(self): # 配置中获取token - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -103,11 +101,9 @@ class sfProductionMaterials(models.Model): # 同步所有材料 def sync_all_production_materials(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -137,11 +133,9 @@ class sfMaterialModel(models.Model): # 定时同步每日材料型号 def sync_materials_model_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -185,11 +179,9 @@ class sfMaterialModel(models.Model): # 同步所有材料型号 def sync_all_materials_model(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -247,11 +239,9 @@ class sfProductionProcessCategory(models.Model): # 定时同步每日表面工艺类别 def sync_production_process_category_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -274,11 +264,9 @@ class sfProductionProcessCategory(models.Model): # 同步所有表面工艺类别 def sync_all_production_process_category(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -306,11 +294,9 @@ class sfProductionProcess(models.Model): # 定时同步每日表面工艺 def sync_production_process_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -349,11 +335,9 @@ class sfProductionProcess(models.Model): # 同步所有表面工艺 def sync_all_production_process(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -387,11 +371,9 @@ class sfProcessingTechnology(models.Model): # 定时同步加工工艺 def sync_processing_technology_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -415,11 +397,9 @@ class sfProcessingTechnology(models.Model): # 同步所有加工工艺 def sync_all_processing_technology(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -449,11 +429,9 @@ class MachineBrandTags(models.Model): # 定时同步品牌类别 def sync_machine_brand_tags_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -473,12 +451,9 @@ class MachineBrandTags(models.Model): # 同步所有品牌类别 def sync_all_machine_brand_tags(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -504,11 +479,9 @@ class MachineControlSystem(models.Model): # 定时同步控制系统 def sync_machine_control_system_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -535,11 +508,9 @@ class MachineControlSystem(models.Model): # 同步所有控制系统 def sync_all_machine_control_system(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -572,11 +543,9 @@ class MachineBrand(models.Model): # 定时同步品牌 def sync_machine_brand_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -603,11 +572,9 @@ class MachineBrand(models.Model): # 同步所有品牌 def sync_all_machine_brand(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -640,11 +607,9 @@ class MachineToolType(models.Model): # 定时同步机床型号 def sync_machine_tool_type_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -745,11 +710,9 @@ class MachineToolType(models.Model): # 同步所有机床型号 def sync_all_machine_tool_type(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -858,11 +821,9 @@ class sfProcessingOrder(models.Model): # 定时同步工序 def sync_processing_order_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -880,11 +841,9 @@ class sfProcessingOrder(models.Model): # 同步所有工序 def sync_all_processing_order(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -908,11 +867,9 @@ class sfProductionProcessParameter(models.Model): # 定时同步每日表面工艺可选参数 def sync_production_process_parameter_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -942,11 +899,9 @@ class sfProductionProcessParameter(models.Model): # 同步所有表面工艺可选参数 def sync_all_production_process_parameter(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -983,11 +938,9 @@ class MachineToolCategory(models.Model): # 定时同步机床类型 def sync_machine_tool_category_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1012,11 +965,9 @@ class MachineToolCategory(models.Model): # 同步所有机床类型 def sync_all_machine_tool_category(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1049,11 +1000,9 @@ class sfSyncCutting_tool_Material(models.Model): # 定时同步每日刀具物料 def sync_cutting_tool_material_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1081,11 +1030,9 @@ class sfSyncCutting_tool_Material(models.Model): # 同步所有刀具物料 def sync_all_cutting_tool_material(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1120,11 +1067,9 @@ class SyncFunctionalCuttingToolModel(models.Model): # 定时同步每日功能刀具类型列表 def sync_functional_cutting_tool_model_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1152,12 +1097,9 @@ class SyncFunctionalCuttingToolModel(models.Model): # 同步所有功能刀具类型列表 def sync_all_functional_cutting_tool_model(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1192,11 +1134,9 @@ class SyncFixtureMaterial(models.Model): # 定时同步夹具物料列表 def sync_fixture_material_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1226,12 +1166,9 @@ class SyncFixtureMaterial(models.Model): # 定时同步所有夹具物料列表 def sync_all_fixture_material(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1268,11 +1205,9 @@ class SyncMulti_Mounting_Type(models.Model): # 定时同步联装类型列表 def sync_multi_mounting_type_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1299,11 +1234,9 @@ class SyncMulti_Mounting_Type(models.Model): # 定时同步所有联装类型列表 def sync_all_multi_mounting_type(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1338,11 +1271,9 @@ class SyncFixtureModel(models.Model): # 定时同步夹具型号列表 def sync_fixture_model_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1417,11 +1348,9 @@ class SyncFixtureModel(models.Model): # 定时同步所有夹具型号列表 def sync_all_fixture_model(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1504,11 +1433,9 @@ class SyncFunctionalFixtureType(models.Model): # 定时同步功能夹具类型列表 def sync_functional_fixture_type_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1536,11 +1463,9 @@ class SyncFunctionalFixtureType(models.Model): # 定时同步所有功能夹具类型列表 def sync_all_functional_fixture_type(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1575,11 +1500,9 @@ class SfToolType(models.Model): # 定时同步每日刀具类型 def sync_tool_type_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1609,11 +1532,9 @@ class SfToolType(models.Model): # 同步所有刀具类型列表 def sync_all_tool_type(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1651,11 +1572,9 @@ class SfMaintenanceEquipmentImage(models.Model): # 定时同步每日能力特征库 def sync_maintenance_equipment_image_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1681,11 +1600,9 @@ class SfMaintenanceEquipmentImage(models.Model): # 同步所有能力特征库 def sync_all_maintenance_equipment_image(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1717,12 +1634,9 @@ class MaterialApply(models.Model): # 定时同步材料应用 def sync_material_apply(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1742,12 +1656,9 @@ class MaterialApply(models.Model): # 同步所有材料应用 def sync_all_material_apply(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1773,12 +1684,9 @@ class ModelInternationalStandards(models.Model): # 定时同步制造标准 def sync_mrs_international_standards(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1791,6 +1699,7 @@ class ModelInternationalStandards(models.Model): else: self.create({ "name": item['name'], + "code": item['code'], "active": item['active'], }) else: @@ -1798,12 +1707,9 @@ class ModelInternationalStandards(models.Model): # 同步所有制造标准 def sync_all_mrs_international_standards(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1813,6 +1719,7 @@ class ModelInternationalStandards(models.Model): if not international_standards: self.create({ "name": item['name'], + "code": item['code'], "active": item['active'], }) else: @@ -1829,40 +1736,170 @@ class Cutting_tool_standard_library(models.Model): # 定时同步刀具标准库 def sync_cutting_tool_standard_library_yesterday(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) if result['status'] == 1: for item in result['cutting_tool_standard_library_yesterday_list']: cutting_tool_standard_library = self.search( - [("code", '=', item['code'])]) - if cutting_tool_standard_library: - cutting_tool_standard_library.write( - {"name": item['name'], - "active": item['active']} - ) - else: + [("code", '=', item['code'].replace("JKM", result['factory_short_name']))]) + cutting_tool_type = self.env['sf.cutting.tool.type'].search( + [("code", '=', item['cutting_tool_type_code'])]) + cutting_tool_material = self.env['sf.cutting.tool.material'].search( + [("code", '=', item['cutting_tool_material_code'])]) + materials_model = self.env['sf.materials.model'].search( + [("materials_no", '=', item['material_model_code'])]) + brand = self.env['sf.machine.brand'].search([("code", '=', item['brand_code'])]) + integral_tool_basic_param_list = [] + for integral_tool_item in item['integral_tool_basic_parameter']: + integral_tool_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_integral_tool_basic_param( + integral_tool_item)) + blade_basic_param_list = [] + for blade_item in item['blade_basic_parameter']: + blade_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_blade_basic_param(blade_item)) + cutter_arbor_basic_param_list = [] + for cutter_arbor_item in item['cutter_arbor_basic_parameter']: + cutter_arbor_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_cutter_arbor_basic_param( + cutter_arbor_item)) + cutter_head_basic_param_list = [] + for cutter_head_item in item['cutter_head_basic_parameter']: + cutter_head_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_cutter_head_basic_param(cutter_head_item)) + knife_handle_basic_param_list = [] + for knife_handle_item in item['knife_handle_basic_parameter']: + knife_handle_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_knife_handle_basic_param( + knife_handle_item)) + chuck_basic_param_list = [] + for chuck_item in item['chuck_basic_parameter']: + chuck_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_chuck_basic_param(chuck_item)) + cutting_speed_list = [] + for cutting_speed_item in item['cutting_speed']: + cutting_speed_list.append( + self.env['sf.cutting.speed']._json_cutting_speed(cutting_speed_item)) + feed_per_tooth_list = [] + for feed_per_tooth_item in item['feed_per_tooth']: + feed_per_tooth_list.append( + self.env['sf.feed.per.tooth']._json_feed_per_tooth(feed_per_tooth_item)) + feed_per_tooth_2_list = [] + for feed_per_tooth_2_item in item['feed_per_tooth_2']: + feed_per_tooth_2_list.append( + self.env['sf.feed.per.tooth']._json_feed_per_tooth(feed_per_tooth_2_item)) + feed_per_tooth_3_list = [] + for feed_per_tooth_3_item in item['feed_per_tooth_3']: + feed_per_tooth_3_list.append( + self.env['sf.feed.per.tooth']._json_feed_per_tooth(feed_per_tooth_3_item)) + feed_per_tooth_4_list = [] + for feed_per_tooth_4_item in item['feed_per_tooth_4']: + feed_per_tooth_4_list.append( + self.env['sf.feed.per.tooth']._json_feed_per_tooth(feed_per_tooth_4_item)) + if not cutting_tool_standard_library: self.create({ + "code": item['code'].replace("JKM", result['factory_short_name']), "name": item['name'], + "cutting_tool_material_id": cutting_tool_material.id, + "cutting_tool_type_id": cutting_tool_type.id, + "brand_id": brand.id, + "material_model_id": materials_model.id, + "tool_hardness": item['tool_hardness'], + "coating_material": item['coating_material'], + "blade_type": item['blade_type'], + "integral_coarse_medium_fine": item['integral_coarse_medium_fine'], + "integral_run_out_accuracy_max": item['integral_run_out_accuracy_max'], + "integral_run_out_accuracy_min": item['integral_run_out_accuracy_min'], + "cutter_bar_ids": [(6, 0, [])] if not item.get('cutter_bar_codes') else self.env[ + 'sf.cutting.tool.type']._get_ids(item['cutter_bar_codes']), + "cutter_pad_ids": [(6, 0, [])] if not item.get('cutter_pad_codes') else self.env[ + 'sf.cutting.tool.type']._get_ids(item['cutter_pad_codes']), + "fit_blade_shape_ids": [(6, 0, [])] if not item.get('fit_blade_shape') else self.env[ + 'maintenance.equipment.image']._get_ids(item['fit_blade_shape']), + "suitable_machining_method_ids": [(6, 0, [])] if not item.get( + 'suitable_machining_methods') else self.env['maintenance.equipment.image']._get_ids( + item['suitable_machining_methods']), + "blade_tip_characteristics_ids": [(6, 0, [])] if not item.get('blade_tip_characteristics') else + self.env['maintenance.equipment.image']._get_ids(item['blade_tip_characteristics']), + "handle_type_ids": [(6, 0, [])] if not item.get('handle_type') else self.env[ + 'maintenance.equipment.image']._get_ids(item['handle_type']), + "cutting_direction_ids": [(6, 0, [])] if not item.get('cutting_direction') else self.env[ + 'maintenance.equipment.image']._get_ids(item['cutting_direction']), + "suitable_coolant_ids": [(6, 0, [])] if not item.get('suitable_coolant') else self.env[ + 'maintenance.equipment.image']._get_ids(item['suitable_coolant']), + "compaction_way_ids": [(6, 0, [])] if not item.get('compaction_way') else self.env[ + 'maintenance.equipment.image']._get_ids(item['compaction_way']), + "integral_tool_basic_parameters_ids": integral_tool_basic_param_list, + "blade_basic_parameters_ids": blade_basic_param_list, + "cutter_bar_basic_parameters_ids": cutter_arbor_basic_param_list, + "cutter_head_basic_parameters_ids": cutter_head_basic_param_list, + "knife_handle_basic_parameters_ids": knife_handle_basic_param_list, + "chuck_basic_parameters_ids": chuck_basic_param_list, + "cutting_speed_ids": cutting_speed_list, + "feed_per_tooth_ids": feed_per_tooth_list, + "feed_per_tooth_ids_2": feed_per_tooth_2_list, + "feed_per_tooth_ids_3": feed_per_tooth_3_list, + "feed_per_tooth_ids_4": feed_per_tooth_4_list, + "is_cloud": True, "active": item['active'], }) + else: + cutting_tool_standard_library.write( + {"name": item['name'], + "cutting_tool_material_id": cutting_tool_material.id, + "cutting_tool_type_id": cutting_tool_type.id, + "brand_id": brand.id, + "material_model_id": materials_model.id, + "tool_hardness": item['tool_hardness'], + "coating_material": item['coating_material'], + "blade_type": item['blade_type'], + "integral_coarse_medium_fine": item['integral_coarse_medium_fine'], + "integral_run_out_accuracy_max": item['integral_run_out_accuracy_max'], + "integral_run_out_accuracy_min": item['integral_run_out_accuracy_min'], + "cutter_bar_ids": [(6, 0, [])] if not item.get('cutter_bar_codes') else self.env[ + 'sf.cutting.tool.type']._get_ids(item['cutter_bar_codes']), + "cutter_pad_ids": [(6, 0, [])] if not item.get('cutter_pad_codes') else self.env[ + 'sf.cutting.tool.type']._get_ids(item['cutter_pad_codes']), + "fit_blade_shape_ids": [(6, 0, [])] if not item.get('fit_blade_shape') else self.env[ + 'maintenance.equipment.image']._get_ids(item['fit_blade_shape']), + "suitable_machining_method_ids": [(6, 0, [])] if not item.get( + 'suitable_machining_methods') else self.env['maintenance.equipment.image']._get_ids( + item['suitable_machining_methods']), + "blade_tip_characteristics_ids": [(6, 0, [])] if not item.get('blade_tip_characteristics') else + self.env['maintenance.equipment.image']._get_ids(item['blade_tip_characteristics']), + "handle_type_ids": [(6, 0, [])] if not item.get('handle_type') else self.env[ + 'maintenance.equipment.image']._get_ids(item['handle_type']), + "cutting_direction_ids": [(6, 0, [])] if not item.get('cutting_direction') else self.env[ + 'maintenance.equipment.image']._get_ids(item['cutting_direction']), + "suitable_coolant_ids": [(6, 0, [])] if not item.get('suitable_coolant') else self.env[ + 'maintenance.equipment.image']._get_ids(item['suitable_coolant']), + "compaction_way_ids": [(6, 0, [])] if not item.get('compaction_way') else self.env[ + 'maintenance.equipment.image']._get_ids(item['compaction_way']), + "integral_tool_basic_parameters_ids": integral_tool_basic_param_list, + "blade_basic_parameters_ids": blade_basic_param_list, + "cutter_bar_basic_parameters_ids": cutter_arbor_basic_param_list, + "cutter_head_basic_parameters_ids": cutter_head_basic_param_list, + "knife_handle_basic_parameters_ids": knife_handle_basic_param_list, + "chuck_basic_parameters_ids": chuck_basic_param_list, + "cutting_speed_ids": cutting_speed_list, + "feed_per_tooth_ids": feed_per_tooth_list, + "feed_per_tooth_ids_2": feed_per_tooth_2_list, + "feed_per_tooth_ids_3": feed_per_tooth_3_list, + "feed_per_tooth_ids_4": feed_per_tooth_4_list, + "active": item['active'], + }) else: raise ValidationError("刀具标准库认证未通过") # 同步所有刀具标准库 def sync_all_cutting_tool_standard_library(self): - sf_sync_config = self.env['res.config.settings'].get_values() - token = sf_sync_config['token'] - sf_secret_key = sf_sync_config['sf_secret_key'] - headers = Common.get_headers(self, token, sf_secret_key) - - strUrl = sf_sync_config['sf_url'] + self.url + config = self.env['res.config.settings'].get_values() + headers = Common.get_headers(self, config['token'], config['sf_secret_key']) + strUrl = config['sf_url'] + self.url r = requests.post(strUrl, json={}, data=None, headers=headers) r = r.json() result = json.loads(r['result']) @@ -1877,18 +1914,53 @@ class Cutting_tool_standard_library(models.Model): materials_model = self.env['sf.materials.model'].search( [("materials_no", '=', item['material_model_code'])]) brand = self.env['sf.machine.brand'].search([("code", '=', item['brand_code'])]) - basic_param_list = [] - for basic_param_item in item['basic_parameter']: - basic_param_list.append( - self.env['sf.tool.materials.basic.parameters']._json_basic_param(basic_param_item)) + integral_tool_basic_param_list = [] + for integral_tool_item in item['integral_tool_basic_parameter']: + integral_tool_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_integral_tool_basic_param( + integral_tool_item)) + blade_basic_param_list = [] + for blade_item in item['blade_basic_parameter']: + blade_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_blade_basic_param(blade_item)) + cutter_arbor_basic_param_list = [] + for cutter_arbor_item in item['cutter_arbor_basic_parameter']: + cutter_arbor_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_cutter_arbor_basic_param( + cutter_arbor_item)) + cutter_head_basic_param_list = [] + for cutter_head_item in item['cutter_head_basic_parameter']: + cutter_head_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_cutter_head_basic_param(cutter_head_item)) + knife_handle_basic_param_list = [] + for knife_handle_item in item['knife_handle_basic_parameter']: + knife_handle_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_knife_handle_basic_param( + knife_handle_item)) + chuck_basic_param_list = [] + for chuck_item in item['chuck_basic_parameter']: + chuck_basic_param_list.append( + self.env['sf.tool.materials.basic.parameters']._json_chuck_basic_param(chuck_item)) cutting_speed_list = [] for cutting_speed_item in item['cutting_speed']: cutting_speed_list.append( self.env['sf.cutting.speed']._json_cutting_speed(cutting_speed_item)) feed_per_tooth_list = [] - for feed_per_tooth_item in item['basic_parameter']: + for feed_per_tooth_item in item['feed_per_tooth']: feed_per_tooth_list.append( self.env['sf.feed.per.tooth']._json_feed_per_tooth(feed_per_tooth_item)) + feed_per_tooth_2_list = [] + for feed_per_tooth_2_item in item['feed_per_tooth_2']: + feed_per_tooth_2_list.append( + self.env['sf.feed.per.tooth']._json_feed_per_tooth_2(feed_per_tooth_2_item)) + feed_per_tooth_3_list = [] + for feed_per_tooth_3_item in item['feed_per_tooth_3']: + feed_per_tooth_3_list.append( + self.env['sf.feed.per.tooth']._json_feed_per_tooth_3(feed_per_tooth_3_item)) + feed_per_tooth_4_list = [] + for feed_per_tooth_4_item in item['feed_per_tooth_4']: + feed_per_tooth_4_list.append( + self.env['sf.feed.per.tooth']._json_feed_per_tooth_4(feed_per_tooth_4_item)) if not cutting_tool_standard_library: self.create({ "code": item['code'].replace("JKM", result['factory_short_name']), @@ -1900,14 +1972,40 @@ class Cutting_tool_standard_library(models.Model): "tool_hardness": item['tool_hardness'], "coating_material": item['coating_material'], "blade_type": item['blade_type'], - "blade_diameter": item['blade_diameter'], - "working_hardness": item['working_hardness'], "integral_coarse_medium_fine": item['integral_coarse_medium_fine'], "integral_run_out_accuracy_max": item['integral_run_out_accuracy_max'], "integral_run_out_accuracy_min": item['integral_run_out_accuracy_min'], - "basic_parameters_ids": basic_param_list, + "cutter_bar_ids": [(6, 0, [])] if not item.get('cutter_bar_codes') else self.env[ + 'sf.cutting.tool.type']._get_ids(item['cutter_bar_codes']), + "cutter_pad_ids": [(6, 0, [])] if not item.get('cutter_pad_codes') else self.env[ + 'sf.cutting.tool.type']._get_ids(item['cutter_pad_codes']), + "fit_blade_shape_ids": [(6, 0, [])] if not item.get('fit_blade_shape') else self.env[ + 'maintenance.equipment.image']._get_ids(item['fit_blade_shape']), + "suitable_machining_method_ids": [(6, 0, [])] if not item.get( + 'suitable_machining_method') else self.env['maintenance.equipment.image']._get_ids( + item['suitable_machining_method']), + "blade_tip_characteristics_ids": [(6, 0, [])] if not item.get('blade_tip_characteristics') else + self.env['maintenance.equipment.image']._get_ids(item['blade_tip_characteristics']), + "handle_type_ids": [(6, 0, [])] if not item.get('handle_type') else self.env[ + 'maintenance.equipment.image']._get_ids(item['handle_type']), + "cutting_direction_ids": [(6, 0, [])] if not item.get('cutting_direction') else self.env[ + 'maintenance.equipment.image']._get_ids(item['cutting_direction']), + "suitable_coolant_ids": [(6, 0, [])] if not item.get('suitable_coolant') else self.env[ + 'maintenance.equipment.image']._get_ids(item['suitable_coolant']), + "compaction_way_ids": [(6, 0, [])] if not item.get('compaction_way') else self.env[ + 'maintenance.equipment.image']._get_ids(item['compaction_way']), + "integral_tool_basic_parameters_ids": integral_tool_basic_param_list, + "blade_basic_parameters_ids": blade_basic_param_list, + "cutter_bar_basic_parameters_ids": cutter_arbor_basic_param_list, + "cutter_head_basic_parameters_ids": cutter_head_basic_param_list, + "knife_handle_basic_parameters_ids": knife_handle_basic_param_list, + "chuck_basic_parameters_ids": chuck_basic_param_list, "cutting_speed_ids": cutting_speed_list, "feed_per_tooth_ids": feed_per_tooth_list, + "feed_per_tooth_ids_2": feed_per_tooth_2_list, + "feed_per_tooth_ids_3": feed_per_tooth_3_list, + "feed_per_tooth_ids_4": feed_per_tooth_4_list, + "is_cloud": True, "active": item['active'], }) else: @@ -1920,15 +2018,40 @@ class Cutting_tool_standard_library(models.Model): "tool_hardness": item['tool_hardness'], "coating_material": item['coating_material'], "blade_type": item['blade_type'], - "blade_diameter": item['blade_diameter'], - "working_hardness": item['working_hardness'], "integral_coarse_medium_fine": item['integral_coarse_medium_fine'], "integral_run_out_accuracy_max": item['integral_run_out_accuracy_max'], "integral_run_out_accuracy_min": item['integral_run_out_accuracy_min'], - "basic_parameters_ids": basic_param_list, + "cutter_bar_ids": [(6, 0, [])] if not item.get('cutter_bar_codes') else self.env[ + 'sf.cutting.tool.type']._get_ids(item['cutter_bar_codes']), + "cutter_pad_ids": [(6, 0, [])] if not item.get('cutter_pad_codes') else self.env[ + 'sf.cutting.tool.type']._get_ids(item['cutter_pad_codes']), + "fit_blade_shape_ids": [(6, 0, [])] if not item.get('fit_blade_shape') else self.env[ + 'maintenance.equipment.image']._get_ids(item['fit_blade_shape']), + "suitable_machining_method_ids": [(6, 0, [])] if not item.get( + 'suitable_machining_methods') else self.env['maintenance.equipment.image']._get_ids( + item['suitable_machining_methods']), + "blade_tip_characteristics_ids": [(6, 0, [])] if not item.get('blade_tip_characteristics') else + self.env['maintenance.equipment.image']._get_ids(item['blade_tip_characteristics']), + "handle_type_ids": [(6, 0, [])] if not item.get('handle_type') else self.env[ + 'maintenance.equipment.image']._get_ids(item['handle_type']), + "cutting_direction_ids": [(6, 0, [])] if not item.get('cutting_direction') else self.env[ + 'maintenance.equipment.image']._get_ids(item['cutting_direction']), + "suitable_coolant_ids": [(6, 0, [])] if not item.get('suitable_coolant') else self.env[ + 'maintenance.equipment.image']._get_ids(item['suitable_coolant']), + "compaction_way_ids": [(6, 0, [])] if not item.get('compaction_way') else self.env[ + 'maintenance.equipment.image']._get_ids(item['compaction_way']), + "integral_tool_basic_parameters_ids": integral_tool_basic_param_list, + "blade_basic_parameters_ids": blade_basic_param_list, + "cutter_bar_basic_parameters_ids": cutter_arbor_basic_param_list, + "cutter_head_basic_parameters_ids": cutter_head_basic_param_list, + "knife_handle_basic_parameters_ids": knife_handle_basic_param_list, + "chuck_basic_parameters_ids": chuck_basic_param_list, "cutting_speed_ids": cutting_speed_list, "feed_per_tooth_ids": feed_per_tooth_list, - "active": item['active'], } - ) + "feed_per_tooth_ids_2": feed_per_tooth_2_list, + "feed_per_tooth_ids_3": feed_per_tooth_3_list, + "feed_per_tooth_ids_4": feed_per_tooth_4_list, + "active": item['active'], + }) else: raise ValidationError("刀具标准库认证未通过")