新增根据工作日历设置的工作日字段创建工作日历的记录

This commit is contained in:
yuxianghui
2023-07-11 17:40:14 +08:00
parent 6dfced8541
commit ef7d9c22d4
2 changed files with 68 additions and 23 deletions

View File

@@ -1,3 +1,5 @@
from datetime import datetime, timedelta
from odoo import models, fields, api
import re
@@ -88,16 +90,49 @@ class WorkLogSetting(models.Model):
else:
record.duration = str(round(end_h - st_h + (end_m - st_m) / 60 + 24, 2))
# @api.model
# def create(self, vals_list):
# """
# 创建新工作日历设置记录时,同时根据所选的休息日新建工作日历的休息日记录
# :param vals_list:
# :return:
# """
#
#
# return super(WorkLogSetting, self).create(vals_list)
@api.onchange('day_off_id')
def _onchange_day_off_id(self):
# 先删除之前创建的工作日历事件记录
self.env['sf.work.schedule.calendar'].search([
('calendar_code', '=', self.code), ('name_id', '=', self.name)]).unlink()
# 获取当年的一月一号的日期
year = fields.Datetime.now().year # 2023
first_day = datetime(year, 1, 1).date() # 2023-01-01
day_of_week = first_day.strftime("%A") # 星期日
# 根据day_of_week将其设置为起始0循环周一到周日按循环顺序设置为0-6
# 列:{'星期日': 0, '星期一': 1, '星期二': 2, '星期三': 3, '星期四': 4, '星期五': 5, '星期六': 6}
desc = {}
desc_weekdays = ['星期一', '星期二', '星期三', '星期四', '星期五', '星期六', '星期日']
status = False
ints = 0
while len(desc) < 7:
if len(desc) != 0:
for week in desc_weekdays:
if len(desc) < 7:
desc.update({week: ints})
ints += 1
else:
for week in desc_weekdays:
if status:
desc.update({week: ints})
ints += 1
if day_of_week == week:
desc.update({week: ints})
status = True
ints += 1
# 创建工作日历的休息日事件
# day_off_ids = self.day_off_id.mapped('name')
# for week in day_off_ids:
# num = desc[week]
# while num <= 30:
# target_date = first_day + timedelta(days=num)
# self.env['sf.work.schedule.calendar'].create({'name': '休息日',
# 'name_id': self.name.id,
# 'date_time': target_date})
# num += 7
class WorkingShift(models.Model):
@@ -132,20 +167,24 @@ class DayOff(models.Model):
_description = '休息日'
name = fields.Selection([
('', ''),
('', ''),
('', ''),
('', ''),
('', ''),
('', ''),
('', '')], '休息日名称')
('星期', '星期'),
('星期', '星期'),
('星期', '星期'),
('星期', '星期'),
('星期', '星期'),
('星期', '星期'),
('星期', '星期')], '休息日名称')
class WorkScheduleCalendar(models.Model):
_name = 'sf.work.schedule.calendar'
_description = '工作安排日历'
_description = '工作日历'
name = fields.Selection([('休息日', '休息日'), ('计划停机', '计划停机')], '日历事件名称')
date_time = fields.Date('休息时间')
name_id = fields.Many2one('sf.work.log.setting', '工作日历名称')
calendar_code = fields.Char('工作日历编码')
day_off_id = fields.Many2many('sf.day.off', string='休息日')
scheduled_outage = fields.Char('计划停机')
monthly_rest_days = fields.Char('月休息天数', readonly=True)
@@ -153,6 +192,10 @@ class WorkScheduleCalendar(models.Model):
monthly_planned_downtime = fields.Char('月计划停机时长', readonly=True)
annual_planned_downtime = fields.Char('年计划停机时长', readonly=True)
name = fields.Selection([('休息日', '休息日'),('计划停机', '计划停机')], '名称')
date_time = fields.Datetime('休息时间')
@api.onchange('name_id')
def _onchange_name_id(self):
for record in self:
record.calendar_code = record.name_id.code