################################################################################### # # Copyright (C) 2017 MuK IT GmbH # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as # published by the Free Software Foundation, either version 3 of the # License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see <http://www.gnu.org/licenses/>. # ################################################################################### import logging from odoo import _, api, models _logger = logging.getLogger(__name__) class ResUsers(models.Model): _inherit = 'res.users' @api.multi def notify(self, **params): """ Informs the web client to refresh the views that belong to the corresponding model by sending a message to the bus. There are two ways to use this method. First by calling it without any parameters. In this case, the views are determined and updated using the current records in self. Alternatively, the method can also be called with corresponding parameters to explicitly update a view from another model. :param title: The notification title :param message: The notification main message :param type: Either 'notification' or 'warning' :param sticky: Determines if the notification is sticky :param buttons: List of buttons, which consists of: text: The buttons text primary: Determines if the button is primary icon: The buttons font-awsome className or image src action: Either an action id, a descriptor or False to just to close the notification on the button click """ params.update({'user_ids': self.ids}) self.env['bus.bus'].sendone('notify', params) @api.multi def notify_info(self, message, title=None, sticky=False): self.notify(type='info', title=title or _('Information'), message=message, sticky=sticky) @api.multi def notify_warning(self, message, title=None, sticky=False): self.notify(type='warning', title=title or _('Warning'), message=message, sticky=sticky)