在sf_base下新增生产线模型,优化了计划管理-工作日历设置的手动输入时间和手动输入班次的格式
This commit is contained in:
@@ -18,6 +18,7 @@
|
|||||||
'views/common_view.xml',
|
'views/common_view.xml',
|
||||||
'views/fixture_view.xml',
|
'views/fixture_view.xml',
|
||||||
'views/functional_fixture_view.xml',
|
'views/functional_fixture_view.xml',
|
||||||
|
'views/production_line_view.xml',
|
||||||
'views/menu_view.xml',
|
'views/menu_view.xml',
|
||||||
"views/tool_views.xml",
|
"views/tool_views.xml",
|
||||||
"views/tool_menu.xml",
|
"views/tool_menu.xml",
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ from . import common
|
|||||||
from . import tool_base_new
|
from . import tool_base_new
|
||||||
from . import fixture
|
from . import fixture
|
||||||
from . import functional_fixture
|
from . import functional_fixture
|
||||||
|
from . import production_line_base
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
30
sf_base/models/production_line_base.py
Normal file
30
sf_base/models/production_line_base.py
Normal file
@@ -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('备注')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -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_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
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
|
@@ -143,5 +143,12 @@
|
|||||||
sequence="1"
|
sequence="1"
|
||||||
action="action_sf_machine_control_system"/>
|
action="action_sf_machine_control_system"/>
|
||||||
|
|
||||||
|
<menuitem
|
||||||
|
id="menu_sf_production_line"
|
||||||
|
parent="menu_sf_base"
|
||||||
|
name="生产线"
|
||||||
|
sequence="20"
|
||||||
|
action="sf_production_line_act"/>
|
||||||
|
|
||||||
</data>
|
</data>
|
||||||
</odoo>
|
</odoo>
|
||||||
75
sf_base/views/production_line_view.xml
Normal file
75
sf_base/views/production_line_view.xml
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<odoo>
|
||||||
|
<record id="sf_production_line_tree" model="ir.ui.view">
|
||||||
|
<field name="name">生产线</field>
|
||||||
|
<field name="model">sf.production.line</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<tree string="生产线">
|
||||||
|
<field name="name"/>
|
||||||
|
<field name="code"/>
|
||||||
|
<field name="remark"/>
|
||||||
|
</tree>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="sf_production_line_form" model="ir.ui.view">
|
||||||
|
<field name="name">生产线</field>
|
||||||
|
<field name="model">sf.production.line</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<form string="生产线">
|
||||||
|
<sheet>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
|
<field name="name"/>
|
||||||
|
<field name="remark"/>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<field name="code"/>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
</sheet>
|
||||||
|
</form>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="sf_production_line_search" model="ir.ui.view">
|
||||||
|
<field name="name">生产线</field>
|
||||||
|
<field name="model">sf.production.line</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<search>
|
||||||
|
<field name="name"/>
|
||||||
|
</search>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="sf_production_line_kanban" model="ir.ui.view">
|
||||||
|
<field name="name">生产线看板</field>
|
||||||
|
<field name="model">sf.production.line</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<kanban>
|
||||||
|
<field name="name"/>
|
||||||
|
<templates>
|
||||||
|
<t t-name="kanban-box">
|
||||||
|
<div class="oe_kanban_global_click">
|
||||||
|
<!-- 在这里定义每个卡片的内容 -->
|
||||||
|
<div>
|
||||||
|
<strong><field name="code"/></strong>
|
||||||
|
<br/>
|
||||||
|
<span><field name="name"/></span>
|
||||||
|
<br/>
|
||||||
|
<span><field name="remark"/></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</t>
|
||||||
|
</templates>
|
||||||
|
|
||||||
|
</kanban>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
<record id="sf_production_line_act" model="ir.actions.act_window">
|
||||||
|
<field name="name">生产线</field>
|
||||||
|
<field name="res_model">sf.production.line</field>
|
||||||
|
<field name="view_mode">kanban,tree,form</field>
|
||||||
|
</record>
|
||||||
|
</odoo>
|
||||||
@@ -13,8 +13,9 @@
|
|||||||
'depends': [],
|
'depends': [],
|
||||||
'data': [
|
'data': [
|
||||||
'security/ir.model.access.csv',
|
'security/ir.model.access.csv',
|
||||||
|
# 'security/ir.model.access.csv',
|
||||||
'views/paln_base_view.xml',
|
'views/paln_base_view.xml',
|
||||||
'views/menu_view.xml'
|
'views/menu_view.xml',
|
||||||
],
|
],
|
||||||
'demo': [
|
'demo': [
|
||||||
],
|
],
|
||||||
|
|||||||
@@ -1,28 +1,10 @@
|
|||||||
from odoo import models, fields
|
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):
|
class ProcedureEquipmentResourceSetting(models.Model):
|
||||||
_name = 'sf.procedure.equipment.resource.setting'
|
_name = 'sf.procedure.equipment.resource.setting'
|
||||||
_description = '工序设备资源设置'
|
_description = '工序设备资源设置'
|
||||||
|
|
||||||
equipment_to_working_procedure_id = fields.Many2one('sf.working.procedure', string='工序')
|
|
||||||
name = fields.Char(string='设备名称')
|
name = fields.Char(string='设备名称')
|
||||||
machine_tool_name = fields.Char(string='机台号')
|
machine_tool_name = fields.Char(string='机台号')
|
||||||
brand = fields.Char(string='品牌')
|
brand = fields.Char(string='品牌')
|
||||||
|
|||||||
@@ -2,49 +2,99 @@ from odoo import models, fields, api
|
|||||||
import re
|
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):
|
class WorkLogSetting(models.Model):
|
||||||
_name = 'sf.work.log.setting'
|
_name = 'sf.work.log.setting'
|
||||||
_description = '工作日历设置'
|
_description = '工作日历设置'
|
||||||
|
|
||||||
name = fields.Char(string='工作日历名称')
|
name = fields.Char(string='工作日历名称')
|
||||||
# start_time = fields.Char(string='日开始时间')
|
|
||||||
start_time = fields.Datetime(string='日开始时间')
|
start_time = fields.Char(string='日开始时间', default="00:00:00")
|
||||||
end_time = fields.Char(string='日结束时间')
|
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='时长')
|
duration = fields.Char(string='时长')
|
||||||
day_off = fields.Char(string='休息日')
|
day_off = fields.Char(string='休息日')
|
||||||
|
|
||||||
user_defined_working_shift_status = fields.Boolean(string='自定义班次', default=False)
|
user_defined_working_shift_status = fields.Boolean(string='自定义班次', default=False)
|
||||||
working_shift = fields.Char(string='班次')
|
working_shift = fields.Char(string='班次')
|
||||||
working_shift_char = fields.Char(string='班次')
|
working_shift_char = fields.Char(string='班次')
|
||||||
working_shift_select = fields.Selection([('0', '早班00:00-08:00'),
|
working_shift_select = fields.Selection([('早班00:00-08:00', '早班00:00-08:00'),
|
||||||
('1', '白班08:00-16:00'),
|
('白班08:00-16:00', '白班08:00-16:00'),
|
||||||
('2', '晚班16:00-24:00'),
|
('晚班16:00-24:00', '晚班16:00-24:00'),
|
||||||
('3', '长白班08:00-20:00'),
|
('长白班08:00-20:00', '长白班08:00-20:00'),
|
||||||
('4', '长晚班20:00-08:00')], string='班次')
|
('长晚班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)
|
status = fields.Boolean(string='状态', default=True)
|
||||||
update_person = fields.Char(string='更新人', default=lambda self: self.env.user.name)
|
update_person = fields.Char(string='更新人', default=lambda self: self.env.user.name)
|
||||||
update_time = fields.Datetime(string='更新时间', default=lambda self: fields.Datetime.now())
|
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')
|
@api.onchange('working_shift_char', 'working_shift_select')
|
||||||
def _onchange_working_shift(self):
|
def _onchange_working_shift(self):
|
||||||
|
"""
|
||||||
|
对班次是否手动输入是进行不同的展示
|
||||||
|
:return:
|
||||||
|
"""
|
||||||
for record in self:
|
for record in self:
|
||||||
if record.working_shift_select:
|
if record.working_shift_select:
|
||||||
record.working_shift = record.working_shift_select
|
record.working_shift = record.working_shift_select
|
||||||
else:
|
else:
|
||||||
record.working_shift = record.working_shift_char
|
record.working_shift = record.working_shift_char
|
||||||
|
|
||||||
# @api.onchange('start_time')
|
@api.onchange('working_shift_start_time_H',
|
||||||
# def _onchange_start_time(self):
|
'working_shift_start_time_M',
|
||||||
# pattern = re.compile(r'^(([0-9]|1[0-9]|2[0-3]):[0-5][0-9])|24:00$')
|
'working_shift_start_time_S',
|
||||||
# if self.start_time and not pattern.match(self.start_time):
|
'working_shift_end_time_H',
|
||||||
# raise models.ValidationError('输入的日开始时间不正确,请重新输入!')
|
'working_shift_end_time_M',
|
||||||
|
'working_shift_end_time_S')
|
||||||
@api.onchange('end_time')
|
def _onchange_working_shift_time(self):
|
||||||
def _onchange_end_time(self):
|
start_time = f"{self.working_shift_start_time_H}:{self.working_shift_start_time_M}:{self.working_shift_start_time_S}"
|
||||||
pattern = re.compile(r'^(([0-9]|1[0-9]|2[0-3]):[0-5][0-9])|24:00$')
|
end_time = f"{self.working_shift_end_time_H}:{self.working_shift_end_time_M}:{self.working_shift_end_time_S}"
|
||||||
for record in self:
|
self.working_shift_char = f"自定义班次{start_time}-{end_time}"
|
||||||
if record.end_time and not pattern.match(record.end_time):
|
|
||||||
raise models.ValidationError('输入的日结束时间不正确,请重新输入!')
|
|
||||||
|
|
||||||
|
@api.onchange('start_time', 'end_time')
|
||||||
|
def _onchange_duration(self):
|
||||||
|
"""
|
||||||
|
根据日开始时间和日结束时间计算每日工作时长
|
||||||
|
:return:
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,5 @@
|
|||||||
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
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_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
|
access_sf_procedure_equipment_resource_setting,sf.procedure.equipment.resource.setting,model_sf_procedure_equipment_resource_setting,base.group_user,1,1,1,1
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
|
@@ -29,23 +29,60 @@
|
|||||||
<field name="name"/>
|
<field name="name"/>
|
||||||
</group>
|
</group>
|
||||||
<group string="选择班次">
|
<group string="选择班次">
|
||||||
|
<group>
|
||||||
|
<field name="working_shift_char" attrs="{'invisible': [('user_defined_working_shift_status', '=', False)]}"/>
|
||||||
|
<field name="working_shift_select" attrs="{'invisible': [('user_defined_working_shift_status', '!=', False)]}"/>
|
||||||
|
</group>
|
||||||
<group>
|
<group>
|
||||||
<field name="user_defined_working_shift_status"/>
|
<field name="user_defined_working_shift_status"/>
|
||||||
<field name="working_shift" invisible="True"/>
|
<field name="working_shift" invisible="True"/>
|
||||||
</group>
|
</group>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
<group>
|
<group>
|
||||||
<field name="working_shift_char" attrs="{'invisible': [('user_defined_working_shift_status', '=', False)]}"/>
|
<group>
|
||||||
<field name="working_shift_select" attrs="{'invisible': [('user_defined_working_shift_status', '!=', False)]}"/>
|
<field name="working_shift_start_time_H" attrs="{'invisible': [('user_defined_working_shift_status', '=', False)]}"/>
|
||||||
|
<field name="working_shift_end_time_H" attrs="{'invisible': [('user_defined_working_shift_status', '=', False)]}"/>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<field name="working_shift_start_time_M" attrs="{'invisible': [('user_defined_working_shift_status', '=', False)]}"/>
|
||||||
|
<field name="working_shift_end_time_M" attrs="{'invisible': [('user_defined_working_shift_status', '=', False)]}"/>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
|
<field name="working_shift_start_time_S" attrs="{'invisible': [('user_defined_working_shift_status', '=', False)]}"/>
|
||||||
|
<field name="working_shift_end_time_S" attrs="{'invisible': [('user_defined_working_shift_status', '=', False)]}"/>
|
||||||
|
</group>
|
||||||
</group>
|
</group>
|
||||||
</group>
|
</group>
|
||||||
<group string="工作时间">
|
<group string="工作时间">
|
||||||
<group>
|
<group>
|
||||||
<!-- <field name="start_time" widget="char" placeholder="请输入的时间为:00:00-24:00"/>-->
|
<group>
|
||||||
<field name="start_time" options="{'no_date': True, 'format': 'HH:mm:ss'}"/>
|
<field name="start_time"/>
|
||||||
|
<field name="end_time" readonly="False"/>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<field name="start_time_H"/>
|
||||||
|
<field name="end_time_H"/>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
|
<field name="start_time_M"/>
|
||||||
|
<field name="end_time_M"/>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<field name="start_time_S"/>
|
||||||
|
<field name="end_time_S"/>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
<group>
|
||||||
|
<group>
|
||||||
<field name="duration"/>
|
<field name="duration"/>
|
||||||
</group>
|
</group>
|
||||||
<group>
|
<group>
|
||||||
<field name="end_time" widget="char" placeholder="请输入的时间为:00:00-24:00"/>
|
|
||||||
<field name="day_off"/>
|
<field name="day_off"/>
|
||||||
</group>
|
</group>
|
||||||
</group>
|
</group>
|
||||||
@@ -85,19 +122,19 @@
|
|||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<!-- <record id="sf_procedure_equipment_resource_setting_form" model="ir.ui.view">-->
|
<record id="sf_procedure_equipment_resource_setting_search" model="ir.ui.view">
|
||||||
<!-- <field name="name">工序设备资源设置</field>-->
|
<field name="name">工序设备资源设置</field>
|
||||||
<!-- <field name="model">sf.procedure.equipment.resource.setting</field>-->
|
<field name="model">sf.procedure.equipment.resource.setting</field>
|
||||||
<!-- <field name="arch" type="xml">-->
|
<field name="arch" type="xml">
|
||||||
<!-- <form>-->
|
<search>
|
||||||
|
<field name="name"/>
|
||||||
<!-- </form>-->
|
</search>
|
||||||
<!-- </field>-->
|
</field>
|
||||||
<!-- </record>-->
|
</record>
|
||||||
|
|
||||||
<record id="sf_procedure_equipment_resource_setting_act" model="ir.actions.act_window">
|
<record id="sf_procedure_equipment_resource_setting_act" model="ir.actions.act_window">
|
||||||
<field name="name">工序设备资源设置</field>
|
<field name="name">工序设备资源设置</field>
|
||||||
<field name="res_model">sf.procedure.equipment.resource.setting</field>
|
<field name="res_model">sf.procedure.equipment.resource.setting</field>
|
||||||
<field name="view_mode">tree,form</field>
|
<field name="view_mode">tree,form,search</field>
|
||||||
</record>
|
</record>
|
||||||
</odoo>
|
</odoo>
|
||||||
Reference in New Issue
Block a user