You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

71 lines
3.1 KiB

7 years ago
7 years ago
  1. # -*- coding: utf-8 -*-
  2. from openerp import models, fields, api, _
  3. from openerp.exceptions import UserError
  4. class Subscribe(models.TransientModel):
  5. _name = 'beesdoo.shift.subscribe'
  6. def _get_date(self):
  7. date = self.env['res.partner'].browse(self._context.get('active_id')).info_session_date
  8. if not date:
  9. return fields.Date.today()
  10. else:
  11. return date
  12. def _get_super(self):
  13. return self.env['res.partner'].browse(self._context.get('active_id')).super
  14. def _get_mode(self):
  15. return self.env['res.partner'].browse(self._context.get('active_id')).working_mode
  16. cooperator_id = fields.Many2one('res.partner', default=lambda self: self.env['res.partner'].browse(self._context.get('active_id')), required=True)
  17. info_session = fields.Boolean(string="Followed an information session", default=True)
  18. info_session_date = fields.Date(string="Date of information session", default=_get_date)
  19. super = fields.Boolean(string="Super Cooperator", default=_get_super)
  20. working_mode = fields.Selection(
  21. [
  22. ('regular', 'Regular worker'),
  23. ('irregular', 'Irregular worker'),
  24. ('exempt', 'Exempted'),
  25. ], default=_get_mode
  26. )
  27. exempt_reason_id = fields.Many2one('cooperative.exempt.reason', 'Exempt Reason')
  28. shift_id = fields.Many2one('beesdoo.shift.template')
  29. reset_counter = fields.Boolean(default=False)
  30. @api.multi
  31. def subscribe(self):
  32. if not self.env.user.has_group('beesdoo_shift.group_shift_management'):
  33. raise UserError(_("You don't have the required access for this operation."))
  34. if self.cooperator_id == self.env.user.partner_id and not self.env.user.has_group('beesdoo_shift.group_cooperative_admin'):
  35. raise UserError(_("You cannot subscribe yourself."))
  36. self.ensure_one()
  37. self = self.with_context(real_uid=self._uid)
  38. if self.shift_id and self.shift_id.remaining_worker <= 0:
  39. raise UserError(_('There is no remaining space for this shift'))
  40. if self.shift_id:
  41. #Remove existing shift then subscribe to the new shift
  42. self.cooperator_id.sudo().write({'subscribed_shift_ids' : [(6,0, [self.shift_id.id])]})
  43. if self.working_mode != 'regular':
  44. #Remove existing shift then subscribe to the new shift
  45. self.cooperator_id.sudo().write({'subscribed_shift_ids' : [(5,)]})
  46. data = {
  47. 'info_session' : self.info_session,
  48. 'info_session_date': self.info_session_date,
  49. 'working_mode' : self.working_mode,
  50. 'exempt_reason_id' : self.exempt_reason_id.id,
  51. 'super' : self.super,
  52. 'cooperator_id': self.cooperator_id.id,
  53. }
  54. if self.reset_counter:
  55. data['sr'] = 0
  56. data['extension_start_time'] = False
  57. data['alert_start_time'] = False
  58. data['time_extension'] = 0
  59. status_id = self.env['cooperative.status'].search([('cooperator_id', '=', self.cooperator_id.id)])
  60. if status_id:
  61. status_id.sudo().write(data)
  62. else:
  63. self.env['cooperative.status'].sudo().create(data)