Merge branch 'develop' of https://e.coding.net/jikimo-hn/jikimo_sfs/jikimo_sf into feature/刀具基础信息生成产品模板
This commit is contained in:
@@ -11,7 +11,7 @@
|
||||
</record>
|
||||
<!-- 功能刀具action -->
|
||||
<record id="action_sf_functional_cutting_tool" model="ir.actions.act_window">
|
||||
<field name="name">功能刀具型号</field>
|
||||
<field name="name">功能刀具</field>
|
||||
<field name="type">ir.actions.act_window</field>
|
||||
<field name="res_model">sf.functional.cutting.tool</field>
|
||||
<field name="view_mode">tree,form</field>
|
||||
|
||||
@@ -35,6 +35,18 @@
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 刀具物料search view -->
|
||||
<record model="ir.ui.view" id="view_cutting_tool_material_search">
|
||||
<field name="name">sf.cutting.tool.material.search</field>
|
||||
<field name="model">sf.cutting.tool.material</field>
|
||||
<field name="arch" type="xml">
|
||||
<search string="刀具物料">
|
||||
<field name="name" string="名称搜索" filter_domain="[('name','ilike',self)]"/>
|
||||
<field name="code" string="编码搜索" filter_domain="[('code','ilike',self)]"/>
|
||||
|
||||
</search>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 功能刀具tree view -->
|
||||
<record id="view_functional_cutting_tool_tree" model="ir.ui.view">
|
||||
<field name="name">sf.functional.cutting.tool.tree</field>
|
||||
@@ -100,6 +112,17 @@
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 功能刀具search view -->
|
||||
<record model="ir.ui.view" id="view_sf_functional_cutting_tool_search">
|
||||
<field name="name">sf.functional.cutting.tool.search</field>
|
||||
<field name="model">sf.functional.cutting.tool</field>
|
||||
<field name="arch" type="xml">
|
||||
<search string="功能刀具">
|
||||
<field name="name" string="名称搜索" filter_domain="[('name','ilike',self)]"/>
|
||||
<field name="code" string="编码搜索" filter_domain="[('code','ilike',self)]"/>
|
||||
</search>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<!-- 整体式刀具tree view -->
|
||||
<record id="view_integral_cutting_tool_tree" model="ir.ui.view">
|
||||
@@ -169,6 +192,17 @@
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 整体式刀具search view -->
|
||||
<record model="ir.ui.view" id="view_integral_cutting_tool_search">
|
||||
<field name="name">sf.integral.cutting.tool.search</field>
|
||||
<field name="model">sf.integral.cutting.tool</field>
|
||||
<field name="arch" type="xml">
|
||||
<search string="整体式刀具">
|
||||
<field name="name" string="名称搜索" filter_domain="[('name','ilike',self)]"/>
|
||||
<field name="code" string="编码搜索" filter_domain="[('code','ilike',self)]"/>
|
||||
</search>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 刀片tree -->
|
||||
<record id="view_blade_tree" model="ir.ui.view">
|
||||
<field name="name">sf.blade.tree</field>
|
||||
@@ -233,6 +267,17 @@
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 刀片search view -->
|
||||
<record model="ir.ui.view" id="view_blade_search">
|
||||
<field name="name">sf.blade.search</field>
|
||||
<field name="model">sf.blade</field>
|
||||
<field name="arch" type="xml">
|
||||
<search string="刀片">
|
||||
<field name="name" string="名称搜索" filter_domain="[('name','ilike',self)]"/>
|
||||
<field name="code" string="编码搜索" filter_domain="[('code','ilike',self)]"/>
|
||||
</search>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 刀杆tree -->
|
||||
<record id="view_cutter_bar_tree" model="ir.ui.view">
|
||||
<field name="name">sf.cutter.bar.tree</field>
|
||||
@@ -300,6 +345,17 @@
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 刀杆search view -->
|
||||
<record model="ir.ui.view" id="view_cutter_bar_search">
|
||||
<field name="name">sf.cutter.bar.search</field>
|
||||
<field name="model">sf.cutter.bar</field>
|
||||
<field name="arch" type="xml">
|
||||
<search string="刀杆">
|
||||
<field name="name" string="名称搜索" filter_domain="[('name','ilike',self)]"/>
|
||||
<field name="code" string="编码搜索" filter_domain="[('code','ilike',self)]"/>
|
||||
</search>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<!-- 刀盘tree -->
|
||||
<record id="view_cutter_pad_tree" model="ir.ui.view">
|
||||
@@ -366,6 +422,17 @@
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 刀盘search view -->
|
||||
<record model="ir.ui.view" id="view_cutter_pad_search">
|
||||
<field name="name">sf.cutter.pad.search</field>
|
||||
<field name="model">sf.cutter.pad</field>
|
||||
<field name="arch" type="xml">
|
||||
<search string="刀盘">
|
||||
<field name="name" string="名称搜索" filter_domain="[('name','ilike',self)]"/>
|
||||
<field name="code" string="编码搜索" filter_domain="[('code','ilike',self)]"/>
|
||||
</search>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<!-- 刀柄tree -->
|
||||
<record id="view_cutter_handle_tree" model="ir.ui.view">
|
||||
@@ -434,6 +501,17 @@
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 刀柄search view -->
|
||||
<record model="ir.ui.view" id="view_handle_search">
|
||||
<field name="name">sf.handle.search</field>
|
||||
<field name="model">sf.handle</field>
|
||||
<field name="arch" type="xml">
|
||||
<search string="刀柄">
|
||||
<field name="name" string="名称搜索" filter_domain="[('name','ilike',self)]"/>
|
||||
<field name="code" string="编码搜索" filter_domain="[('code','ilike',self)]"/>
|
||||
</search>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<!-- 夹头tree -->
|
||||
<record id="view_cutter_chuck_tree" model="ir.ui.view">
|
||||
@@ -499,6 +577,17 @@
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
<!-- 夹头search view -->
|
||||
<record model="ir.ui.view" id="view_chuck_search">
|
||||
<field name="name">sf.chuck.search</field>
|
||||
<field name="model">sf.chuck</field>
|
||||
<field name="arch" type="xml">
|
||||
<search string="夹头">
|
||||
<field name="name" string="名称搜索" filter_domain="[('name','ilike',self)]"/>
|
||||
<field name="code" string="编码搜索" filter_domain="[('code','ilike',self)]"/>
|
||||
</search>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<!-- 功能刀具类型tree -->
|
||||
<record id="view_cutter_function_tree" model="ir.ui.view">
|
||||
|
||||
@@ -42,95 +42,96 @@ class ResConfigSettings(models.TransientModel):
|
||||
_logger.info("同步资源库机床类型")
|
||||
# self.env['sf.production.process.parameter'].sync_all_production_process_parameter()
|
||||
# _logger.info("同步表面工艺参数")
|
||||
_logger.info("定时同步每日功能刀具类型列表...")
|
||||
# self.env['sf.functional.cutting.tool.model'].sync_functional_cutting_tool_model()
|
||||
_logger.info("同步每日功能刀具类型完成")
|
||||
# _logger.info("定时同步每日功能刀具类型列表...")
|
||||
# # self.env['sf.functional.cutting.tool.model'].sync_functional_cutting_tool_model()
|
||||
# _logger.info("同步每日功能刀具类型完成")
|
||||
_logger.info("同步所有功能刀具类型...")
|
||||
self.env['sf.functional.cutting.tool.model'].sync_all_functional_cutting_tool_model()
|
||||
_logger.info("同步所有功能刀具类型完成")
|
||||
_logger.info("定时同步每日整体式刀具类型列表...")
|
||||
# self.env['sf.integral.cutting.tool'].sync_integral_cutting_tool()
|
||||
_logger.info("同步整体式刀具类型完成")
|
||||
_logger.info("同步每日刀具物料...")
|
||||
self.env['sf.cutting.tool.material'].sync_cutting_tool_material()
|
||||
_logger.info("同步每日刀具物料完成")
|
||||
# _logger.info("定时同步每日整体式刀具类型列表...")
|
||||
# # self.env['sf.integral.cutting.tool'].sync_integral_cutting_tool()
|
||||
# _logger.info("同步整体式刀具类型完成")
|
||||
# _logger.info("同步每日刀具物料...")
|
||||
# self.env['sf.cutting.tool.material'].sync_cutting_tool_material()
|
||||
# _logger.info("同步每日刀具物料完成")
|
||||
_logger.info("同步所有刀具物料...")
|
||||
self.env['sf.cutting.tool.material'].sync_all_cutting_tool_material()
|
||||
_logger.info("同步每日刀片类型列表...")
|
||||
self.env['sf.blade.model'].sync_blade_model()
|
||||
_logger.info("同步每日刀片类型完成")
|
||||
_logger.info("同步所有刀具物料完成")
|
||||
# _logger.info("同步每日刀片类型列表...")
|
||||
# self.env['sf.blade.model'].sync_blade_model()
|
||||
# _logger.info("同步每日刀片类型完成")
|
||||
_logger.info("同步所有刀片类型列表...")
|
||||
self.env['sf.blade.model'].sync_all_blade_model()
|
||||
_logger.info("同步所有刀片类型完成")
|
||||
_logger.info("同步每日刀杆类型...")
|
||||
self.env['sf.cutter.bar.model'].sync_cutter_bar_model()
|
||||
_logger.info("同步每日刀杆类型完成")
|
||||
# _logger.info("同步每日刀杆类型...")
|
||||
# self.env['sf.cutter.bar.model'].sync_cutter_bar_model()
|
||||
# _logger.info("同步每日刀杆类型完成")
|
||||
_logger.info("同步所有刀杆类型...")
|
||||
self.env['sf.cutter.bar.model'].sync_all_cutter_bar_model()
|
||||
_logger.info("同步所有刀杆类型完成")
|
||||
_logger.info("同步每日刀盘类型...")
|
||||
self.env['sf.cutter.pad.model'].sync_cutter_pad_model()
|
||||
_logger.info("同步每日刀盘类型完成")
|
||||
# _logger.info("同步每日刀盘类型...")
|
||||
# self.env['sf.cutter.pad.model'].sync_cutter_pad_model()
|
||||
# _logger.info("同步每日刀盘类型完成")
|
||||
_logger.info("同步所有刀盘类型...")
|
||||
self.env['sf.cutter.pad.model'].sync_all_cutter_pad_model()
|
||||
_logger.info("同步所有刀盘类型完成")
|
||||
_logger.info("同步每日刀柄类型...")
|
||||
self.env['sf.handle.model'].sync_handle_model()
|
||||
_logger.info("同步每日刀柄类型完成")
|
||||
# _logger.info("同步每日刀柄类型...")
|
||||
# self.env['sf.handle.model'].sync_handle_model()
|
||||
# _logger.info("同步每日刀柄类型完成")
|
||||
_logger.info("同步所有刀柄类型...")
|
||||
self.env['sf.handle.model'].sync_all_handle_model()
|
||||
_logger.info("同步所有刀柄类型完成")
|
||||
_logger.info("同步每日夹头类型...")
|
||||
self.env['sf.chuck.model'].sync_chuck_model()
|
||||
_logger.info("同步每日夹头类型完成")
|
||||
# _logger.info("同步每日夹头类型...")
|
||||
# self.env['sf.chuck.model'].sync_chuck_model()
|
||||
# _logger.info("同步每日夹头类型完成")
|
||||
_logger.info("同步所有夹头类型...")
|
||||
self.env['sf.chuck.model'].sync_all_chuck_model()
|
||||
_logger.info("同步所有夹头类型完成")
|
||||
_logger.info("同步每日整体式刀具类型...")
|
||||
self.env['sf.integral.cutting.tool.model'].sync_integral_cutting_tool_model()
|
||||
_logger.info("同步每日整体式刀具类型完成")
|
||||
# _logger.info("同步每日整体式刀具类型...")
|
||||
# self.env['sf.integral.cutting.tool.model'].sync_integral_cutting_tool_model()
|
||||
# _logger.info("同步每日整体式刀具类型完成")
|
||||
_logger.info("同步所有整体式刀具类型...")
|
||||
self.env['sf.integral.cutting.tool.model'].sync_all_integral_cutting_tool_model()
|
||||
_logger.info("同步所有整体式刀具类型完成")
|
||||
_logger.info("同步每日刀片列表...")
|
||||
self.env['sf.blade'].sync_blade()
|
||||
_logger.info("同步每日刀片完成")
|
||||
# _logger.info("同步每日刀片列表...")
|
||||
# self.env['sf.blade'].sync_blade()
|
||||
# _logger.info("同步每日刀片完成")
|
||||
_logger.info("同步所有刀片列表...")
|
||||
self.env['sf.blade'].sync_all_blade()
|
||||
_logger.info("同步所有刀片完成")
|
||||
_logger.info("同步每日刀杆列表...")
|
||||
self.env['sf.cutter.bar'].sync_cutter_bar()
|
||||
_logger.info("同步每日刀杆完成")
|
||||
# _logger.info("同步每日刀杆列表...")
|
||||
# self.env['sf.cutter.bar'].sync_cutter_bar()
|
||||
# _logger.info("同步每日刀杆完成")
|
||||
_logger.info("同步所有刀杆列表...")
|
||||
self.env['sf.cutter.bar'].sync_all_cutter_bar()
|
||||
_logger.info("同步所有刀杆完成")
|
||||
_logger.info("同步每日刀盘列表...")
|
||||
self.env['sf.cutter.pad'].sync_cutter_pad()
|
||||
_logger.info("同步每日刀盘完成")
|
||||
# _logger.info("同步每日刀盘列表...")
|
||||
# self.env['sf.cutter.pad'].sync_cutter_pad()
|
||||
# _logger.info("同步每日刀盘完成")
|
||||
_logger.info("同步所有刀盘列表...")
|
||||
self.env['sf.cutter.pad'].sync_all_cutter_pad()
|
||||
_logger.info("同步所有刀盘完成")
|
||||
_logger.info("同步每日刀柄列表...")
|
||||
self.env['sf.handle'].sync_handle()
|
||||
_logger.info("同步每日刀柄完成")
|
||||
# _logger.info("同步每日刀柄列表...")
|
||||
# self.env['sf.handle'].sync_handle()
|
||||
# _logger.info("同步每日刀柄完成")
|
||||
_logger.info("同步所有刀柄列表...")
|
||||
self.env['sf.handle'].sync_all_handle()
|
||||
_logger.info("同步所有刀柄完成")
|
||||
_logger.info("同步每日夹头列表...")
|
||||
self.env['sf.chuck'].sync_chuck()
|
||||
_logger.info("同步每日夹头完成")
|
||||
# _logger.info("同步每日夹头列表...")
|
||||
# self.env['sf.chuck'].sync_chuck()
|
||||
# _logger.info("同步每日夹头完成")
|
||||
_logger.info("同步所有夹头列表...")
|
||||
self.env['sf.chuck'].sync_all_chuck()
|
||||
_logger.info("同步所有夹头完成")
|
||||
_logger.info("同步每日整体式刀具列表...")
|
||||
self.env['sf.integral.cutting.tool'].sync_integral_cutting_tool()
|
||||
_logger.info("同步每日整体式刀具完成")
|
||||
# _logger.info("同步每日整体式刀具列表...")
|
||||
# self.env['sf.integral.cutting.tool'].sync_integral_cutting_tool()
|
||||
# _logger.info("同步每日整体式刀具完成")
|
||||
_logger.info("同步所有整体式刀具列表...")
|
||||
self.env['sf.integral.cutting.tool'].sync_all_integral_cutting_tool()
|
||||
_logger.info("同步所有整体式刀具完成")
|
||||
_logger.info("同步每日同步功能刀具列表...")
|
||||
self.env['sf.functional.cutting.tool'].sync_functional_cutting_tool()
|
||||
_logger.info("同步每日功能刀具列表完成")
|
||||
# _logger.info("同步每日同步功能刀具列表...")
|
||||
# self.env['sf.functional.cutting.tool'].sync_functional_cutting_tool()
|
||||
# _logger.info("同步每日功能刀具列表完成")
|
||||
_logger.info("同步所有功能刀具列表...")
|
||||
self.env['sf.functional.cutting.tool'].sync_all_functional_cutting_tool()
|
||||
_logger.info("同步所有功能刀具列表完成")
|
||||
|
||||
@@ -1988,7 +1988,7 @@ class SyncCutterBar(models.Model):
|
||||
self.env['sf.cutter.bar'].create({
|
||||
"code": item['code'],
|
||||
"name": item['name'],
|
||||
"cutter_bar_model_number": self.env['sf.cutter.bar'].search(
|
||||
"cutter_bar_model_number": self.env['sf.cutter.bar.model'].search(
|
||||
[("code", '=', item['cutter_bar_model_number'])]).id,
|
||||
"brand": self.env['sf.machine.brand'].search(
|
||||
[("code", '=', item['brand'])]).id,
|
||||
@@ -2013,7 +2013,7 @@ class SyncCutterBar(models.Model):
|
||||
brand.write({
|
||||
"code": item['code'],
|
||||
"name": item['name'],
|
||||
"cutter_bar_model_number": self.env['sf.cutter.bar'].search(
|
||||
"cutter_bar_model_number": self.env['sf.cutter.bar.model'].search(
|
||||
[("code", '=', item['cutter_bar_model_number'])]).id,
|
||||
"brand": self.env['sf.machine.brand'].search(
|
||||
[("code", '=', item['brand'])]).id,
|
||||
@@ -2049,7 +2049,7 @@ class SyncCutterBar(models.Model):
|
||||
r = requests.post(strUrl, json={}, data=None, headers=headers)
|
||||
r = r.json()
|
||||
result = json.loads(r['result'])
|
||||
# print('result:%s' % result)
|
||||
print('result:%s' % result)
|
||||
if result['status'] == 1:
|
||||
if result.get('mrs_cutter_bar_all_list'):
|
||||
for item in result['mrs_cutter_bar_all_list']:
|
||||
@@ -2070,7 +2070,7 @@ class SyncCutterBar(models.Model):
|
||||
self.env['sf.cutter.bar'].create({
|
||||
"code": item['code'],
|
||||
"name": item['name'],
|
||||
"cutter_bar_model_number": self.env['sf.cutter.bar'].search(
|
||||
"cutter_bar_model_number": self.env['sf.cutter.bar.model'].search(
|
||||
[("code", '=', item['cutter_bar_model_number'])]).id,
|
||||
"brand": self.env['sf.machine.brand'].search(
|
||||
[("code", '=', item['brand'])]).id,
|
||||
@@ -2095,7 +2095,7 @@ class SyncCutterBar(models.Model):
|
||||
brand.write({
|
||||
"code": item['code'],
|
||||
"name": item['name'],
|
||||
"cutter_bar_model_number": self.env['sf.cutter.bar'].search(
|
||||
"cutter_bar_model_number": self.env['sf.cutter.bar.model'].search(
|
||||
[("code", '=', item['cutter_bar_model_number'])]).id,
|
||||
"brand": self.env['sf.machine.brand'].search(
|
||||
[("code", '=', item['brand'])]).id,
|
||||
|
||||
2
sf_tool_management/__init__.py
Normal file
2
sf_tool_management/__init__.py
Normal file
@@ -0,0 +1,2 @@
|
||||
# -*-coding:utf-8-*-
|
||||
from . import models
|
||||
34
sf_tool_management/__manifest__.py
Normal file
34
sf_tool_management/__manifest__.py
Normal file
@@ -0,0 +1,34 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||||
{
|
||||
'name': '机企猫智能工厂 刀具管理',
|
||||
'version': '1.0',
|
||||
'summary': '智能工厂刀具管理',
|
||||
'sequence': 1,
|
||||
'description': """
|
||||
在本模块,定义了主要的角色、菜单、基础业务对象
|
||||
""",
|
||||
'category': 'sf',
|
||||
'website': 'https://www.sf.jikimo.com',
|
||||
'depends': ['account', 'sf_base', 'mrp'],
|
||||
'data': [
|
||||
'security/group_security.xml',
|
||||
'security/ir.model.access.csv',
|
||||
'views/tool_base_views.xml',
|
||||
'views/menu_view.xml',
|
||||
|
||||
],
|
||||
'demo': [
|
||||
],
|
||||
'assets': {
|
||||
|
||||
'web.assets_qweb': [
|
||||
],
|
||||
|
||||
|
||||
},
|
||||
'license': 'LGPL-3',
|
||||
'installable': True,
|
||||
'application': False,
|
||||
'auto_install': False,
|
||||
}
|
||||
2
sf_tool_management/models/__init__.py
Normal file
2
sf_tool_management/models/__init__.py
Normal file
@@ -0,0 +1,2 @@
|
||||
from . import base
|
||||
|
||||
76
sf_tool_management/models/base.py
Normal file
76
sf_tool_management/models/base.py
Normal file
@@ -0,0 +1,76 @@
|
||||
# -*- 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 = '功能刀具管理'
|
||||
|
||||
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('上机时间')
|
||||
machine_tool_code = fields.Char('机台号')
|
||||
cutting_tool_code = fields.Char('刀位号')
|
||||
idle_time = fields.Char('闲置时长')
|
||||
alarm_value = fields.Char('报警值')
|
||||
used_value = fields.Char('已使用值')
|
||||
alarm_type = fields.Char('报警类型')
|
||||
alarm_time = fields.Char('报警时间')
|
||||
dispose_user = fields.Char('处理人')
|
||||
dispose_time = fields.Char('处理时间')
|
||||
dispose_func = 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.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
|
||||
4
sf_tool_management/security/group_security.xml
Normal file
4
sf_tool_management/security/group_security.xml
Normal file
@@ -0,0 +1,4 @@
|
||||
<odoo>
|
||||
<data>
|
||||
</data>
|
||||
</odoo>
|
||||
7
sf_tool_management/security/ir.model.access.csv
Normal file
7
sf_tool_management/security/ir.model.access.csv
Normal file
@@ -0,0 +1,7 @@
|
||||
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
||||
access_sf_functional_cutting_tool_entity,sf.functional.cutting.tool.entity,model_sf_functional_cutting_tool_entity,base.group_user,1,1,1,1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
53
sf_tool_management/views/menu_view.xml
Normal file
53
sf_tool_management/views/menu_view.xml
Normal file
@@ -0,0 +1,53 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<odoo>
|
||||
<data>
|
||||
|
||||
<record id="action_sf_functional_cutting_tool_warning" 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>
|
||||
</record>
|
||||
|
||||
|
||||
|
||||
<menuitem id="menu_sf_tool_manage"
|
||||
name="刀具管理"
|
||||
groups="mrp.group_mrp_routings"
|
||||
parent="mrp.menu_mrp_root"
|
||||
sequence="20"/>
|
||||
<menuitem
|
||||
id="menu_sf_functional_cutting_tool"
|
||||
parent="menu_sf_tool_manage"
|
||||
name="功能刀具列表"
|
||||
sequence="3"
|
||||
action="sf_base.action_sf_functional_cutting_tool"
|
||||
/>
|
||||
|
||||
|
||||
<menuitem
|
||||
id="menu_sf_functional_cutting_tool_warning"
|
||||
parent="menu_sf_tool_manage"
|
||||
name="功能刀具预警"
|
||||
sequence="3"
|
||||
action="action_sf_functional_cutting_tool_warning"
|
||||
/>
|
||||
|
||||
<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>
|
||||
146
sf_tool_management/views/tool_base_views.xml
Normal file
146
sf_tool_management/views/tool_base_views.xml
Normal file
@@ -0,0 +1,146 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<odoo>
|
||||
<data>
|
||||
<!-- 功能刀具预警tree view -->
|
||||
<record id="view_functional_cutting_tool_warning_tree" model="ir.ui.view">
|
||||
<field name="name">sf.functional.cutting.tool.entity.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="install_tool_time" optional="show"/>
|
||||
<field name="outbound_time" optional="show"/>
|
||||
<field name="machining_accuracy" optional="hide"/>
|
||||
<field name="on_board_time" optional="show"/>
|
||||
<field name="machine_tool_code" optional="show"/>
|
||||
<field name="cutting_tool_code" optional="show"/>
|
||||
<field name="idle_time" optional="show"/>
|
||||
<field name="alarm_value" optional="show"/>
|
||||
<field name="used_value" optional="show"/>
|
||||
<field name="alarm_type" optional="show"/>
|
||||
<field name="alarm_time" optional="show"/>
|
||||
<field name="dispose_user" optional="show"/>
|
||||
<field name="dispose_time" optional="show"/>
|
||||
<field name="dispose_func" optional="show"/>
|
||||
<field name="remark" optional="show"/>
|
||||
|
||||
</tree>
|
||||
</field>
|
||||
</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">
|
||||
<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"/>
|
||||
<field name="cutterbar_model_number"/>
|
||||
<field name="cutterpad_model_number"/>
|
||||
<field name="handle_model_number"/>
|
||||
<field name="chuck_model_number"/>
|
||||
<field name="diameter"/>
|
||||
<field name="tool_grade"/>
|
||||
<field name="machining_accuracy"/>
|
||||
<field name="tool_length"/>
|
||||
<field name="blade_number"/>
|
||||
<field name="integral_blade_length"/>
|
||||
<field name="effective_blade_length"/>
|
||||
<field name="max_life"/>
|
||||
<field name="is_standard"/>
|
||||
<field name="applicable_range"/>
|
||||
<field name="thickness"/>
|
||||
<field name="max_life_span"/>
|
||||
<field name="alarm_value"/>
|
||||
<field name="used_value"/>
|
||||
<field name="current_state"/>
|
||||
<field name="current_store_area"/>
|
||||
<field name="current_store_place"/>
|
||||
<field name="number"/>
|
||||
<field name="reason_application"/>
|
||||
<field name="applicant"/>
|
||||
<field name="return_staff"/>
|
||||
<field name="return_time"/>
|
||||
<field name="tool_state"/>
|
||||
<field name="tool_install_staff"/>
|
||||
<field name="tool_install_time"/>
|
||||
<field name="receive_equipment"/>
|
||||
<field name="receive_staff"/>
|
||||
<field name="receive_time"/>
|
||||
<field name="remark"/>
|
||||
</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" width="200"/>
|
||||
<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"/>
|
||||
<field name="diameter"/>
|
||||
<field name="tool_grade"/>
|
||||
<field name="machining_accuracy"/>
|
||||
<field name="tool_length"/>
|
||||
<field name="blade_number"/>
|
||||
<field name="integral_blade_length"/>
|
||||
<field name="effective_blade_length"/>
|
||||
<field name="max_life"/>
|
||||
<field name="is_standard"/>
|
||||
<field name="applicable_range"/>
|
||||
<field name="tool_stock_num"/>
|
||||
<field name="side_shelf_num"/>
|
||||
<field name="on_tool_stock_num"/>
|
||||
<field name="tool_stock_total"/>
|
||||
<field name="return_reuse_num_re"/>
|
||||
<field name="return_reuse_num_co"/>
|
||||
<field name="return_processing_num"/>
|
||||
<field name="return_total"/>
|
||||
<field name="total"/>
|
||||
<field name="remark"/>
|
||||
</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>
|
||||
Reference in New Issue
Block a user