处理bug

This commit is contained in:
qihao.gong@jikimo.com
2023-06-16 10:56:25 +08:00
parent 018fecfc59
commit 23aba08c87
12 changed files with 286 additions and 99 deletions

View File

@@ -30,7 +30,7 @@
'web.assets_qweb': [
],
'web.assets_backend': [
'sf_base/static/src/scss/format_img.scss',
'sf_base/static/src/scss/*.scss',
],
},

View File

@@ -85,7 +85,7 @@ class MachineTool(models.Model):
[("正常", "正常"), ("故障", "故障"), ("不可用", "不可用")],
default='正常', string="机床状态")
#0606新增字段
machine_tool_picture = fields.Binary('机床图片')
machine_tool_picture = fields.Binary('图片')
heightened_way = fields.Selection([
('sifudianji', '伺服电机驱动'),
('youyagang', '油压缸驱动'),
@@ -260,7 +260,7 @@ class MachineToolType(models.Model):
rotate_speed = fields.Integer('转速')
#0606新增字段
created_user = fields.Many2one('res.users', string='创建人', default=lambda self: self.env.user)
machine_tool_picture = fields.Binary('机床图片')
machine_tool_picture = fields.Binary('图片')
heightened_way = fields.Selection([
('sifudianji', '伺服电机驱动'),
('youyagang', '油压缸驱动'),

View File

@@ -0,0 +1,7 @@
.test_model {
display: flex !important;
}
.test_model>.o_form_label {
margin-left: 20px;
margin-right: 0px !important;
}

View File

@@ -96,23 +96,25 @@
</field>
</record>
<record model="ir.ui.view" id="form_sf_machine_tool_type">
<record model="ir.ui.view" id="form_sf_machine_tool_type">
<field name="name">form.sf.machine_tool.type</field>
<field name="model">sf.machine_tool.type</field>
<field name="arch" type="xml">
<form string="机床型号">
<field name="machine_tool_picture" widget="image"/>
<group string="基本信息">
<group>
<field name="code" force_save="1" readonly="1"/>
<field name="name" required="1"/>
</group>
<group>
<field name="machine_tool_category"/>
<field name="machine_tool_category" required="1"/>
<field name="brand_id" required="1"
domain="[('tag_ids', '=', '机床')]"
options="{'no_create': True}" />
</group>
<group>
<field name="machine_tool_picture" widget="image" nolabel="1"/>
</group>
</group>
<group string="参数">
<group>
@@ -177,6 +179,7 @@
</field>
</record>
<record id="action_sf_machine_tool_type" model="ir.actions.act_window">
<field name="name">机床型号</field>
<field name="type">ir.actions.act_window</field>
@@ -249,7 +252,7 @@
<field name="view_mode">tree,form</field>
<field name="help" type="html">
<p class="o_view_nocontent_smiling_face">
[机床型] 还没有哦!点左上角的[创建]按钮,沙发归你了!
[机床型] 还没有哦!点左上角的[创建]按钮,沙发归你了!
</p>
<p>
</p>

View File

@@ -1,8 +1,8 @@
from odoo import models, fields, api
from odoo.exceptions import ValidationError
from odoo.modules import get_resource_path
from OCC.Extend.DataExchange import read_step_file
from OCC.Extend.DataExchange import write_stl_file
# from OCC.Extend.DataExchange import read_step_file
# from OCC.Extend.DataExchange import write_stl_file
import logging
import base64
import hashlib
@@ -468,20 +468,20 @@ class ResProductTemplate(models.Model):
item.model_file = self.transition_glb_file(report_path, model_code)
# 将attach的datas内容转为glb文件
def transition_glb_file(self, report_path, code):
shapes = read_step_file(report_path)
output_file = os.path.join('/tmp', str(code) + '.stl')
write_stl_file(shapes, output_file, 'binary', 0.03, 0.5)
# 转化为glb
output_glb_file = os.path.join('/tmp', str(code) + '.glb')
util_path = get_resource_path('sf_dlm', 'static/util')
cmd = 'python3 %s/stl2gltf.py %s %s -b' % (util_path, output_file, output_glb_file)
os.system(cmd)
# 转base64
with open(output_glb_file, 'rb') as fileObj:
image_data = fileObj.read()
base64_data = base64.b64encode(image_data)
return base64_data
# def transition_glb_file(self, report_path, code):
# shapes = read_step_file(report_path)
# output_file = os.path.join('/tmp', str(code) + '.stl')
# write_stl_file(shapes, output_file, 'binary', 0.03, 0.5)
# # 转化为glb
# output_glb_file = os.path.join('/tmp', str(code) + '.glb')
# util_path = get_resource_path('sf_dlm', 'static/util')
# cmd = 'python3 %s/stl2gltf.py %s %s -b' % (util_path, output_file, output_glb_file)
# os.system(cmd)
# # 转base64
# with open(output_glb_file, 'rb') as fileObj:
# image_data = fileObj.read()
# base64_data = base64.b64encode(image_data)
# return base64_data
@api.onchange('integral_cutting_tool_type_id')
def _get_integral_cutting_tool_type_info(self):

View File

@@ -1,2 +1,2 @@
# -*-coding:utf-8-*-
from . import models
from . import models

View File

@@ -16,6 +16,7 @@
'security/ir.model.access.csv',
'views/tool_base_views.xml',
'views/menu_view.xml',
],
'demo': [
],

View File

@@ -1,4 +1,2 @@
from . import base

View File

@@ -1,12 +1,15 @@
# -*- coding: utf-8 -*-
from odoo import fields, models, api
# 功能刀具预警
class FunctionalCuttingToolEntity(models.Model):
_name = 'sf.functional.cutting.tool.entity'
_inherit = 'sf.functional.cutting.tool'
_description = '功能刀具预警'
_description = '功能刀具管理'
order = fields.Char(string='')
functional_cutting_tool_id = fields.Many2one('sf.functional.cutting.tool', string='功能刀具', invisible=True)
# 功能刀具预警 特有字段
install_tool_time = fields.Char("装刀时间")
outbound_time = fields.Char('出库时间')
on_board_time = fields.Char('上机时间')
@@ -20,5 +23,77 @@ class FunctionalCuttingToolEntity(models.Model):
dispose_user = fields.Char('处理人')
dispose_time = fields.Char('处理时间')
dispose_func = fields.Char('处理方法/措施')
remake = fields.Char('备注')
remark = fields.Char('备注')
# 功能刀具出入库记录 特有字段
thickness = fields.Selection([('1', ''), ('2', ''), ('3', '')], string='粗/中/细')
max_life_span = fields.Char(string='最大寿命值')
# alarm_value = fields.Char(string='报警值')
# used_value = fields.Char(string='已使用值')
current_state = fields.Char(string='当前状态')
current_store_area = fields.Char(string='当前库区')
current_store_place = fields.Char(string='当前库位')
number = fields.Integer(string='数量')
reason_application = fields.Char(string='申请原因')
applicant = fields.Char(string='申请人')
return_staff = fields.Char(string='归还人')
return_time = fields.Date(string='归还入库时间')
tool_state = fields.Char(string="刀具状态")
tool_install_staff = fields.Char(string='装刀人')
tool_install_time = fields.Datetime(string='装刀时间')
receive_equipment = fields.Char(string='领用机台')
receive_staff = fields.Char(string='领用人')
receive_time = fields.Char(string='领用出库时间')
# remark = fields.Text(string='备注/说明')
# 功能刀具实时分布
tool_stock_num = fields.Text(string='刀具房库存数量')
side_shelf_num = fields.Text(string='线边货架货架数量')
on_tool_stock_num = fields.Text(string='机内刀库库存数量')
tool_stock_total = fields.Text(string='合计')
return_reuse_num_re = fields.Text(string='归还再用数量(精)')
return_reuse_num_co = fields.Text(string='归还再用数量(粗)')
return_processing_num = fields.Text(string='归还需磨削数量')
return_total = fields.Text(string='合计')
total = fields.Text(string='总计')
# remark = fields.Text(string='备注/说明')
# @api.onchange('functional_cutting_tool_id')
# def get_functional_cutting_tool_info(self):
# for item in self:
# item.code = item.functional_cutting_tool_id.code,
# item.name = item.functional_cutting_tool_id.name,
# item.functional_model_number = item.functional_cutting_tool_id.functional_model_number,
# item.integral_model_number = item.functional_cutting_tool_id.integral_model_number,
# item.blade_model_number = item.functional_cutting_tool_id.blade_model_number,
# item.cutterbar_model_number = item.functional_cutting_tool_id.cutterbar_model_number,
# item.cutterpad_model_number = item.functional_cutting_tool_id.cutterpad_model_number,
# item.handle_model_number = item.functional_cutting_tool_id.handle_model_number,
# item.chuck_model_number = item.functional_cutting_tool_id.chuck_model_number,
# item.diameter = item.functional_cutting_tool_id.diameter,
# item.tool_grade = item.functional_cutting_tool_id.tool_grade,
# item.machining_accuracy = item.functional_cutting_tool_id.machining_accuracy,
# item.ctool_lengthode = item.functional_cutting_tool_id.tool_length,
# item.blade_number = item.functional_cutting_tool_id.blade_number,
# item.integral_blade_length = item.functional_cutting_tool_id.integral_blade_length,
# item.effective_blade_length = item.functional_cutting_tool_id.effective_blade_length,
# item.max_life = item.functional_cutting_tool_id.max_life,
# item.is_standard = item.functional_cutting_tool_id.is_standard,
# item.applicable_range = item.functional_cutting_tool_id.applicable_range,
@api.model
def create(self, vals):
if not vals.get('order'):
vals['order'] = self._generate_code()
return super(FunctionalCuttingToolEntity, self).create(vals)
@api.model
def _generate_code(self):
last_tool = self.search([], order='id desc', limit=1)
if last_tool:
last_code = int(last_tool.code.split('-')[-1])
new_code = '{:03d}'.format(last_code + 1)
else:
new_code = '001'
return new_code

View File

@@ -1,5 +1,5 @@
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_sf_functional_cutting_tool_warning,sf.functional.cutting.tool.warning,model_sf_functional_cutting_tool_warning,base.group_user,1,1,1,1
access_sf_functional_cutting_tool_entity,sf.functional.cutting.tool.entity,model_sf_functional_cutting_tool_entity,base.group_user,1,1,1,1
1 id name model_id:id group_id:id perm_read perm_write perm_create perm_unlink
2 access_sf_functional_cutting_tool_warning access_sf_functional_cutting_tool_entity sf.functional.cutting.tool.warning sf.functional.cutting.tool.entity model_sf_functional_cutting_tool_warning model_sf_functional_cutting_tool_entity base.group_user 1 1 1 1
3
4
5

View File

@@ -6,10 +6,11 @@
<field name="name">功能刀具预警</field>
<field name="type">ir.actions.act_window</field>
<field name="res_model">sf.functional.cutting.tool.entity</field>
<field name="view_mode">tree,form</field>
<field name="view_mode">tree</field>
</record>
<menuitem id="menu_sf_tool_manage"
name="刀具管理"
groups="mrp.group_mrp_routings"
@@ -20,7 +21,7 @@
parent="menu_sf_tool_manage"
name="功能刀具列表"
sequence="3"
action="sf_base.action_sf_functional_cutting_tool"
action="sf_function_tool_entry_list_view_act"
/>
@@ -28,8 +29,25 @@
id="menu_sf_functional_cutting_tool_warning"
parent="menu_sf_tool_manage"
name="功能刀具预警"
sequence="3"
action="action_sf_functional_cutting_tool_warning"
sequence="4"
action="sf_function_tool_entry_warning_view_act"
/>
<menuitem
sequence="6"
name="功能刀具实时分布"
id="menu_sf_functional_tool_real_time_distribution"
action="sf_functional_tool_real_time_distribution_view_act"
parent="menu_sf_tool_manage"
/>
<menuitem
sequence="10"
name="功能刀具出入库记录"
id="menu_sf_function_tool_entry_exit_records"
action="sf_function_tool_entry_exit_records_view_act"
parent="menu_sf_tool_manage"
/>
</data>
</odoo>

View File

@@ -1,6 +1,45 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<data>
<!-- 功能刀具列表tree view -->
<record id="view_functional_cutting_tool_list_tree" model="ir.ui.view">
<field name="name">sf.functional.cutting.tool.entity.list.tree</field>
<field name="model">sf.functional.cutting.tool.entity</field>
<field name="arch" type="xml">
<tree string="功能刀具">
<field name="code" />
<field name="name" />
<field name="functional_model_number" />
<field name="integral_model_number"/>
<field name="blade_model_number" optional="hide"/>
<field name="cutterbar_model_number" optional="hide"/>
<field name="cutterpad_model_number" optional="hide"/>
<field name="handle_model_number" optional="hide"/>
<field name="chuck_model_number" optional="hide"/>
<field name="diameter" optional="show"/>
<field name="tool_grade" optional="show"/>
<field name="machining_accuracy" optional="hide"/>
<field name="tool_length" optional="show"/>
<field name="blade_number" optional="show"/>
<field name="integral_blade_length" optional="show"/>
<field name="effective_blade_length" optional="show"/>
<field name="max_life" optional="show"/>
<field name="is_standard" optional="show"/>
<field name="applicable_range" optional="show"/>
<field name="image" widget='image' optional="show"/>
</tree>
</field>
</record>
<record id="sf_function_tool_entry_list_view_act" model="ir.actions.act_window">
<field name="name">功能刀具列表</field>
<field name="type">ir.actions.act_window</field>
<field name="res_model">sf.functional.cutting.tool.entity</field>
<field name="view_mode">tree</field>
<field name="view_id" ref="view_functional_cutting_tool_list_tree"/>
</record>
<!-- 功能刀具预警tree view -->
<record id="view_functional_cutting_tool_warning_tree" model="ir.ui.view">
<field name="name">sf.functional.cutting.tool.entity.tree</field>
@@ -30,79 +69,125 @@
<field name="dispose_user" optional="show"/>
<field name="dispose_time" optional="show"/>
<field name="dispose_func" optional="show"/>
<field name="remake" optional="show"/>
<field name="remark" optional="show"/>
</tree>
</field>
</record>
<!-- form view -->
<record id="view_functional_cutting_tool_warning_form" model="ir.ui.view">
<field name="name">sf.functional.cutting.tool.entity.form</field>
<record id="sf_function_tool_entry_warning_view_act" model="ir.actions.act_window">
<field name="name">功能刀具预警</field>
<field name="type">ir.actions.act_window</field>
<field name="res_model">sf.functional.cutting.tool.entity</field>
<field name="view_mode">tree</field>
<field name="view_id" ref="view_functional_cutting_tool_warning_tree"/>
</record>
<!-- ========================================功能刀具出入库记录================================================================== -->
<record id="sf_function_tool_entry_exit_records_view_tree" model="ir.ui.view">
<field name="name">功能刀具出入库记录</field>
<field name="model">sf.functional.cutting.tool.entity</field>
<field name="arch" type="xml">
<form string="功能刀具">
<sheet>
<group col='1'>
<group string='基本信息'>
<group>
<field name="code"/>
<field name="name"/>
<field name="functional_model_number"/>
<field name="integral_model_number"/>
<field name="blade_model_number"/>
<field name="cutterbar_model_number"/>
<field name="cutterpad_model_number"/>
<field name="handle_model_number"/>
<field name="chuck_model_number"/>
</group>
<group>
<field name="image" nolabel="1" widget="image"/>
</group>
</group>
<group string='参数信息'>
<group>
<field name="diameter"/>
<field name="tool_grade"/>
<field name="machining_accuracy"/>
<field name="tool_length"/>
<field name="blade_number"/>
</group>
<group>
<field name="integral_blade_length"/>
<field name="effective_blade_length"/>
<field name="max_life"/>
<field name="is_standard"/>
</group>
</group>
<group string='其他信息'>
<group>
<field name="applicable_range"/>
<field name="install_tool_time"/>
<field name="outbound_time"/>
<field name="on_board_time"/>
<field name="machine_tool_code"/>
<field name="cutting_tool_code"/>
<field name="idle_time"/>
</group><group>
<field name="alarm_value"/>
<field name="used_value"/>
<field name="alarm_type"/>
<field name="alarm_time"/>
<field name="dispose_user"/>
<field name="dispose_time"/>
<field name="dispose_func"/>
<field name="remake"/>
</group>
</group>
</group>
</sheet>
</form>
<tree>
<!-- <field name="order"/>-->
<field name="code"/>
<field name="name"/>
<field name="functional_model_number"/>
<field name="integral_model_number"/>
<field name="blade_model_number" optional="hide"/>
<field name="cutterbar_model_number" optional="hide"/>
<field name="cutterpad_model_number" optional="hide"/>
<field name="handle_model_number" optional="hide"/>
<field name="chuck_model_number" optional="hide"/>
<field name="diameter" optional="hide"/>
<field name="tool_grade" optional="hide"/>
<field name="machining_accuracy" optional="hide"/>
<field name="tool_length" optional="hide"/>
<field name="blade_number" optional="hide"/>
<field name="integral_blade_length" optional="hide"/>
<field name="effective_blade_length" optional="hide"/>
<field name="max_life" optional="hide"/>
<field name="is_standard" optional="hide"/>
<field name="applicable_range" optional="hide"/>
<field name="thickness" optional="show"/>
<field name="max_life_span" optional="show"/>
<field name="alarm_value" optional="show"/>
<field name="used_value" optional="show"/>
<field name="current_state" optional="show"/>
<field name="current_store_area" optional="show"/>
<field name="current_store_place" optional="show"/>
<field name="number" optional="show"/>
<field name="reason_application" optional="show"/>
<field name="applicant" optional="show"/>
<field name="return_staff" optional="show"/>
<field name="return_time" optional="show"/>
<field name="tool_state" optional="show"/>
<field name="tool_install_staff" optional="show"/>
<field name="tool_install_time" optional="show"/>
<field name="receive_equipment" optional="show"/>
<field name="receive_staff" optional="show"/>
<field name="receive_time" optional="show"/>
<field name="remark" optional="show"/>
</tree>
</field>
</record>
<record id="sf_function_tool_entry_exit_records_view_act" model="ir.actions.act_window">
<field name="name">功能刀具出入库记录</field>
<field name="type">ir.actions.act_window</field>
<field name="res_model">sf.functional.cutting.tool.entity</field>
<field name="view_mode">tree</field>
<field name="view_id" ref="sf_function_tool_entry_exit_records_view_tree"/>
</record>
<!-- =====================================功能刀具实时分布============================================================= -->
<record id="sf_functional_tool_real_time_distribution_view_tree" model="ir.ui.view">
<field name="name">功能刀具实时分布</field>
<field name="model">sf.functional.cutting.tool.entity</field>
<field name="arch" type="xml">
<tree>
<!-- <field name="order"/>-->
<field name="code"/>
<field name="name"/>
<field name="functional_model_number"/>
<field name="integral_model_number"/>
<field name="blade_model_number" optional="hide"/>
<field name="cutterbar_model_number" optional="hide"/>
<field name="cutterpad_model_number" optional="hide"/>
<field name="handle_model_number" optional="hide"/>
<field name="chuck_model_number" optional="hide"/>
<field name="diameter" optional="hide"/>
<field name="tool_grade" optional="hide"/>
<field name="machining_accuracy" optional="hide"/>
<field name="tool_length" optional="hide"/>
<field name="blade_number" optional="hide"/>
<field name="integral_blade_length" optional="hide"/>
<field name="effective_blade_length" optional="hide"/>
<field name="max_life" optional="hide"/>
<field name="is_standard" optional="hide"/>
<field name="applicable_range" optional="hide"/>
<field name="tool_stock_num" optional="show"/>
<field name="side_shelf_num" optional="show"/>
<field name="on_tool_stock_num" optional="show"/>
<field name="tool_stock_total" optional="show"/>
<field name="return_reuse_num_re" optional="show"/>
<field name="return_reuse_num_co" optional="show"/>
<field name="return_processing_num" optional="show"/>
<field name="return_total" optional="show"/>
<field name="total" optional="show"/>
<field name="remark" optional="show"/>
</tree>
</field>
</record>
<record id="sf_functional_tool_real_time_distribution_view_act" model="ir.actions.act_window">
<field name="name">功能刀具实时分布</field>
<field name="type">ir.actions.act_window</field>
<field name="res_model">sf.functional.cutting.tool.entity</field>
<field name="view_mode">tree</field>
<field name="view_id" ref="sf_functional_tool_real_time_distribution_view_tree"/>
</record>
</data>
</odoo>