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/hr/models/mail_channel.py | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 addons/hr/models/mail_channel.py (limited to 'addons/hr/models/mail_channel.py') diff --git a/addons/hr/models/mail_channel.py b/addons/hr/models/mail_channel.py new file mode 100644 index 00000000..5ea45fe3 --- /dev/null +++ b/addons/hr/models/mail_channel.py @@ -0,0 +1,27 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import fields, models + + +class Channel(models.Model): + _inherit = 'mail.channel' + + subscription_department_ids = fields.Many2many( + 'hr.department', string='HR Departments', + help='Automatically subscribe members of those departments to the channel.') + + def _subscribe_users(self): + """ Auto-subscribe members of a department to a channel """ + super(Channel, self)._subscribe_users() + for mail_channel in self: + if mail_channel.subscription_department_ids: + mail_channel.write( + {'channel_partner_ids': + [(4, partner_id) for partner_id in mail_channel.mapped('subscription_department_ids.member_ids.user_id.partner_id').ids]}) + + def write(self, vals): + res = super(Channel, self).write(vals) + if vals.get('subscription_department_ids'): + self._subscribe_users() + return res -- cgit v1.2.3