[IMP] event_track_calendar_event*:
change behaviour to allow multiple dates (calendar events) to event tracks
This commit is contained in:
@@ -6,8 +6,26 @@ from datetime import timedelta
|
||||
class EventTrack(models.Model):
|
||||
_inherit = "event.track"
|
||||
|
||||
calendar_event = fields.Many2one('calendar.event', 'Calendar event')
|
||||
calendar_event_ids = fields.One2many('calendar.event', 'event_track_id', 'Days')
|
||||
date = fields.Datetime(compute="_compute_date")
|
||||
|
||||
def _compute_date(self):
|
||||
"""Date become a field computed from first calendar event date
|
||||
"""
|
||||
for event_track in self:
|
||||
if event_track.calendar_event_ids:
|
||||
event_track.date = event_track.calendar_event_ids.sorted(key=lambda r: r.start)[0].start
|
||||
else:
|
||||
event_track.date = None
|
||||
|
||||
def get_calendar_event_values(self):
|
||||
"""return default values of calendar events
|
||||
"""
|
||||
return {
|
||||
'partner_ids':[Command.set(self.get_calendar_event_partner_value())],
|
||||
'location':self.location_id.name if self.location_id else '',
|
||||
'user_id':self.user_id.id
|
||||
}
|
||||
|
||||
def get_calendar_event_partner_value(self):
|
||||
"""Compute list of partner ids for calendar event
|
||||
@@ -23,36 +41,28 @@ class EventTrack(models.Model):
|
||||
partner_ids.extend([registration.partner_id.id for registration in self.event_id.registration_ids if registration.partner_id])
|
||||
|
||||
return partner_ids
|
||||
|
||||
|
||||
def get_calendar_event_values(self):
|
||||
self.ensure_one()
|
||||
|
||||
return {
|
||||
'start':self.date,
|
||||
'duration':self.duration,
|
||||
'stop':self.date + timedelta(minutes=round((self.duration or 1.0) * 60)),
|
||||
'user_id':self.user_id.id,
|
||||
'partner_ids':[Command.set(self.get_calendar_event_partner_value())],
|
||||
'name':self.event_id.name+' - '+self.name,
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
def sync_calendar_event(self):
|
||||
"""synchronize calendar event values with event track data
|
||||
"""
|
||||
for track in self:
|
||||
if not track.calendar_event:
|
||||
track.calendar_event = self.env['calendar.event'].create(track.get_calendar_event_values())
|
||||
else:
|
||||
track.calendar_event.write(track.get_calendar_event_values())
|
||||
track.calendar_event_ids.write(track.get_calendar_event_values())
|
||||
|
||||
|
||||
@api.model_create_multi
|
||||
def create(self, vals_list):
|
||||
"""
|
||||
after creation of event track synchronise calendar event values
|
||||
"""
|
||||
res = super(EventTrack, self).create(vals_list)
|
||||
for track in res:
|
||||
track.sync_calendar_event()
|
||||
res.sync_calendar_event()
|
||||
return res
|
||||
|
||||
def write(self, vals):
|
||||
"""
|
||||
after modification of event track synchronise calendar event values
|
||||
"""
|
||||
res = super().write(vals)
|
||||
self.sync_calendar_event()
|
||||
return res
|
||||
|
Reference in New Issue
Block a user