Odoo modules related to events management
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.

122 lines
4.2 KiB

  1. import pytz
  2. from datetime import timedelta
  3. from odoo import models, fields, api, _
  4. class EventEvent(models.Model):
  5. _inherit = "event.event"
  6. meeting_ids = fields.One2many(
  7. comodel_name="calendar.event",
  8. inverse_name="res_id",
  9. string="Linked meetings",
  10. )
  11. meeting_count = fields.Integer(
  12. string="Meeting count",
  13. compute="_count_meetings",
  14. )
  15. in_user_agenda = fields.Boolean(
  16. "In User agenda",
  17. compute="_get_in_user_agenda",
  18. )
  19. def _count_meetings(self):
  20. for event in self:
  21. event.meeting_count = len(event.meeting_ids)
  22. def _get_in_user_agenda(self):
  23. uid = self.env.uid
  24. for event in self:
  25. event.in_user_agenda = uid in event.meeting_ids.mapped("user_id").ids
  26. def add_to_agenda(self, user_id=False):
  27. vals_list = []
  28. self_model_id = self.env["ir.model"]._get_id(self._name)
  29. uid = user_id or self.env.uid
  30. to_add = self.filtered(
  31. lambda ee: uid not in ee.meeting_ids.mapped("user_id.id")
  32. )
  33. for event in to_add:
  34. groupped_tags = {}
  35. for tag in event.tag_ids:
  36. categ = tag.category_id.name
  37. if categ in groupped_tags:
  38. groupped_tags[categ] += ", {}".format(tag.name)
  39. else:
  40. groupped_tags[categ] = tag.name
  41. event_tz = pytz.timezone(event.date_tz)
  42. vals_list.append(
  43. {
  44. "name": event.name + " (event Odoo)",
  45. "description": _("<p>Organizer: {}{}<br/>Note:\n</p>").format(
  46. event.organizer_id.display_name,
  47. "".join(
  48. [
  49. "<br/>{} : {}".format(tag_group[0], tag_group[1])
  50. for tag_group in groupped_tags.items()
  51. ]
  52. ),
  53. event.note,
  54. ),
  55. "user_id": uid,
  56. "location": event.address_inline,
  57. "start": event_tz.localize(event.date_begin)
  58. .astimezone(pytz.timezone(self.env.user.tz))
  59. .replace(tzinfo=None),
  60. "stop": event_tz.localize(event.date_end)
  61. .astimezone(pytz.timezone(self.env.user.tz))
  62. .replace(tzinfo=None),
  63. "res_id": event.id,
  64. "res_model_id": self_model_id,
  65. # "event_tz": event.date_tz,
  66. }
  67. )
  68. if vals_list:
  69. self.env["calendar.event"].create(vals_list)
  70. def remove_from_agenda(self, user_id=False):
  71. to_unlink = self.mapped("meeting_ids").filtered(
  72. lambda meeting: meeting.user_id.id == user_id or self.env.uid
  73. )
  74. if to_unlink:
  75. to_unlink.unlink()
  76. def display_meetings(self):
  77. self.ensure_one()
  78. date_begin = self.date_begin.date()
  79. return {
  80. "name": _("Meetings"),
  81. "type": "ir.actions.act_window",
  82. "res_model": "calendar.event",
  83. "views": [(False, "tree"), (False, "calendar"), (False, "form")],
  84. "domain": [("res_id", "=", self.id), ("res_model", "=", self._name)],
  85. "context": {
  86. "calendar_mode": "week",
  87. "initial_date": fields.Date.to_string(
  88. date_begin - timedelta(days=-date_begin.weekday())
  89. ),
  90. },
  91. }
  92. @api.model
  93. def agenda_fields(self):
  94. return [
  95. "name",
  96. "date_begin_located",
  97. "date_end_located",
  98. "date_tz",
  99. "tag_ids",
  100. "organizer_id",
  101. "adress_inline",
  102. "note",
  103. ]
  104. def write(self, vals):
  105. res = super().write(vals)
  106. agenda_fields = self.agenda_fields()
  107. meetings = self.mapped("meeting_ids")
  108. if any(field in agenda_fields for field in vals.keys()) and meetings:
  109. meetings.write(
  110. dict([(field, vals[field]) for field in agenda_fields & vals.keys()])
  111. )
  112. return res