Browse Source

[IMP] b_shift : attendance sheets code cleaning

pull/143/head
Elouan Le Bars 5 years ago
parent
commit
87b38ef134
  1. 39
      beesdoo_shift/models/attendance_sheet.py
  2. 5
      beesdoo_shift/wizard/validate_attendance_sheet.py

39
beesdoo_shift/models/attendance_sheet.py

@ -30,10 +30,7 @@ class AttendanceSheetShift(models.Model):
ondelete="cascade", ondelete="cascade",
) )
stage = fields.Selection( stage = fields.Selection(
[
("present", "Present"),
("absent", "Absent")
],
[("present", "Present"), ("absent", "Absent")],
string="Shift Stage", string="Shift Stage",
copy=False, copy=False,
) )
@ -152,7 +149,11 @@ class AttendanceSheetShiftAdded(models.Model):
class AttendanceSheet(models.Model): class AttendanceSheet(models.Model):
_name = "beesdoo.shift.sheet" _name = "beesdoo.shift.sheet"
_inherit = ["mail.thread", "ir.needaction_mixin", "barcodes.barcode_events_mixin"]
_inherit = [
"mail.thread",
"ir.needaction_mixin",
"barcodes.barcode_events_mixin",
]
_description = "Attendance sheets with all the shifts in one time range." _description = "Attendance sheets with all the shifts in one time range."
_order = "start_time" _order = "start_time"
@ -161,14 +162,10 @@ class AttendanceSheet(models.Model):
) )
active = fields.Boolean(string="Active", default=1) active = fields.Boolean(string="Active", default=1)
state = fields.Selection( state = fields.Selection(
[
("not_validated", "Not Validated"),
("validated", "Validated"),
],
[("not_validated", "Not Validated"), ("validated", "Validated"),],
string="Status", string="Status",
readonly=True, readonly=True,
index=True, index=True,
copy=False,
default="not_validated", default="not_validated",
track_visibility="onchange", track_visibility="onchange",
) )
@ -303,7 +300,6 @@ class AttendanceSheet(models.Model):
start_time_dt = fields.Datetime.context_timestamp(self, start_time_dt) start_time_dt = fields.Datetime.context_timestamp(self, start_time_dt)
end_time_dt = fields.Datetime.from_string(self.end_time) end_time_dt = fields.Datetime.from_string(self.end_time)
end_time_dt = fields.Datetime.context_timestamp(self, end_time_dt) end_time_dt = fields.Datetime.context_timestamp(self, end_time_dt)
self.name = ( self.name = (
start_time_dt.strftime("%Y-%m-%d") start_time_dt.strftime("%Y-%m-%d")
+ " " + " "
@ -311,7 +307,6 @@ class AttendanceSheet(models.Model):
+ "-" + "-"
+ end_time_dt.strftime("%H:%M") + end_time_dt.strftime("%H:%M")
) )
return
# Is this method necessary ? # Is this method necessary ?
@api.depends("annotation") @api.depends("annotation")
@ -356,8 +351,8 @@ class AttendanceSheet(models.Model):
task_templates.add(task.task_template_id) task_templates.add(task.task_template_id)
new_sheet.expected_worker_nb += 1 new_sheet.expected_worker_nb += 1
# Maximum number of workers calculation # Maximum number of workers calculation
for task_template in task_templates:
new_sheet.max_worker_nb += task_template.worker_nb
new_sheet.max_worker_nb = sum(r.worker_nb for r in task_templates)
return new_sheet return new_sheet
# Workaround to display notifications only for unread and not validated # Workaround to display notifications only for unread and not validated
@ -371,7 +366,6 @@ class AttendanceSheet(models.Model):
return self.search_count(domain) return self.search_count(domain)
return return
@api.one
def validate(self): def validate(self):
self.ensure_one() self.ensure_one()
if self.state == "validated": if self.state == "validated":
@ -397,11 +391,11 @@ class AttendanceSheet(models.Model):
# Expected shifts status update # Expected shifts status update
for expected_shift in self.expected_shift_ids: for expected_shift in self.expected_shift_ids:
actual_shift = expected_shift.task_id actual_shift = expected_shift.task_id
actual_stage = stage.search(
[("code", "=", expected_shift.get_actual_stage())]
)
# We get stage record corresponding to mapped stage id
actual_stage = self.env.ref("beesdoo_shift.%s" % expected_shift.get_actual_stage())
# If the actual stage has been deleted, the sheet is still validated. # If the actual stage has been deleted, the sheet is still validated.
# Raising an exception would stop this.
# Raising an exception would stop this but would prevent validation.
# How can we show a message without stopping validation ? # How can we show a message without stopping validation ?
if actual_stage: if actual_stage:
actual_shift.stage_id = actual_stage actual_shift.stage_id = actual_stage
@ -409,10 +403,7 @@ class AttendanceSheet(models.Model):
# Added shifts status update # Added shifts status update
for added_shift in self.added_shift_ids: for added_shift in self.added_shift_ids:
actual_stage = stage.search(
[("code", "=", added_shift.get_actual_stage())]
)
# WARNING: mapping the selection field to the booleans used in Task
actual_stage = self.env.ref("beesdoo_shift.%s" % added_shift.get_actual_stage())
is_regular_worker = added_shift.worker_id.working_mode == "regular" is_regular_worker = added_shift.worker_id.working_mode == "regular"
is_regular_shift = added_shift.regular_task_type == "normal" is_regular_shift = added_shift.regular_task_type == "normal"
# Add an annotation if a regular worker is doing its regular shift # Add an annotation if a regular worker is doing its regular shift
@ -429,7 +420,7 @@ class AttendanceSheet(models.Model):
("start_time", "=", self.start_time), ("start_time", "=", self.start_time),
("end_time", "=", self.end_time), ("end_time", "=", self.end_time),
("task_type_id", "=", added_shift.task_type_id.id), ("task_type_id", "=", added_shift.task_type_id.id),
]
], limit=1
) )
if len(non_assigned_shifts): if len(non_assigned_shifts):

5
beesdoo_shift/wizard/validate_attendance_sheet.py

@ -8,10 +8,6 @@ class ValidateAttendanceSheet(models.TransientModel):
_description = """Check the user name and validate sheet. _description = """Check the user name and validate sheet.
Useless for users in group_cooperative_admin""" Useless for users in group_cooperative_admin"""
def _get_sheet(self):
return self._context.get("active_id")
# current user as default value !
#card = fields.Many2one("member.card", string="MemberCard") #card = fields.Many2one("member.card", string="MemberCard")
barcode = fields.Char(string="Barcode", required=True) barcode = fields.Char(string="Barcode", required=True)
user = fields.Many2one("res.partner", compute="_compute_user", string="User Name", readonly=True) user = fields.Many2one("res.partner", compute="_compute_user", string="User Name", readonly=True)
@ -33,7 +29,6 @@ class ValidateAttendanceSheet(models.TransientModel):
sheet_id = self._context.get("active_id") sheet_id = self._context.get("active_id")
sheet_model = self._context.get("active_model") sheet_model = self._context.get("active_model")
sheet = self.env[sheet_model].browse(sheet_id) sheet = self.env[sheet_model].browse(sheet_id)
sheet.ensure_one()
if not self.user.super: if not self.user.super:
raise UserError( raise UserError(
"You must be super-coop or admin to validate the sheet." "You must be super-coop or admin to validate the sheet."

Loading…
Cancel
Save