优化了工作日历时间输入,新增工作日历设置自动计算时长功能,修改了生产线模型的位置(移至sf_maintenance模块下),优化了部分的产线设备资源设置模型
This commit is contained in:
@@ -3,17 +3,36 @@ from odoo import models, fields
|
||||
|
||||
class ProcedureEquipmentResourceSetting(models.Model):
|
||||
_name = 'sf.procedure.equipment.resource.setting'
|
||||
_description = '工序设备资源设置'
|
||||
_description = '产线设备资源设置'
|
||||
|
||||
name = fields.Char(string='设备名称')
|
||||
machine_tool_name = fields.Char(string='机台号')
|
||||
def _get_code(self):
|
||||
"""
|
||||
自动生成编码
|
||||
:return:
|
||||
"""
|
||||
fixture_material = self.env['sf.procedure.equipment.resource.setting'].sudo().search(
|
||||
[('code', '!=', '')],
|
||||
limit=1,
|
||||
order="id desc")
|
||||
if not fixture_material:
|
||||
num = "%03d" % 1
|
||||
else:
|
||||
m = int(fixture_material.code) + 1
|
||||
num = "%03d" % m
|
||||
return num
|
||||
|
||||
code = fields.Char(string='序号', readonly=True, default=_get_code)
|
||||
work_center_name = fields.Char(string='工作中心名称')
|
||||
equipment_code = fields.Char(string='机台号')
|
||||
# todo 绑定设备
|
||||
# equipment_name = fields.Many2one('', string='设备名称')
|
||||
brand = fields.Char(string='品牌')
|
||||
model = fields.Char(string='型号')
|
||||
production_capacity = fields.Char(string='产能')
|
||||
working_calendar = fields.Many2one('sf.work.log.setting', string='工作日历')
|
||||
working_procedure = fields.Char(string='工序')
|
||||
production_capacity = fields.Char(string='产能', required=True)
|
||||
working_calendar_id = fields.Many2one('sf.work.log.setting', string='工作日历')
|
||||
working_shift = fields.Char(string='班次')
|
||||
create_time = fields.Datetime(string='新增时间', default=lambda self: fields.Datetime.now())
|
||||
stale_dated_time = fields.Datetime(string='过期时间')
|
||||
status = fields.Selection([('0', '正常'), ('1', '故障停机'), ('2', '计划停机')], string='设备状态', default='0')
|
||||
participate_in_scheduling = fields.Boolean(string='参与排程', default=True)
|
||||
|
||||
|
||||
@@ -18,54 +18,73 @@ class WorkLogSetting(models.Model):
|
||||
_name = 'sf.work.log.setting'
|
||||
_description = '工作日历设置'
|
||||
|
||||
name = fields.Char(string='工作日历名称')
|
||||
def _get_code(self):
|
||||
"""
|
||||
自动生成编码
|
||||
:return:
|
||||
"""
|
||||
fixture_material = self.env['sf.work.log.setting'].sudo().search(
|
||||
[('code', '!=', '')],
|
||||
limit=1,
|
||||
order="id desc")
|
||||
if not fixture_material:
|
||||
num = "%03d" % 1
|
||||
else:
|
||||
m = int(fixture_material.code) + 1
|
||||
num = "%03d" % m
|
||||
return num
|
||||
|
||||
start_time = fields.Char(string='日开始时间', default="00:00:00")
|
||||
start_time_H = fields.Selection(time_H_selection(), '时', default='00')
|
||||
start_time_M = fields.Selection(time_M_or_S_selection(), '分', default='00')
|
||||
start_time_S = fields.Selection(time_M_or_S_selection(), '秒', default='00')
|
||||
end_time = fields.Char(string='日结束时间', default="00:00:00")
|
||||
end_time_H = fields.Selection(time_H_selection(), '时', default='00')
|
||||
end_time_M = fields.Selection(time_M_or_S_selection(), '分', default='00')
|
||||
end_time_S = fields.Selection(time_M_or_S_selection(), '秒', default='00')
|
||||
code = fields.Char(string='序号', default=_get_code, readonly=True)
|
||||
name = fields.Char(string='工作日历名称', required=True)
|
||||
|
||||
duration = fields.Char(string='时长')
|
||||
day_off = fields.Char(string='休息日')
|
||||
start_time = fields.Char(string='日开始时间', readonly=True, compute='_compute_start_time')
|
||||
start_time_H = fields.Selection(time_H_selection(), '时', required=True)
|
||||
start_time_M = fields.Selection(time_M_or_S_selection(), '分', required=True)
|
||||
end_time = fields.Char(string='日结束时间', readonly=True, compute='_compute_end_time')
|
||||
end_time_H = fields.Selection(time_H_selection(), '时', required=True)
|
||||
end_time_M = fields.Selection(time_M_or_S_selection(), '分', required=True)
|
||||
|
||||
duration = fields.Char(string='时长', readonly=True, compute='_compute_duration')
|
||||
day_off = fields.Char(string='休息日', required=True)
|
||||
|
||||
user_defined_working_shift_status = fields.Boolean(string='自定义班次', default=False)
|
||||
working_shift = fields.Char(string='班次')
|
||||
working_shift_char = fields.Char(string='班次')
|
||||
working_shift_char = fields.Char(string='班次', readonly=True, compute='_compute_working_shift_time')
|
||||
working_shift_select = fields.Selection([('早班00:00-08:00', '早班00:00-08:00'),
|
||||
('白班08:00-16:00', '白班08:00-16:00'),
|
||||
('晚班16:00-24:00', '晚班16:00-24:00'),
|
||||
('长白班08:00-20:00', '长白班08:00-20:00'),
|
||||
('长晚班20:00-08:00', '长晚班20:00-08:00')], string='班次')
|
||||
working_shift_start_time_H = fields.Selection(time_H_selection(), '班次开始时间:时', default='00')
|
||||
working_shift_start_time_M = fields.Selection(time_M_or_S_selection(), '分', default='00')
|
||||
working_shift_start_time_S = fields.Selection(time_M_or_S_selection(), '秒', default='00')
|
||||
working_shift_end_time_H = fields.Selection(time_H_selection(), '班次结束时间:时', default='00')
|
||||
working_shift_end_time_M = fields.Selection(time_M_or_S_selection(), '分', default='00')
|
||||
working_shift_end_time_S = fields.Selection(time_M_or_S_selection(), '秒', default='00')
|
||||
working_shift_start_time_H = fields.Selection(time_H_selection(), '班次开始时间:时',
|
||||
attr={'required': [('user_defined_working_shift_status', '=', 'True')]})
|
||||
working_shift_start_time_M = fields.Selection(time_M_or_S_selection(), '分',
|
||||
attr={'required': [('user_defined_working_shift_status', '=', 'True')]})
|
||||
working_shift_end_time_H = fields.Selection(time_H_selection(), '班次结束时间:时',
|
||||
attr={'required': [('user_defined_working_shift_status', '=', 'True')]})
|
||||
working_shift_end_time_M = fields.Selection(time_M_or_S_selection(), '分',
|
||||
attr={'required': [('user_defined_working_shift_status', '=', 'True')]})
|
||||
|
||||
status = fields.Boolean(string='状态', default=True)
|
||||
update_person = fields.Char(string='更新人', default=lambda self: self.env.user.name)
|
||||
update_time = fields.Datetime(string='更新时间', default=lambda self: fields.Datetime.now())
|
||||
|
||||
@api.onchange('start_time_H', 'start_time_M', 'start_time_S')
|
||||
def _onchange_start_time(self):
|
||||
@api.depends('start_time_H', 'start_time_M')
|
||||
def _compute_start_time(self):
|
||||
"""
|
||||
设置输入日开始时间
|
||||
:return:
|
||||
"""
|
||||
self.start_time = f"{self.start_time_H}:{self.start_time_M}:{self.start_time_S}"
|
||||
for record in self:
|
||||
record.start_time = f"{record.start_time_H}:{record.start_time_M}:00"
|
||||
|
||||
@api.onchange('end_time_H', 'end_time_M', 'end_time_S')
|
||||
def _onchange_end_time(self):
|
||||
@api.depends('end_time_H', 'end_time_M')
|
||||
def _compute_end_time(self):
|
||||
"""
|
||||
设置输入日结束时间
|
||||
:return:
|
||||
"""
|
||||
self.end_time = f"{self.end_time_H}:{self.end_time_M}:{self.end_time_S}"
|
||||
for record in self:
|
||||
record.end_time = f"{record.end_time_H}:{record.end_time_M}:00"
|
||||
|
||||
@api.onchange('working_shift_char', 'working_shift_select')
|
||||
def _onchange_working_shift(self):
|
||||
@@ -79,22 +98,27 @@ class WorkLogSetting(models.Model):
|
||||
else:
|
||||
record.working_shift = record.working_shift_char
|
||||
|
||||
@api.onchange('working_shift_start_time_H',
|
||||
'working_shift_start_time_M',
|
||||
'working_shift_start_time_S',
|
||||
'working_shift_end_time_H',
|
||||
'working_shift_end_time_M',
|
||||
'working_shift_end_time_S')
|
||||
def _onchange_working_shift_time(self):
|
||||
start_time = f"{self.working_shift_start_time_H}:{self.working_shift_start_time_M}:{self.working_shift_start_time_S}"
|
||||
end_time = f"{self.working_shift_end_time_H}:{self.working_shift_end_time_M}:{self.working_shift_end_time_S}"
|
||||
@api.depends(
|
||||
'working_shift_start_time_H', 'working_shift_start_time_M',
|
||||
'working_shift_end_time_H', 'working_shift_end_time_M')
|
||||
def _compute_working_shift_time(self):
|
||||
start_time = f"{self.working_shift_start_time_H}:{self.working_shift_start_time_M}:00"
|
||||
end_time = f"{self.working_shift_end_time_H}:{self.working_shift_end_time_M}:00"
|
||||
self.working_shift_char = f"自定义班次{start_time}-{end_time}"
|
||||
|
||||
@api.onchange('start_time', 'end_time')
|
||||
def _onchange_duration(self):
|
||||
@api.depends('start_time_H', 'start_time_M', 'end_time_H', 'end_time_M')
|
||||
def _compute_duration(self):
|
||||
"""
|
||||
根据日开始时间和日结束时间计算每日工作时长
|
||||
:return:
|
||||
"""
|
||||
|
||||
|
||||
for record in self:
|
||||
st_h = float(record.start_time_H)
|
||||
st_m = float(record.start_time_M)
|
||||
end_h = float(record.end_time_H)
|
||||
end_m = float(record.end_time_M)
|
||||
# 日开始时间小于日结束时间
|
||||
if st_h < end_h:
|
||||
record.duration = str(round(end_h-st_h+(end_m-st_m)/60, 2))
|
||||
else:
|
||||
record.duration = str(round(end_h-st_h+(end_m-st_m)/60+24, 2))
|
||||
|
||||
Reference in New Issue
Block a user