From 123adcfc76c5220923d0a53ae126992ae5d8369e Mon Sep 17 00:00:00 2001 From: yuxianghui <1608204036@qq.com> Date: Thu, 6 Jul 2023 17:38:08 +0800 Subject: [PATCH] =?UTF-8?q?=E5=9C=A8sf=5Fbase=E4=B8=8B=E6=96=B0=E5=A2=9E?= =?UTF-8?q?=E7=94=9F=E4=BA=A7=E7=BA=BF=E6=A8=A1=E5=9E=8B=EF=BC=8C=E4=BC=98?= =?UTF-8?q?=E5=8C=96=E4=BA=86=E8=AE=A1=E5=88=92=E7=AE=A1=E7=90=86-?= =?UTF-8?q?=E5=B7=A5=E4=BD=9C=E6=97=A5=E5=8E=86=E8=AE=BE=E7=BD=AE=E7=9A=84?= =?UTF-8?q?=E6=89=8B=E5=8A=A8=E8=BE=93=E5=85=A5=E6=97=B6=E9=97=B4=E5=92=8C?= =?UTF-8?q?=E6=89=8B=E5=8A=A8=E8=BE=93=E5=85=A5=E7=8F=AD=E6=AC=A1=E7=9A=84?= =?UTF-8?q?=E6=A0=BC=E5=BC=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sf_base/__manifest__.py | 1 + sf_base/models/__init__.py | 1 + sf_base/models/production_line_base.py | 30 +++++++ sf_base/security/ir.model.access.csv | 3 + sf_base/views/menu_view.xml | 7 ++ sf_base/views/production_line_view.xml | 75 ++++++++++++++++ sf_plan_management/__manifest__.py | 3 +- sf_plan_management/models/base.py | 18 ---- sf_plan_management/models/calendar_base.py | 90 ++++++++++++++----- .../security/ir.model.access.csv | 2 - sf_plan_management/views/paln_base_view.xml | 67 ++++++++++---- 11 files changed, 241 insertions(+), 56 deletions(-) create mode 100644 sf_base/models/production_line_base.py create mode 100644 sf_base/views/production_line_view.xml diff --git a/sf_base/__manifest__.py b/sf_base/__manifest__.py index d6f8a88a..41de851f 100644 --- a/sf_base/__manifest__.py +++ b/sf_base/__manifest__.py @@ -18,6 +18,7 @@ 'views/common_view.xml', 'views/fixture_view.xml', 'views/functional_fixture_view.xml', + 'views/production_line_view.xml', 'views/menu_view.xml', "views/tool_views.xml", "views/tool_menu.xml", diff --git a/sf_base/models/__init__.py b/sf_base/models/__init__.py index cc906ab8..12823af1 100644 --- a/sf_base/models/__init__.py +++ b/sf_base/models/__init__.py @@ -3,6 +3,7 @@ from . import common from . import tool_base_new from . import fixture from . import functional_fixture +from . import production_line_base diff --git a/sf_base/models/production_line_base.py b/sf_base/models/production_line_base.py new file mode 100644 index 00000000..9dfeabe2 --- /dev/null +++ b/sf_base/models/production_line_base.py @@ -0,0 +1,30 @@ +from odoo import models,fields,api + + +class ProductionLine(models.Model): + _name = 'sf.production.line' + _description = '生产线' + + def _get_code(self): + """ + 自动生成编码 + :return: + """ + fixture_material = self.env['sf.production.line'].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 + + name = fields.Char('生产线') + code = fields.Char('编码', default=_get_code, readonly=True) + remark = fields.Char('备注') + + + + diff --git a/sf_base/security/ir.model.access.csv b/sf_base/security/ir.model.access.csv index 175e4589..7b3ef980 100644 --- a/sf_base/security/ir.model.access.csv +++ b/sf_base/security/ir.model.access.csv @@ -30,4 +30,7 @@ access_sf_functional_fixture_type,sf_functional_fixture_type,model_sf_functional access_sf_functional_fixture,sf_functional_fixture,model_sf_functional_fixture,base.group_user,1,1,1,1 +access_sf_production_line,sf.production.line,model_sf_production_line,base.group_user,1,1,1,1 + + diff --git a/sf_base/views/menu_view.xml b/sf_base/views/menu_view.xml index cd32e960..9f250a87 100644 --- a/sf_base/views/menu_view.xml +++ b/sf_base/views/menu_view.xml @@ -143,5 +143,12 @@ sequence="1" action="action_sf_machine_control_system"/> + + \ No newline at end of file diff --git a/sf_base/views/production_line_view.xml b/sf_base/views/production_line_view.xml new file mode 100644 index 00000000..17de359d --- /dev/null +++ b/sf_base/views/production_line_view.xml @@ -0,0 +1,75 @@ + + + + 生产线 + sf.production.line + + + + + + + + + + + 生产线 + sf.production.line + +
+ + + + + + + + + + + +
+
+
+ + + 生产线 + sf.production.line + + + + + + + + + 生产线看板 + sf.production.line + + + + + +
+ +
+ +
+ +
+ +
+
+
+
+ +
+
+
+ + + 生产线 + sf.production.line + kanban,tree,form + +
\ No newline at end of file diff --git a/sf_plan_management/__manifest__.py b/sf_plan_management/__manifest__.py index 9a8af0cd..5f82e7b4 100644 --- a/sf_plan_management/__manifest__.py +++ b/sf_plan_management/__manifest__.py @@ -13,8 +13,9 @@ 'depends': [], 'data': [ 'security/ir.model.access.csv', + # 'security/ir.model.access.csv', 'views/paln_base_view.xml', - 'views/menu_view.xml' + 'views/menu_view.xml', ], 'demo': [ ], diff --git a/sf_plan_management/models/base.py b/sf_plan_management/models/base.py index 76b1c0fc..57fcfb59 100644 --- a/sf_plan_management/models/base.py +++ b/sf_plan_management/models/base.py @@ -1,28 +1,10 @@ from odoo import models, fields -class ProductionLine(models.Model): - _name = 'sf.production.line' - _description = '生产线' - - name = fields.Char(string='生产线名称') - - -class WorkingProcedure(models.Model): - _name = 'sf.working.procedure' - _description = '工序' - - name = fields.Char(string='工序名称') - content = fields.Char(string='主要加工内容') - - WorkingProcedure_to_ProductionLine_id = fields.Many2one('sf.production.line') - - class ProcedureEquipmentResourceSetting(models.Model): _name = 'sf.procedure.equipment.resource.setting' _description = '工序设备资源设置' - equipment_to_working_procedure_id = fields.Many2one('sf.working.procedure', string='工序') name = fields.Char(string='设备名称') machine_tool_name = fields.Char(string='机台号') brand = fields.Char(string='品牌') diff --git a/sf_plan_management/models/calendar_base.py b/sf_plan_management/models/calendar_base.py index dc22b92f..ad48a7b2 100644 --- a/sf_plan_management/models/calendar_base.py +++ b/sf_plan_management/models/calendar_base.py @@ -2,49 +2,99 @@ from odoo import models, fields, api import re +def time_H_selection(): + return [('00', '00'), ('01', '01'), ('02', '02'), ('03', '03'), ('04', '04'), ('05', '05'), + ('06', '06'), ('07', '07'), ('08', '08'), ('09', '09'), ('10', '10'), ('11', '11'), + ('12', '12'), ('13', '13'), ('14', '14'), ('15', '15'), ('16', '16'), ('17', '17'), + ('18', '18'), ('19', '19'), ('20', '20'), ('21', '21'), ('22', '22'), ('23', '23')] + + +def time_M_or_S_selection(): + return [('00', '00'), ('05', '05'), ('10', '10'), ('15', '15'), ('20', '20'), ('25', '25'), + ('30', '30'), ('35', '35'), ('40', '40'), ('45', '45'), ('50', '50'), ('55', '55')] + + class WorkLogSetting(models.Model): _name = 'sf.work.log.setting' _description = '工作日历设置' name = fields.Char(string='工作日历名称') - # start_time = fields.Char(string='日开始时间') - start_time = fields.Datetime(string='日开始时间') - end_time = fields.Char(string='日结束时间') + + 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') + duration = fields.Char(string='时长') day_off = fields.Char(string='休息日') user_defined_working_shift_status = fields.Boolean(string='自定义班次', default=False) working_shift = fields.Char(string='班次') working_shift_char = fields.Char(string='班次') - working_shift_select = fields.Selection([('0', '早班00:00-08:00'), - ('1', '白班08:00-16:00'), - ('2', '晚班16:00-24:00'), - ('3', '长白班08:00-20:00'), - ('4', '长晚班20:00-08:00')], string='班次') + 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') 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): + """ + 设置输入日开始时间 + :return: + """ + self.start_time = f"{self.start_time_H}:{self.start_time_M}:{self.start_time_S}" + + @api.onchange('end_time_H', 'end_time_M', 'end_time_S') + def _onchange_end_time(self): + """ + 设置输入日结束时间 + :return: + """ + self.end_time = f"{self.end_time_H}:{self.end_time_M}:{self.end_time_S}" + @api.onchange('working_shift_char', 'working_shift_select') def _onchange_working_shift(self): + """ + 对班次是否手动输入是进行不同的展示 + :return: + """ for record in self: if record.working_shift_select: record.working_shift = record.working_shift_select else: record.working_shift = record.working_shift_char - # @api.onchange('start_time') - # def _onchange_start_time(self): - # pattern = re.compile(r'^(([0-9]|1[0-9]|2[0-3]):[0-5][0-9])|24:00$') - # if self.start_time and not pattern.match(self.start_time): - # raise models.ValidationError('输入的日开始时间不正确,请重新输入!') - - @api.onchange('end_time') - def _onchange_end_time(self): - pattern = re.compile(r'^(([0-9]|1[0-9]|2[0-3]):[0-5][0-9])|24:00$') - for record in self: - if record.end_time and not pattern.match(record.end_time): - raise models.ValidationError('输入的日结束时间不正确,请重新输入!') + @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}" + self.working_shift_char = f"自定义班次{start_time}-{end_time}" + @api.onchange('start_time', 'end_time') + def _onchange_duration(self): + """ + 根据日开始时间和日结束时间计算每日工作时长 + :return: + """ + diff --git a/sf_plan_management/security/ir.model.access.csv b/sf_plan_management/security/ir.model.access.csv index 1103d658..98cf2ae7 100644 --- a/sf_plan_management/security/ir.model.access.csv +++ b/sf_plan_management/security/ir.model.access.csv @@ -1,7 +1,5 @@ id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink access_sf_work_log_setting,sf.work.log.setting,model_sf_work_log_setting,base.group_user,1,1,1,1 -access_sf_production_line,sf.production.line,model_sf_production_line,base.group_user,1,1,1,1 -access_sf_working_procedure,sf.working.procedure,model_sf_working_procedure,base.group_user,1,1,1,1 access_sf_procedure_equipment_resource_setting,sf.procedure.equipment.resource.setting,model_sf_procedure_equipment_resource_setting,base.group_user,1,1,1,1 diff --git a/sf_plan_management/views/paln_base_view.xml b/sf_plan_management/views/paln_base_view.xml index b8b63cb3..f33057bd 100644 --- a/sf_plan_management/views/paln_base_view.xml +++ b/sf_plan_management/views/paln_base_view.xml @@ -29,23 +29,60 @@ + + + + + + - - + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + - @@ -85,19 +122,19 @@ - - - - - - - - - + + 工序设备资源设置 + sf.procedure.equipment.resource.setting + + + + + + 工序设备资源设置 sf.procedure.equipment.resource.setting - tree,form + tree,form,search \ No newline at end of file