urd_odoo_addons/groupeurd_crm/models.py

149 lines
6.3 KiB
Python
Raw Normal View History

# -*- coding: utf-8 -*-
from openerp import models, fields, api
from openerp.osv import osv
from openerp import tools
from openerp.tools.translate import _
# Surcharge l'objet "Abonné" pour ajouter un lien vers l'objet "Contact"
class contact(models.Model):
_name = "mail.mass_mailing.contact"
_inherit = "mail.mass_mailing.contact"
partner_id = fields.Many2one("res.partner", string="Contact")
@api.model
def create(self, vals):
new_id = super(contact, self).create(vals)
partner = self.env['res.partner'].search([('email','=',new_id.email)])
if partner:
new_id.partner_id = partner[0].id # "new_id.partner_id" plutôt que "self.partner_id" car le self est vide dans un create
if new_id.list_id not in new_id.partner_id.list_ids:
new_id.partner_id.list_ids |= new_id.list_id
return new_id
class languagelist(models.Model):
_name = "groupeurd_crm.languagelist"
locale = fields.Char(required = True, string="Locale")
name = fields.Char(required = True, string="Nom de la langue")
# Surcharge l'objet "Contact" pour ajouter les liens vers les objets "Abonné" et "Liste de diffusion"
class partner(models.Model):
_name = "res.partner"
_inherit = "res.partner"
list_ids = fields.Many2many("mail.mass_mailing.list", string="Listes de diffusion")
contact_ids = fields.One2many("mail.mass_mailing.contact", "partner_id", string="Abonnements")
secondary_languages = fields.Many2many("groupeurd_crm.languagelist", string="Langues secondaires")
country_experiences = fields.Many2many("res.country", string="Pays d'expertise")
linkedin = fields.Char(string="LinkedIn")
2018-06-21 16:49:13 +02:00
moodle_username = fields.Char(string="Moodle username")
yearly_budget = fields.Integer(string="Budget annuel de l'organisation (M€)")
sigmah_adoption_status = fields.Selection([('no',"Non"),('engaged',"Adoption engagée"),('partial',"Utilisation partielle"),('complete',"Utilisation complète")], default='no', string="Adoption de Sigmah", required=True)
sigmah_package = fields.Selection([('basic',"socle"),('full',"complet")], string="Forfait de services")
sigmah_use_start = fields.Date(string="Début d'utilisation")
sigmah_autonomous_hosting = fields.Boolean(default=False, string="Hébergement autonome")
sigmah_users_count = fields.Integer(string="Nombre d'utilisateurs de Sigmah")
2018-06-21 16:49:13 +02:00
#Si des listes de diffusion sont ajoutées à la création du "Contact", ajouter les abonnements en conséquence
@api.model
def create(self, vals):
#On fait la création d'abord pour pouvoir associer les abonnements ensuite
res = super(partner, self).create(vals)
#Ajout de listes: pour toutes les listes en valeur, créer l'abonnement
subscribe_contact_vals_array = []
if vals.get('list_ids'):
for list_id in vals['list_ids'][0][2]:
list = self.env['mail.mass_mailing.list'].browse(list_id)
subscribe_contact_vals_array.append({'email': vals.get('email'), 'list_id':list_id})
#Appliquer les ajout de listes
for contact_vals in subscribe_contact_vals_array:
self.env['mail.mass_mailing.contact'].create(contact_vals)
return res
2018-06-21 16:49:13 +02:00
#Si des listes de diffusion sont ajoutées/supprimées pour le "Contact", modifier les abonnements en conséquence
@api.multi
def write(self, vals):
#Ajout de listes: pour toutes les listes en valeur, si une liste n'est pas dans les listes existantes, créer l'abonnement
subscribe_contact_vals_array = []
if vals.get('list_ids'):
for list_id in vals['list_ids'][0][2]:
list = self.env['mail.mass_mailing.list'].browse(list_id)
for partner_element in self:
if list not in partner_element.list_ids:
subscribe_contact_vals_array.append({'email': partner_element.email, 'list_id':list_id})
#Suppression de listes: pour toutes les listes existantes, si l'une d'elle n'est plus dans les listes passées en valeur, supprimer l'abonnement
unsubscribe_list_ids = []
for partner_element in self:
for list in partner_element.list_ids:
if vals.get('list_ids'):
if list.id not in vals['list_ids'][0][2]:
unsubscribe_list_ids.append(list.id)
#On fait l'écriture avant les ajout de listes pour éviter les boucles
res = super(partner, self).write(vals)
#Appliquer les ajout de listes
for contact_vals in subscribe_contact_vals_array:
self.env['mail.mass_mailing.contact'].create(contact_vals)
#Appliquer les désincriptions
for unsubscribe_list_id in unsubscribe_list_ids:
contact_array = self.env['mail.mass_mailing.contact'].search([('list_id','=',unsubscribe_list_id)])
for contact in contact_array:
contact.opt_out = True
contact.unsubscription_date = fields.Datetime.now()
contact.unsubscribed_by_odoo_user = self.env.user
return res
2018-06-21 16:49:13 +02:00
#Si des listes de diffusion ont été ajoutées pour le "Contact", supprimer les abonnements en conséquence lors de la suppression du contact
@api.multi
def unlink(self):
#Appliquer les désincriptions
for partner_element in self:
contact_array = self.env['mail.mass_mailing.contact'].search([('email','=',partner_element.email)])
for contact in contact_array:
contact.opt_out = True
contact.unsubscription_date = fields.Datetime.now()
contact.unsubscribed_by_odoo_user = self.env.user
#On fait la suppression après les désabonnements pour avoir l'objet partner toujours présent
res = super(partner, self).unlink()
return res
def goto_linkedin(self, cr, uid, ids, context=None):
partner_obj = self.pool.get('res.partner')
partner = partner_obj.browse(cr, uid, ids, context=context)[0]
if partner.linkedin:
good_starting_urls = ['https://linkedin.com/', 'https://www.linkedin.com/', \
'http://linkedin.com/', 'http://www.linkedin.com/']
non_protocol_starting_urls = ['linkedin.com/', 'www.linkedin.com/']
if any(map(lambda x: partner.linkedin.startswith(x), good_starting_urls)):
url = partner.linkedin
elif any(map(lambda x: partner.linkedin.startswith(x), non_protocol_starting_urls)):
url = 'https://' + partner.linkedin
else:
url = 'https://www.linkedin.com/' + partner.linkedin
return {'type': 'ir.actions.act_url', 'url': url, 'target': 'new'}
# A FAIRE
# A la création de contact, mettre à jour contact_ids et list_ids en fonction des abonnements existants pour cette adresse email
# A la modification de contact, mettre à jour contact_ids et list_ids en fonction des abonnements existants pour cette adresse email