139 lines
5.8 KiB
Python
139 lines
5.8 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
from flectra import api, fields, models, _
|
|
from flectra.addons.http_routing.models.ir_http import slug
|
|
|
|
|
|
class EventType(models.Model):
|
|
_name = 'event.type'
|
|
_inherit = ['event.type']
|
|
|
|
website_menu = fields.Boolean(
|
|
'Display a dedicated menu on Website')
|
|
|
|
|
|
class Event(models.Model):
|
|
_name = 'event.event'
|
|
_inherit = ['event.event', 'website.seo.metadata', 'website.published.mixin']
|
|
|
|
website_published = fields.Boolean(track_visibility='onchange')
|
|
website_id = fields.Many2one('website', string='Website', copy=False,
|
|
default=lambda self: self.env.ref(
|
|
'website.default_website'),
|
|
help='Website in which '
|
|
'Event will published.')
|
|
|
|
is_participating = fields.Boolean("Is Participating", compute="_compute_is_participating")
|
|
|
|
website_menu = fields.Boolean(
|
|
'Dedicated Menu', compute='_compute_website_menu', inverse='_set_website_menu',
|
|
help="Creates menus Introduction, Location and Register on the page "
|
|
" of the event on the website.", store=True)
|
|
menu_id = fields.Many2one('website.menu', 'Event Menu', copy=False)
|
|
|
|
def _compute_is_participating(self):
|
|
# we don't allow public user to see participating label
|
|
if self.env.user != self.env.ref('base.public_user'):
|
|
email = self.env.user.partner_id.email
|
|
for event in self:
|
|
domain = ['&', '|', ('email', '=', email), ('partner_id', '=', self.env.user.partner_id.id), ('event_id', '=', event.id)]
|
|
event.is_participating = self.env['event.registration'].search_count(domain)
|
|
|
|
@api.multi
|
|
@api.depends('name')
|
|
def _compute_website_url(self):
|
|
super(Event, self)._compute_website_url()
|
|
for event in self:
|
|
if event.id: # avoid to perform a slug on a not yet saved record in case of an onchange.
|
|
event.website_url = '/event/%s' % slug(event)
|
|
|
|
@api.onchange('event_type_id')
|
|
def _onchange_type(self):
|
|
super(Event, self)._onchange_type()
|
|
if self.event_type_id:
|
|
self.website_menu = self.event_type_id.website_menu
|
|
|
|
def _get_standard_menu_entries_names(self):
|
|
""" Method returning menu entries possibly generated by event modules.
|
|
It is used to distinguish module-generated pages from custom pages. """
|
|
return [_('Introduction'), _('Location'), _('Register')]
|
|
|
|
def _get_menu_entries(self):
|
|
""" Method returning menu entries to display on the website view of the
|
|
event, possibly depending on some options in inheriting modules. """
|
|
self.ensure_one()
|
|
return [
|
|
(_('Introduction'), False, 'website_event.template_intro'),
|
|
(_('Location'), False, 'website_event.template_location'),
|
|
(_('Register'), '/event/%s/register' % slug(self), False),
|
|
]
|
|
|
|
@api.multi
|
|
def _set_website_menu(self):
|
|
for event in self:
|
|
if event.menu_id and not event.website_menu:
|
|
event.menu_id.unlink()
|
|
elif event.website_menu:
|
|
if not event.menu_id:
|
|
root_menu = self.env['website.menu'].create({'name': event.name})
|
|
event.menu_id = root_menu
|
|
|
|
existing_page_names = event.menu_id.child_id.mapped('name')
|
|
required_page_names = [entry[0] for entry in event._get_menu_entries()]
|
|
standard_page_names = self._get_standard_menu_entries_names()
|
|
|
|
# remove entries that should not exist anymore
|
|
submenu_to_delete = event.menu_id.child_id.filtered(lambda menu: menu.name not in required_page_names and menu.name in standard_page_names)
|
|
submenu_to_delete.unlink()
|
|
|
|
# create missing entries
|
|
for sequence, (name, url, xml_id) in enumerate(event._get_menu_entries()):
|
|
if name not in existing_page_names:
|
|
if not url:
|
|
newpath = self.env['website'].new_page(name + ' ' + event.name, template=xml_id, ispage=False)['url']
|
|
url = "/event/" + slug(event) + "/page/" + newpath[1:]
|
|
self.env['website.menu'].create({
|
|
'name': name,
|
|
'url': url,
|
|
'parent_id': event.menu_id.id,
|
|
'sequence': sequence,
|
|
})
|
|
|
|
@api.multi
|
|
def _compute_website_menu(self):
|
|
for event in self:
|
|
event.website_menu = bool(event.menu_id)
|
|
|
|
@api.multi
|
|
def google_map_img(self, zoom=8, width=298, height=298):
|
|
self.ensure_one()
|
|
if self.address_id:
|
|
return self.sudo().address_id.google_map_img(zoom=zoom, width=width, height=height)
|
|
return None
|
|
|
|
@api.multi
|
|
def google_map_link(self, zoom=8):
|
|
self.ensure_one()
|
|
if self.address_id:
|
|
return self.sudo().address_id.google_map_link(zoom=zoom)
|
|
return None
|
|
|
|
@api.multi
|
|
def _track_subtype(self, init_values):
|
|
self.ensure_one()
|
|
if 'website_published' in init_values and self.website_published:
|
|
return 'website_event.mt_event_published'
|
|
elif 'website_published' in init_values and not self.website_published:
|
|
return 'website_event.mt_event_unpublished'
|
|
return super(Event, self)._track_subtype(init_values)
|
|
|
|
@api.multi
|
|
def action_open_badge_editor(self):
|
|
""" open the event badge editor : redirect to the report page of event badge report """
|
|
self.ensure_one()
|
|
return {
|
|
'type': 'ir.actions.act_url',
|
|
'target': 'new',
|
|
'url': '/report/html/%s/%s?enable_editor' % ('event.event_event_report_template_badge', self.id),
|
|
}
|