设备日志、oee优化
This commit is contained in:
@@ -7,7 +7,7 @@ class SfMaintenanceEquipmentOEE(models.Model):
|
|||||||
_description = '设备OEE'
|
_description = '设备OEE'
|
||||||
|
|
||||||
name = fields.Char('设备oee')
|
name = fields.Char('设备oee')
|
||||||
equipment_id = fields.Many2one('maintenance.equipment', '设备',
|
equipment_id = fields.Many2one('maintenance.equipment', '机台号',
|
||||||
domain="[('category_id.equipment_type', '=', '机床'),('state_zc', '=', '已注册')]")
|
domain="[('category_id.equipment_type', '=', '机床'),('state_zc', '=', '已注册')]")
|
||||||
type_id = fields.Many2one('sf.machine_tool.type', '型号', related='equipment_id.type_id')
|
type_id = fields.Many2one('sf.machine_tool.type', '型号', related='equipment_id.type_id')
|
||||||
machine_tool_picture = fields.Binary('设备图片', related='equipment_id.machine_tool_picture')
|
machine_tool_picture = fields.Binary('设备图片', related='equipment_id.machine_tool_picture')
|
||||||
@@ -15,12 +15,15 @@ class SfMaintenanceEquipmentOEE(models.Model):
|
|||||||
[("正常", "正常"), ("故障停机", "故障停机"), ("计划维保", "计划维保"), ("空闲", "空闲"),
|
[("正常", "正常"), ("故障停机", "故障停机"), ("计划维保", "计划维保"), ("空闲", "空闲"),
|
||||||
("封存(报废)", "封存(报废)")],
|
("封存(报废)", "封存(报废)")],
|
||||||
default='正常', string="机床状态", related='equipment_id.state')
|
default='正常', string="机床状态", related='equipment_id.state')
|
||||||
run_time = fields.Float('正常运行总时长(h)')
|
run_time = fields.Float('加工时长(h)')
|
||||||
equipment_time = fields.Float('总时长(h)')
|
equipment_time = fields.Float('开机时长(h)')
|
||||||
done_nums = fields.Integer('累计加工总件数')
|
done_nums = fields.Integer('加工件数')
|
||||||
utilization_rate = fields.Char('开动率')
|
utilization_rate = fields.Char('可用率')
|
||||||
fault_time = fields.Float('故障停机总时长(h)')
|
fault_time = fields.Float('故障时长')
|
||||||
fault_nums = fields.Integer('故障次数')
|
fault_nums = fields.Integer('故障次数')
|
||||||
|
# 故障率
|
||||||
|
fault_rate = fields.Char('故障率')
|
||||||
|
# 设备故障日志
|
||||||
sf_maintenance_logs_ids = fields.One2many('sf.maintenance.logs', 'maintenance_equipment_oee_id', '设备故障日志',
|
sf_maintenance_logs_ids = fields.One2many('sf.maintenance.logs', 'maintenance_equipment_oee_id', '设备故障日志',
|
||||||
related='equipment_id.sf_maintenance_logs_ids')
|
related='equipment_id.sf_maintenance_logs_ids')
|
||||||
oee_logs = fields.One2many('maintenance.equipment.oee.logs', 'equipment_oee_id', string='运行日志')
|
oee_logs = fields.One2many('maintenance.equipment.oee.logs', 'equipment_oee_id', string='运行日志')
|
||||||
@@ -38,12 +41,46 @@ class SfMaintenanceEquipmentOEELog(models.Model):
|
|||||||
_name = 'maintenance.equipment.oee.logs'
|
_name = 'maintenance.equipment.oee.logs'
|
||||||
_description = '设备运行日志'
|
_description = '设备运行日志'
|
||||||
|
|
||||||
name = fields.Char('运行日志')
|
equipment_id = fields.Many2one('maintenance.equipment', '机台号')
|
||||||
run_time = fields.Datetime('时间')
|
name = fields.Char('设备名称')
|
||||||
state = fields.Selection([("开机", "开机"), ("关机", "关机"), ("等待", "等待"), ("开始加工", "开始加工"),
|
machine_tool_picture = fields.Binary('设备图片')
|
||||||
("结束加工", "结束加工"), ("故障", "故障"),
|
type_id = fields.Many2one('sf.machine_tool.type', '品牌型号')
|
||||||
("检修", "检修"), ("保养", "保养")], default="", string="事件/状态")
|
state = fields.Selection([("加工", "加工"), ("关机", "关机"), ("待机", "待机"), ("故障", "故障"),
|
||||||
workorder_id = fields.Char('加工订单')
|
("检修", "检修"), ("保养", "保养")], default="", string="实时状态")
|
||||||
time = fields.Char('持续时长')
|
online_time = fields.Char('开机时长')
|
||||||
color = fields.Char('颜色', default=1)
|
|
||||||
|
offline_time = fields.Char('关机时长')
|
||||||
|
offline_nums = fields.Integer('关机次数')
|
||||||
|
# 待机时长
|
||||||
|
|
||||||
|
idle_time = fields.Char('待机时长')
|
||||||
|
|
||||||
|
# 待机率
|
||||||
|
idle_rate = fields.Char('待机率')
|
||||||
|
|
||||||
|
work_time = fields.Char('加工时长')
|
||||||
|
work_rate = fields.Char('可用率')
|
||||||
|
fault_time = fields.Char('故障时长')
|
||||||
|
fault_rate = fields.Char('故障率')
|
||||||
|
fault_nums = fields.Integer('故障次数')
|
||||||
|
|
||||||
|
detail_ids = fields.One2many('maintenance.equipment.oee.log.detail', 'log_id', string='日志详情')
|
||||||
|
|
||||||
|
# maintenance_time = fields.Char('维保时长')
|
||||||
|
# work_nums = fields.Integer('加工件数')
|
||||||
equipment_oee_id = fields.Many2one('maintenance.equipment.oee', '设备OEE')
|
equipment_oee_id = fields.Many2one('maintenance.equipment.oee', '设备OEE')
|
||||||
|
|
||||||
|
|
||||||
|
# 设备运行日志详情
|
||||||
|
class SfMaintenanceEquipmentOEELogDetail(models.Model):
|
||||||
|
_name = 'maintenance.equipment.oee.log.detail'
|
||||||
|
_description = '设备运行日志详情'
|
||||||
|
|
||||||
|
sequence = fields.Integer('序号')
|
||||||
|
time = fields.Datetime('时间')
|
||||||
|
state = fields.Selection([("加工", "加工"), ("关机", "关机"), ("待机", "待机"), ("故障", "故障"),
|
||||||
|
("检修", "检修"), ("保养", "保养")], default="", string="事件/状态")
|
||||||
|
production_id = fields.Many2one('mrp.production', '加工工单')
|
||||||
|
|
||||||
|
log_id = fields.Many2one('maintenance.equipment.oee.logs', '日志')
|
||||||
|
|
||||||
|
|||||||
@@ -67,3 +67,6 @@ access_sf_cutting_tool_type_admin_sf_group_equipment_user,sf_cutting_tool_type_a
|
|||||||
access_sf_cutting_tool_type_group_purchase_director_sf_group_equipment_user,sf_cutting_tool_type_group_purchase_director,sf_base.model_sf_cutting_tool_type,sf_maintenance.sf_group_equipment_user,1,0,0,0
|
access_sf_cutting_tool_type_group_purchase_director_sf_group_equipment_user,sf_cutting_tool_type_group_purchase_director,sf_base.model_sf_cutting_tool_type,sf_maintenance.sf_group_equipment_user,1,0,0,0
|
||||||
access_sf_cutting_tool_type_group_sale_director_sf_group_equipment_user,sf_cutting_tool_type_group_sale_director,sf_base.model_sf_cutting_tool_type,sf_maintenance.sf_group_equipment_user,1,0,0,0
|
access_sf_cutting_tool_type_group_sale_director_sf_group_equipment_user,sf_cutting_tool_type_group_sale_director,sf_base.model_sf_cutting_tool_type,sf_maintenance.sf_group_equipment_user,1,0,0,0
|
||||||
access_sf_cutting_tool_type_group_plan_director_sf_group_equipment_user,sf_cutting_tool_type_group_plan_director,sf_base.model_sf_cutting_tool_type,sf_maintenance.sf_group_equipment_user,1,0,0,0
|
access_sf_cutting_tool_type_group_plan_director_sf_group_equipment_user,sf_cutting_tool_type_group_plan_director,sf_base.model_sf_cutting_tool_type,sf_maintenance.sf_group_equipment_user,1,0,0,0
|
||||||
|
|
||||||
|
access_maintenance_equipment_oee_logs,maintenance_equipment_oee_logs,model_maintenance_equipment_oee_logs,sf_maintenance.sf_group_equipment_manager,1,1,1,0
|
||||||
|
access_maintenance_equipment_oee_log_detail,maintenance_equipment_oee_log_detail,model_maintenance_equipment_oee_log_detail,sf_maintenance.sf_group_equipment_manager,1,1,1,0
|
||||||
|
@@ -14,6 +14,7 @@
|
|||||||
<field name="utilization_rate"/>
|
<field name="utilization_rate"/>
|
||||||
<field name="fault_time"/>
|
<field name="fault_time"/>
|
||||||
<field name="fault_nums"/>
|
<field name="fault_nums"/>
|
||||||
|
<field name="fault_rate"/>
|
||||||
</tree>
|
</tree>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
@@ -49,19 +50,19 @@
|
|||||||
</group>
|
</group>
|
||||||
|
|
||||||
</group>
|
</group>
|
||||||
<notebook>
|
<!-- <notebook> -->
|
||||||
<page string="运行日志">
|
<!-- <page string="运行日志"> -->
|
||||||
<field name="oee_logs">
|
<!-- <field name="oee_logs"> -->
|
||||||
<tree create="1" edit="1" delete="1" editable="bottom">
|
<!-- <tree create="1" edit="1" delete="1" editable="bottom"> -->
|
||||||
<field name = 'run_time'/>
|
<!-- <field name = 'run_time'/> -->
|
||||||
<field name = 'state'/>
|
<!-- <field name = 'state'/> -->
|
||||||
<field name = 'workorder_id'/>
|
<!-- <field name = 'workorder_id'/> -->
|
||||||
<field name = 'time'/>
|
<!-- <field name = 'time'/> -->
|
||||||
<field name = 'color' widget="color"/>
|
<!-- <field name = 'color' widget="color"/> -->
|
||||||
</tree>
|
<!-- </tree> -->
|
||||||
</field>
|
<!-- </field> -->
|
||||||
</page>
|
<!-- </page> -->
|
||||||
</notebook>
|
<!-- </notebook> -->
|
||||||
</sheet>
|
</sheet>
|
||||||
</form>
|
</form>
|
||||||
</field>
|
</field>
|
||||||
|
|||||||
@@ -105,6 +105,233 @@
|
|||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
|
<!-- 设备运行日志 -->
|
||||||
|
<record id="view_maintenance_logs_run_tree" model="ir.ui.view">
|
||||||
|
<field name="name">maintenance.logs.run.tree</field>
|
||||||
|
<field name="model">maintenance.equipment.oee.logs</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<tree>
|
||||||
|
<field name="equipment_id"/>
|
||||||
|
</tree>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="view_maintenance_logs_run_form" model="ir.ui.view">
|
||||||
|
<field name="name">maintenance.logs.run.form</field>
|
||||||
|
<field name="model">maintenance.equipment.oee.logs</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<!-- <form string="设备运行日志"> -->
|
||||||
|
<!-- <header> -->
|
||||||
|
<!-- <field name="equipment_id" readonly="1"/> -->
|
||||||
|
<!-- </header> -->
|
||||||
|
<!-- <sheet> -->
|
||||||
|
<!-- <div class="oe_title"> -->
|
||||||
|
<!-- <h1> -->
|
||||||
|
<!-- <field name="start_time" readonly="1"/> -->
|
||||||
|
<!-- </h1> -->
|
||||||
|
<!-- </div> -->
|
||||||
|
<!-- <group> -->
|
||||||
|
<!-- <group> -->
|
||||||
|
<!-- <field name="stop_time" readonly="1"/> -->
|
||||||
|
<!-- <field name="duration" readonly="1"/> -->
|
||||||
|
<!-- <field name="oee" readonly="1"/> -->
|
||||||
|
<!-- </group> -->
|
||||||
|
<!-- <group> -->
|
||||||
|
<!-- <field name="note"/> -->
|
||||||
|
<!-- </group> -->
|
||||||
|
|
||||||
|
<!-- </group> -->
|
||||||
|
<!-- </sheet> -->
|
||||||
|
<!-- </form> -->
|
||||||
|
<form string="设备运行日志">
|
||||||
|
<!-- <header> -->
|
||||||
|
<!-- <field name="name" readonly="1"/> -->
|
||||||
|
<!-- </header> -->
|
||||||
|
<sheet>
|
||||||
|
<div class="oe_title">
|
||||||
|
<h1>
|
||||||
|
<field name="name"/>
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
|
<field name="type_id"/>
|
||||||
|
<field name="state"/>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
|
<!-- <field name="state" nolabel="1"/> -->
|
||||||
|
<field name="state" string=""/>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<field name="machine_tool_picture" widget="image" nolabel="1"/>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
|
<field name="online_time" readonly="1"/>
|
||||||
|
<field name="offline_time" readonly="1"/>
|
||||||
|
<field name="fault_rate" readonly="1"/>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<field name="offline_nums" readonly="1"/>
|
||||||
|
<field name="fault_time" readonly="1"/>
|
||||||
|
<field name="fault_nums" readonly="1"/>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
|
<field name="idle_time"/>
|
||||||
|
<field name="idle_rate"/>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<field name="work_time"/>
|
||||||
|
<field name="work_rate"/>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
|
||||||
|
</group>
|
||||||
|
<notebook>
|
||||||
|
<page string="日志详情">
|
||||||
|
<field name="detail_ids">
|
||||||
|
<tree>
|
||||||
|
<field name="sequence"/>
|
||||||
|
<field name="time"/>
|
||||||
|
<field name="state"/>
|
||||||
|
<field name="production_id"/>
|
||||||
|
</tree>
|
||||||
|
<!-- <form> -->
|
||||||
|
<!-- <field name="sequence"/> -->
|
||||||
|
<!-- <field name="time"/> -->
|
||||||
|
<!-- <field name="state"/> -->
|
||||||
|
<!-- <field name="production_id"/> -->
|
||||||
|
<!-- </form> -->
|
||||||
|
|
||||||
|
</field>
|
||||||
|
</page>
|
||||||
|
</notebook>
|
||||||
|
</sheet>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- <record id="view_maintenance_logs_run_search" model="ir.ui.view"> -->
|
||||||
|
<!-- <field name="name">maintenance.logs.run.search</field> -->
|
||||||
|
<!-- <field name="model">maintenance.equipment.oee.logs</field> -->
|
||||||
|
<!-- <field name="arch" type="xml"> -->
|
||||||
|
<!-- <search> -->
|
||||||
|
<!-- <field name="equipment_id"/> -->
|
||||||
|
<!-- <field name="start_time"/> -->
|
||||||
|
<!-- <field name="stop_time"/> -->
|
||||||
|
<!-- <field name="duration"/> -->
|
||||||
|
<!-- <field name="oee"/> -->
|
||||||
|
<!-- <field name="note"/> -->
|
||||||
|
<!-- </search> -->
|
||||||
|
|
||||||
|
<!-- </field> -->
|
||||||
|
<!-- </record> -->
|
||||||
|
|
||||||
|
<!-- 设备运行日志详情 -->
|
||||||
|
<record id="view_maintenance_logs_run_detail_tree" model="ir.ui.view">
|
||||||
|
<field name="name">maintenance.logs.run.detail.tree</field>
|
||||||
|
<field name="model">maintenance.equipment.oee.log.detail</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<tree>
|
||||||
|
<field name="sequence"/>
|
||||||
|
<field name="time"/>
|
||||||
|
<field name="state"/>
|
||||||
|
<field name="production_id"/>
|
||||||
|
</tree>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="view_maintenance_logs_run_detail_form" model="ir.ui.view">
|
||||||
|
<field name="name">maintenance.logs.run.detail.form</field>
|
||||||
|
<field name="model">maintenance.equipment.oee.log.detail</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<form string="设备运行日志详情">
|
||||||
|
<header>
|
||||||
|
<field name="sequence" readonly="1"/>
|
||||||
|
</header>
|
||||||
|
<sheet>
|
||||||
|
<div class="oe_title">
|
||||||
|
<h1>
|
||||||
|
<field name="time" readonly="1"/>
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
|
<field name="state" readonly="1"/>
|
||||||
|
<field name="production_id" readonly="1"/>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<field name="log_id"/>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
</sheet>
|
||||||
|
</form>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<!-- <record id="view_maintenance_logs_run_detail_search" model="ir.ui.view"> -->
|
||||||
|
<!-- <field name="name">maintenance.logs.run.detail.search</field> -->
|
||||||
|
<!-- <field name="model">maintenance.equipment.oee.logs.detail</field> -->
|
||||||
|
<!-- <field name="arch" type="xml"> -->
|
||||||
|
<!-- <search> -->
|
||||||
|
<!-- <field name="equipment_id"/> -->
|
||||||
|
<!-- <field name="start_time"/> -->
|
||||||
|
<!-- <field name="stop_time"/> -->
|
||||||
|
<!-- <field name="duration"/> -->
|
||||||
|
<!-- <field name="oee"/> -->
|
||||||
|
<!-- <field name="note"/> -->
|
||||||
|
<!-- </search> -->
|
||||||
|
<!-- </field> -->
|
||||||
|
<!-- </record> -->
|
||||||
|
|
||||||
|
<!-- 设备运行日志详情action -->
|
||||||
|
<!-- <record id="action_maintenance_logs_run_detail" model="ir.actions.act_window"> -->
|
||||||
|
<!-- <field name="name">设备运行日志详情</field> -->
|
||||||
|
<!-- <field name="type">ir.actions.act_window</field> -->
|
||||||
|
<!-- <field name="res_model">maintenance.equipment.oee.logs.detail</field> -->
|
||||||
|
<!-- <field name="view_mode">tree,form</field> -->
|
||||||
|
<!-- <field name="view_id" ref="view_maintenance_logs_run_detail_tree"/> -->
|
||||||
|
<!-- <field name="help" type="html"> -->
|
||||||
|
<!-- <p class="oe_view_nocontent_create"> -->
|
||||||
|
<!-- 设备运行日志详情 -->
|
||||||
|
<!-- </p> -->
|
||||||
|
<!-- </field> -->
|
||||||
|
<!-- -->
|
||||||
|
<!-- </record> -->
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<record id="action_maintenance_logs_run" model="ir.actions.act_window">
|
||||||
|
<field name="name">设备运行日志</field>
|
||||||
|
<field name="type">ir.actions.act_window</field>
|
||||||
|
<field name="res_model">maintenance.equipment.oee.logs</field>
|
||||||
|
<!-- <field name="search_view_id" ref="view_maintenance_logs_run_search"/> -->
|
||||||
|
<field name="view_mode">tree,form</field>
|
||||||
|
<!-- <field name="view_mode">form</field> -->
|
||||||
|
<field name="view_id" ref="view_maintenance_logs_run_tree"/>
|
||||||
|
<field name="help" type="html">
|
||||||
|
<p class="oe_view_nocontent_create">
|
||||||
|
设备运行日志
|
||||||
|
</p>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
|
||||||
|
<menuitem name="设备运行日志" id="menu_maintenance_logs_run" parent="maintenance.menu_m_request"
|
||||||
|
sequence="10" action="action_maintenance_logs_run"/>
|
||||||
|
|
||||||
|
|
||||||
<!-- Action -->
|
<!-- Action -->
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user