From 3751379f1e9a4c215fb6eb898b4ccc67659b9ace Mon Sep 17 00:00:00 2001 From: stephanchrst Date: Tue, 10 May 2022 21:51:50 +0700 Subject: initial commit 2 --- addons/website_event_track/models/website_menu.py | 30 +++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 addons/website_event_track/models/website_menu.py (limited to 'addons/website_event_track/models/website_menu.py') diff --git a/addons/website_event_track/models/website_menu.py b/addons/website_event_track/models/website_menu.py new file mode 100644 index 00000000..703c3afb --- /dev/null +++ b/addons/website_event_track/models/website_menu.py @@ -0,0 +1,30 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import models + + +class WebsiteMenu(models.Model): + _inherit = "website.menu" + + def unlink(self): + """ Override to synchronize event configuration fields with menu deletion. + This should be cleaned in upcoming versions. """ + event_updates = {} + website_event_menus = self.env['website.event.menu'].search([('menu_id', 'in', self.ids)]) + for event_menu in website_event_menus: + to_update = event_updates.setdefault(event_menu.event_id, list()) + # specifically check for /track in menu URL; to avoid unchecking track field when removing + # agenda page that has also menu_type='track' + if event_menu.menu_type == 'track' and '/track' in event_menu.menu_id.url: + to_update.append('website_track') + + # call super that resumes the unlink of menus entries (including website event menus) + res = super(WebsiteMenu, self).unlink() + + # update events + for event, to_update in event_updates.items(): + if to_update: + event.write(dict((fname, False) for fname in to_update)) + + return res -- cgit v1.2.3