RSS pour les messages de groupe
[auf_savoirs_en_partage_django.git] / auf_savoirs_en_partage / chercheurs / models.py
CommitLineData
932eef9a 1# -*- encoding: utf-8 -*-
92990258 2import hashlib
fdcf5874 3
5212238e 4from datamaster_modeles.models import *
43ed73e7 5from django.conf import settings
fdcf5874
EMS
6from django.contrib.auth.models import User
7from django.core.urlresolvers import reverse as url
932eef9a 8from django.db import models
a2c6bb72 9from django.db.models import Q
92990258 10from django.utils.encoding import smart_str
43ed73e7 11from django.utils.hashcompat import sha_constructor
5212238e 12from djangosphinx.models import SphinxSearch
fdcf5874
EMS
13
14from savoirs.models import Discipline, SEPManager, SEPSphinxQuerySet, SEPQuerySet, Search
932eef9a 15
13146d99 16GENRE_CHOICES = (('m', 'Homme'), ('f', 'Femme'))
932eef9a 17class Personne(models.Model):
595ab4d6 18 salutation = models.CharField(max_length=128, null=True, blank=True)
932eef9a 19 nom = models.CharField(max_length=255)
595ab4d6 20 prenom = models.CharField(max_length=128, verbose_name='prénom')
165da916
EMS
21 courriel = models.EmailField(max_length=128, verbose_name="courriel")
22 afficher_courriel = models.BooleanField(default=True)
595ab4d6 23 fonction = models.CharField(max_length=128, null=True, blank=True)
c18af6bd 24 date_naissance = models.DateField(null=True, blank=True)
595ab4d6 25 sousfonction = models.CharField(max_length=128, null=True, blank=True, verbose_name='sous-fonction')
0a379c77
EMS
26 telephone = models.CharField(max_length=32, null=True, blank=True, verbose_name='numéro de téléphone')
27 adresse_postale = models.TextField(blank=True)
932eef9a 28 genre = models.CharField(max_length=1, choices=GENRE_CHOICES)
595ab4d6 29 commentaire = models.TextField(verbose_name='commentaires', null=True, blank=True)
3e556e66 30 actif = models.BooleanField(editable=False, default=False)
932eef9a
AJ
31
32 def __unicode__(self):
33 return u"%s %s, %s" % (self.prenom, self.nom, self.courriel)
34
35 class Meta:
13ec4813 36 ordering = ["nom", "prenom"]
92990258 37
705013cb
EMS
38 @property
39 def civilite(self):
40 if self.genre == 'm':
41 return 'M.'
42 elif self.genre == 'f':
43 return 'Mme'
44 else:
45 return ''
46
3a3d9c6f
EMS
47 def courriel_display(self):
48 return self.courriel.replace(u'@', u' (à) ')
49
5212238e 50class ChercheurQuerySet(SEPQuerySet):
a2c6bb72 51
5212238e
EMS
52 def filter_groupe(self, groupe):
53 return self.filter(groupes=groupe)
54
55 def filter_pays(self, pays):
56 return self.filter(Q(etablissement__pays=pays) | Q(etablissement_autre_pays=pays))
57
58 def filter_region(self, region):
59 return self.filter(Q(etablissement__pays__region=region) | Q(etablissement_autre_pays__region=region))
a2c6bb72 60
5212238e
EMS
61 def filter_nord_sud(self, nord_sud):
62 return self.filter(Q(etablissement__pays__nord_sud=nord_sud) | Q(etablissement_autre_pays__nord_sud=nord_sud))
116db1fd 63
5c9bae2d
OL
64 def filter_genre(self, genre):
65 return self.filter(genre=genre)
66
5212238e
EMS
67 def filter_statut(self, statut):
68 return self.filter(statut=statut)
69
70 def filter_expert(self):
71 return self.exclude(expertises=None)
72
230671ff
EMS
73 def filter_date_modification(self, min=None, max=None):
74 return self._filter_date('date_modification', min=min, max=max)
75
acd5cd8f 76 def order_by_nom(self, direction=''):
3648b3d6 77 return self.order_by(direction + 'nom', direction + 'prenom', '-date_modification')
acd5cd8f
EMS
78
79 def order_by_etablissement(self, direction=''):
1760a3e9
EMS
80 return self.extra(select=dict(etablissement_nom='IFNULL(ref_etablissement.nom, chercheurs_chercheur.etablissement_autre_nom)'),
81 order_by=[direction + 'etablissement_nom', '-date_modification'])
acd5cd8f
EMS
82
83 def order_by_pays(self, direction=''):
84 return self.extra(select=dict(
85 pays_etablissement='''(SELECT nom FROM ref_pays
86 WHERE ref_pays.code = IFNULL(ref_etablissement.pays, chercheurs_chercheur.etablissement_autre_pays))'''
87 ), order_by=[direction + 'pays_etablissement', '-date_modification'])
88
5212238e
EMS
89class ChercheurSphinxQuerySet(SEPSphinxQuerySet):
90
91 def __init__(self, model=None):
4134daa0 92 return SEPSphinxQuerySet.__init__(self, model=model, index='savoirsenpartage_chercheurs',
acd5cd8f 93 weights=dict(nom=2, prenom=2))
d9da735f 94
c1b134f8 95 def filter_region(self, region):
5212238e
EMS
96 return self.filter(region_id=region.id)
97
98 def filter_groupe(self, groupe):
99 return self.filter(groupe_ids=groupe.id)
100
101 def filter_pays(self, pays):
102 return self.filter(pays_id=pays.id)
c1b134f8 103
5212238e
EMS
104 NORD_SUD_CODES = {'Nord': 1, 'Sud': 2}
105 def filter_nord_sud(self, nord_sud):
106 return self.filter(nord_sud=self.NORD_SUD_CODES[nord_sud])
107
c6efde25
OL
108 GENRE_CODES = dict([(k, i+1) for i, (k, v) in enumerate(GENRE_CHOICES)])
109 def filter_genre(self, genre):
110 return self.filter(genre=self.GENRE_CODES[genre])
111
5212238e
EMS
112 STATUT_CODES = {'enseignant': 1, 'etudiant': 2, 'independant': 3}
113 def filter_statut(self, statut):
114 return self.filter(statut=self.STATUT_CODES[statut])
115
d9da735f
EMS
116 def filter_expert(self):
117 return self.filter(expert=True)
118
230671ff 119 def filter_date_modification(self, min=None, max=None):
7ed3ee8f 120 return self._filter_date('date_modification', min=min, max=max)
230671ff 121
acd5cd8f
EMS
122 def order_by_nom(self, direction=''):
123 return self.order_by(direction + 'nom_complet', '-date_modification')
124
125 def order_by_etablissement(self, direction=''):
126 return self.order_by(direction + 'etablissement_attr', '-date_modification')
127
128 def order_by_pays(self, direction=''):
129 return self.order_by(direction + 'pays_attr', '-date_modification')
130
5212238e 131class ChercheurManager(SEPManager):
a2c6bb72
EMS
132
133 def get_query_set(self):
695930dd 134 return ChercheurQuerySet(self.model).filter(actif=True)
a2c6bb72 135
5212238e
EMS
136 def get_sphinx_query_set(self):
137 return ChercheurSphinxQuerySet(self.model).order_by('-date_modification')
5212238e 138
116db1fd 139 def filter_region(self, region):
5212238e 140 """Le filtrage de chercheurs par région n'est pas une recherche texte."""
c1b134f8
EMS
141 return self.get_query_set().filter_region(region)
142
5212238e
EMS
143 def filter_groupe(self, groupe):
144 return self.get_query_set().filter_groupe(groupe)
bae03b7b 145
5212238e
EMS
146 def filter_pays(self, pays):
147 return self.get_query_set().filter_pays(pays)
148
149 def filter_nord_sud(self, nord_sud):
150 return self.get_query_set().filter_nord_sud(nord_sud)
151
a7bf6c5a 152 def filter_genre(self, genre):
634d46da 153 return self.get_query_set().filter_genre(genre=genre)
a7bf6c5a 154
5212238e
EMS
155 def filter_statut(self, statut):
156 return self.get_query_set().filter_statut(statut)
157
158 def filter_expert(self):
159 return self.get_query_set().filter_expert()
3efbacbe 160
230671ff
EMS
161 def filter_date_modification(self, min=None, max=None):
162 return self.get_query_set().filter_date_modification(min=min, max=max)
163
acd5cd8f
EMS
164 def order_by_nom(self, direction=''):
165 return self.get_query_set().order_by_nom(self, direction=direction)
166
167 def order_by_etablissement(self, direction=''):
168 return self.get_query_set().order_by_etablissement(self, direction=direction)
169
170 def order_by_pays(self, direction=''):
171 return self.get_query_set().order_by_pays(self, direction=direction)
172
bc15119b
EMS
173STATUT_CHOICES = (
174 ('enseignant', 'Enseignant-chercheur dans un établissement'),
175 ('etudiant', 'Étudiant-chercheur doctorant'),
176 ('independant', 'Chercheur indépendant docteur')
177)
178
13ec4813 179class Chercheur(Personne):
bc15119b
EMS
180 RESEAU_INSTITUTIONNEL_CHOICES = (
181 ('AFELSH', 'Association des facultés ou établissements de lettres et sciences humaines des universités d’expression française (AFELSH)'),
182 ('CIDEGEF', 'Conférence internationale des dirigeants des institutions d’enseignement supérieur et de recherche de gestion d’expression française (CIDEGEF)'),
183 ('RIFEFF', 'Réseau international francophone des établissements de formation de formateurs (RIFEFF)'),
184 ('CIDMEF', 'Conférence internationale des doyens des facultés de médecine d’expression française (CIDMEF)'),
185 ('CIDCDF', 'Conférence internationale des doyens des facultés de chirurgie dentaire d’expression totalement ou partiellement française (CIDCDF)'),
186 ('CIFDUF', 'Conférence internationale des facultés de droit ayant en commun l’usage du français (CIFDUF)'),
187 ('CIRUISEF', 'Conférence internationale des responsables des universités et institutions à dominante scientifique et technique d’expression française (CIRUISEF)'),
188 ('Theophraste', 'Réseau Théophraste (Réseau de centres francophones de formation au journalisme)'),
189 ('CIDPHARMEF', 'Conférence internationale des doyens des facultés de pharmacie d’expression française (CIDPHARMEF)'),
190 ('CIDEFA', 'Conférence internationale des directeurs et doyens des établissements supérieurs d’expression française des sciences de l’agriculture et de l’alimentation (CIDEFA)'),
191 ('CITEF', 'Conférence internationale des formations d’ingénieurs et techniciens d’expression française (CITEF)'),
192 ('APERAU', 'Association pour la promotion de l’enseignement et de la recherche en aménagement et urbanisme (APERAU)'),
193 )
194 INSTANCE_AUF_CHOICES = (
195 ('CASSOC', 'Conseil associatif'),
196 ('CA', "Conseil d'administration"),
197 ('CS', 'Conseil scientifique'),
2fcf82c9
EMS
198 ('CRE', "Commission régionale d'experts"),
199 ('CR', 'Conférence des recteurs'),
200 ('CNO', "Conseil national d'orientation")
bc15119b
EMS
201 )
202
00755d9b 203 nationalite = models.ForeignKey(Pays, null = True, db_column='nationalite', to_field='code',
0b0fbbd7 204 verbose_name = 'nationalité', related_name='nationalite')
a4e383ac 205 statut = models.CharField(max_length=36, choices=STATUT_CHOICES)
0b0fbbd7 206 diplome = models.CharField(max_length=255, null=True, verbose_name = 'diplôme le plus élevé')
73cabd75 207 etablissement = models.ForeignKey(Etablissement, db_column='etablissement', null=True, blank=True)
0b0fbbd7 208 etablissement_autre_nom = models.CharField(max_length=255, null=True, blank=True, verbose_name = 'autre établissement')
00755d9b 209 etablissement_autre_pays = models.ForeignKey(Pays, null = True, blank=True, db_column='etablissement_autre_pays',
0b0fbbd7
EMS
210 to_field='code', related_name='etablissement_autre_pays',
211 verbose_name = "pays de l'établissement")
0874e7d1 212 attestation = models.BooleanField()
73cabd75 213
0b0fbbd7 214 #Domaine
602e4194 215 thematique = models.ForeignKey(Thematique, db_column='thematique', blank=True, null=True, verbose_name='thematique')
518d0b44 216 mots_cles = models.CharField(max_length=255, null=True, verbose_name='mots-clés')
0b0fbbd7 217 discipline = models.ForeignKey(Discipline, db_column='discipline', null=True, verbose_name='Discipline')
518d0b44 218 theme_recherche = models.TextField(null=True, blank=True, verbose_name='thèmes de recherche')
0b0fbbd7 219 groupe_recherche = models.CharField(max_length=255, blank=True, verbose_name='groupe de recherche')
219710da
EMS
220 url_site_web = models.URLField(max_length=255, null=True, blank=True,
221 verbose_name='adresse site Internet', verify_exists=False)
222 url_blog = models.URLField(max_length=255, null=True, blank=True, verbose_name='blog',
223 verify_exists=False)
3c576696
EMS
224 url_reseau_social = models.URLField(
225 max_length=255, null=True, blank=True, verbose_name='Réseau social',
219710da 226 verify_exists=False,
3c576696
EMS
227 help_text=u"Vous pouvez indiquer ici l'adresse de votre page personnelle dans votre réseau social préféré (e.g. Facebook, LinkedIn, Twitter, Identica, ...)"
228 )
00755d9b 229
0c0d997c 230 groupes = models.ManyToManyField('Groupe', through='ChercheurGroupe', related_name='membres', blank=True, verbose_name='Domaines de recherche')
932eef9a 231
a7b16ec9 232 # Activités en francophonie
121d9439 233 membre_instance_auf = models.NullBooleanField(verbose_name="est ou a déjà été membre d'une instance de l'AUF")
bc15119b
EMS
234 membre_instance_auf_nom = models.CharField(max_length=10, blank=True, choices=INSTANCE_AUF_CHOICES, verbose_name="instance")
235 membre_instance_auf_fonction = models.CharField(max_length=255, blank=True, verbose_name="fonction")
a7b16ec9 236 membre_instance_auf_dates = models.CharField(max_length=255, blank=True, verbose_name="dates")
121d9439 237 expert_oif = models.NullBooleanField(verbose_name="a été sollicité par l'OIF")
614b3269
EMS
238 expert_oif_details = models.CharField(max_length=255, blank=True, verbose_name="détails")
239 expert_oif_dates = models.CharField(max_length=255, blank=True, verbose_name="dates")
121d9439 240 membre_association_francophone = models.NullBooleanField(verbose_name="est membre d'une association francophone")
c073c94d 241 membre_association_francophone_details = models.CharField(max_length=255, blank=True, verbose_name="nom de l'association")
121d9439
EMS
242 membre_reseau_institutionnel = models.NullBooleanField(
243 verbose_name="est membre des instances d'un réseau institutionnel de l'AUF"
bc15119b
EMS
244 )
245 membre_reseau_institutionnel_nom = models.CharField(
246 max_length=15, choices=RESEAU_INSTITUTIONNEL_CHOICES, blank=True,
247 verbose_name="réseau institutionnel"
c073c94d 248 )
bc15119b
EMS
249 membre_reseau_institutionnel_fonction = models.CharField(
250 max_length=255, blank=True, verbose_name="fonction"
c073c94d
EMS
251 )
252 membre_reseau_institutionnel_dates = models.CharField(
253 max_length=255, blank=True, verbose_name="dates"
254 )
a7b16ec9 255
cb591fb3 256 # Expertises
121d9439 257 expertises_auf = models.NullBooleanField(verbose_name="est disposé à réaliser des expertises pour l'AUF")
cb591fb3 258
00755d9b
AJ
259 #meta
260 date_creation = models.DateField(auto_now_add=True, db_column='date_creation')
261 date_modification = models.DateField(auto_now=True, db_column='date_modification')
262
a2c6bb72
EMS
263 # Manager
264 objects = ChercheurManager()
c59dba82 265 all_objects = models.Manager()
a2c6bb72 266
af5ed842
PP
267 class Meta:
268 permissions = (
8ca40209 269 ("view_chercheur", "Peut visualiser la liste des chercheurs"),
af5ed842
PP
270 )
271
588d6b93 272 def __unicode__(self):
13ec4813 273 return u"%s %s" % (self.nom.upper(), self.prenom.title())
e427f068 274
b57a7362
AJ
275 def statut_display(self):
276 for s in STATUT_CHOICES:
277 if self.statut == s[0]:
278 return s[1]
e427f068 279 return "-"
588d6b93 280
e4d01d1d
EMS
281 @property
282 def etablissement_display(self):
230671ff 283 return (self.nom_etablissement or '') + (', ' + self.pays.nom if self.pays else '')
e4d01d1d 284
d32102bd
EMS
285 @property
286 def pays(self):
287 return self.etablissement.pays if self.etablissement else self.etablissement_autre_pays
288
289 @property
d264c787
EMS
290 def nom_etablissement(self):
291 return self.etablissement.nom if self.etablissement else self.etablissement_autre_nom
292
293 @property
d32102bd
EMS
294 def region(self):
295 return self.pays.region
296
5b55252d
PP
297 @property
298 def domaines_recherche(self):
299 return self.groupes.filter(groupe_chercheur=False)
300
301 @property
302 def groupes_chercheur(self):
303 return self.groupes.filter(groupe_chercheur=True)
304
71e3d741
EMS
305 def save(self):
306 """Si on a donné un établissement membre, on laisse tomber l'autre établissement."""
307 if self.etablissement:
308 self.etablissement_autre_nom = None
309 self.etablissement_autre_pays = None
310 super(Chercheur, self).save()
311
43ed73e7
EMS
312 def activation_token(self):
313 return sha_constructor(settings.SECRET_KEY + unicode(self.id)).hexdigest()[::2]
314
4b89a7df
EMS
315 def get_absolute_url(self):
316 return url('chercheur', kwargs={'id': self.id})
317
00755d9b 318class Publication(models.Model):
595ab4d6 319 chercheur = models.ForeignKey(Chercheur, related_name='publications')
1df3737b 320 auteurs = models.CharField(max_length=255, blank=True, verbose_name='auteur(s)')
595ab4d6 321 titre = models.CharField(max_length=255, null=True, blank=True, verbose_name='titre')
1df3737b
EMS
322 revue = models.CharField(max_length=255, null=True, blank=True, verbose_name='revue')
323 annee = models.IntegerField(null=True, blank=True, verbose_name='année de publication')
324 editeur = models.CharField(max_length=255, null=True, blank=True, verbose_name='éditeur')
325 lieu_edition = models.CharField(max_length=255, null=True, blank=True, verbose_name="lieu d'édition")
326 nb_pages = models.CharField(max_length=255, null=True, blank=True, verbose_name='nombre de pages')
912e3c6c 327 url = models.URLField(max_length=255, null=True, blank=True, verbose_name='lien vers la publication', verify_exists=False)
6befc7c9 328 #Migration des publications depuis l'ancien repertoire de chercheurs
1df3737b 329 publication_affichage = models.TextField(verbose_name='publication', null=True, blank=True)
595ab4d6 330 actif = models.BooleanField(editable=False)
2a36714f
AJ
331
332 def __unicode__(self):
c59dba82 333 return self.titre or '(Aucun)'
2a36714f 334
3eb41a6d
EMS
335 def save(self):
336 if self.publication_affichage and (self.auteurs or self.titre or
337 self.revue or self.annee or
338 self.editeur or self.lieu_edition
339 or self.nb_pages or self.url):
340 self.publication_affichage = ''
341 super(Publication, self).save()
342
595ab4d6
EMS
343class These(models.Model):
344 chercheur = models.OneToOneField(Chercheur, primary_key=True)
14fd1c3f 345 titre = models.CharField(max_length=255, verbose_name='Titre')
595ab4d6 346 annee = models.IntegerField(verbose_name='Année de soutenance (réalisée ou prévue)')
14fd1c3f 347 directeur = models.CharField(max_length=255, verbose_name='Directeur')
595ab4d6
EMS
348 etablissement = models.CharField(max_length=255, verbose_name='Établissement de soutenance')
349 nb_pages = models.IntegerField(verbose_name='Nombre de pages', blank=True, null=True)
912e3c6c 350 url = models.URLField(max_length=255, verbose_name='Lien vers la publication', blank=True, verify_exists=False)
595ab4d6
EMS
351
352 def __unicode__(self):
353 return self.titre
354
2a36714f
AJ
355class Expertise(models.Model):
356 id = models.AutoField(primary_key=True, db_column='id')
ee8b3a49 357 chercheur = models.ForeignKey(Chercheur, related_name='expertises')
356cc691 358 nom = models.CharField(max_length=255, verbose_name = "Objet de l'expertise")
c1234eb8 359 date = models.CharField(max_length=255, blank=True)
ee8b3a49 360 lieu = models.CharField(max_length=255, null=True, blank=True, verbose_name = "Lieu de l'expertise")
b16bcbaf
EMS
361 organisme_demandeur = models.CharField(max_length=255, null=True, blank=True, verbose_name = 'Organisme demandeur')
362 organisme_demandeur_visible = models.BooleanField(verbose_name="Afficher l'organisme demandeur")
2a36714f 363 actif = models.BooleanField(editable = False, db_column='actif')
5b9abc81
AJ
364
365 def __unicode__(self):
366 return u"%s" % (self.nom)
2a36714f 367
057c3327
PP
368class GroupeManager(models.Manager):
369 def search(self, text):
370 return self.get_query_set().filter(nom__icontains=text)
371
372class GroupeChercheurManager(GroupeManager):
5b55252d
PP
373 def get_query_set(self):
374 return super(GroupeChercheurManager, self).get_query_set().filter(groupe_chercheur=True)
375
057c3327 376class DomaineRechercheManager(GroupeManager):
5b55252d
PP
377 def get_query_set(self):
378 return super(DomaineRechercheManager, self).get_query_set().filter(groupe_chercheur=False)
379
932eef9a
AJ
380class Groupe(models.Model):
381 id = models.AutoField(primary_key=True, db_column='id')
382 nom = models.CharField(max_length=255, db_column='nom')
00755d9b
AJ
383 url = models.URLField(max_length=255, null=True, blank=True,
384 verbose_name='Site web')
385 liste_diffusion = models.URLField(max_length=255, null=True, blank=True,
386 verbose_name='Liste de diffusion')
387 bulletin = models.URLField(max_length=255, null=True, blank=True,
388 verbose_name='Bulletin')
932eef9a 389 actif = models.BooleanField(editable = False, db_column='actif')
04985abd 390 groupe_chercheur = models.BooleanField(default=False, editable=False, verbose_name='Groupe de chercheur')
5b55252d 391
4a7399ee 392 responsables = models.ManyToManyField(User, related_name='responsable_groupe', verbose_name='responsables', blank=True)
cec3f8db 393
0c0d997c 394 page_accueil = models.TextField(null=True, blank=True)
5b55252d 395
057c3327 396 objects = GroupeManager()
5b55252d
PP
397 groupe_chercheur_objects = GroupeChercheurManager()
398 domaine_recherche_objects = DomaineRechercheManager()
932eef9a 399
55ef8558
EMS
400 class Meta:
401 verbose_name = 'domaine de recherche'
402 verbose_name_plural = 'domaines de recherche'
403
932eef9a
AJ
404 def __unicode__(self):
405 return u"%s" % (self.nom)
5b55252d 406
bf2904f0
PP
407 def get_absolute_url(self):
408 return url('groupe_retrieve', kwargs={'id': self.id})
409
410
5b55252d
PP
411class GroupeChercheur(Groupe):
412 objects = GroupeChercheurManager()
413
414 class Meta:
415 proxy = True
416 verbose_name = 'groupe de chercheur'
417 verbose_name_plural = 'groupes de chercheur'
418
04985abd
PP
419 def save(self, *args, **kwargs):
420 self.groupe_chercheur = True
421 super(GroupeChercheur, self).save(*args, **kwargs)
422
5b55252d
PP
423class DomaineRecherche(Groupe):
424 objects = DomaineRechercheManager()
425
426 class Meta:
427 proxy = True
428 verbose_name = 'domaine de recherche'
429 verbose_name_plural = 'domaines de recherche'
430
04985abd
PP
431 def save(self, *args, **kwargs):
432 self.groupe_chercheur = False
433 super(DomaineRecherche, self).save(*args, **kwargs)
434
932eef9a 435class ChercheurGroupe(models.Model):
73cabd75 436 id = models.AutoField(primary_key=True, db_column='id')
6d5279ff 437 chercheur = models.ForeignKey('Chercheur', db_column='chercheur')
0c0d997c 438 groupe = models.ForeignKey('Groupe', db_column='groupe', related_name="membership")
00755d9b
AJ
439 date_inscription = models.DateField(auto_now_add=True)
440 date_modification = models.DateField(auto_now=True)
6d5279ff 441 actif = models.BooleanField(db_column='actif')
2a36714f 442
55ef8558
EMS
443 class Meta:
444 verbose_name = 'adhésion'
445
2a36714f
AJ
446 def __unicode__(self):
447 return u"%s - %s" % (self.chercheur, self.groupe)
fdcf5874
EMS
448
449class ChercheurSearch(Search):
450 nom_chercheur = models.CharField(max_length=100, blank=True, verbose_name='nom')
5b55252d
PP
451 domaine = models.ForeignKey(DomaineRecherche, blank=True, null=True, verbose_name='domaine de recherche')
452 groupe_chercheur = models.ForeignKey(GroupeChercheur, blank=True, null=True, verbose_name='groupe de chercheur')
fdcf5874
EMS
453 groupe_recherche = models.CharField(max_length=100, blank=True, null=True,
454 verbose_name='groupe de recherche',
455 help_text='ou Laboratoire, ou Groupement inter-universitaire')
456 statut = models.CharField(max_length=100, blank=True, choices=STATUT_CHOICES + (('expert', 'Expert'),))
457 pays = models.ForeignKey(Pays, blank=True, null=True)
458 nord_sud = models.CharField(max_length=4, blank=True, choices=(('Nord', 'Nord'), ('Sud', 'Sud')),
459 verbose_name='Nord/Sud',
460 help_text="Distinction d'ordre géopolitique et économique, non géographique, qui conditionne souvent l'attribution de soutiens par les agences internationales: on entend par Nord les pays développés, par Sud les pays en développement (pays les moins avancés, pays émergents et pays à économies en transition)")
461 activites_francophonie = models.CharField(
462 max_length=25, blank=True, verbose_name='activités en Francophonie',
463 choices=(('instance_auf', "Membre d'une instance de l'AUF"),
464 ('expert_oif', "Sollicité par l'OIF"),
465 ('association_francophone', "Membre d'une association ou d'une société savante francophone"),
466 ('reseau_institutionnel', "Membre des instances d'un réseau institutionnel de l'AUF"))
467 )
468 genre = models.CharField(max_length=1, blank=True, choices=GENRE_CHOICES)
469
470 class Meta:
471 verbose_name = 'recherche de chercheurs'
472 verbose_name_plural = 'recherches de chercheurs'
473
4b89a7df 474 def run(self, min_date=None, max_date=None):
fdcf5874
EMS
475 results = Chercheur.objects
476 if self.q:
477 results = results.search(self.q)
478 if self.nom_chercheur:
479 results = results.add_to_query('@(nom,prenom) ' + self.nom_chercheur)
480 if self.groupe_recherche:
481 results = results.add_to_query('@groupe_recherche ' + self.groupe_recherche)
482 if self.discipline:
483 results = results.filter_discipline(self.discipline)
484 if self.region:
485 results = results.filter_region(self.region)
486 if self.statut:
487 if self.statut == "expert":
488 results = results.filter_expert()
489 else:
490 results = results.filter_statut(self.statut)
491 if self.domaine:
492 results = results.filter_groupe(self.domaine)
5b55252d
PP
493 if self.groupe_chercheur:
494 results = results.filter_groupe(self.groupe_chercheur)
fdcf5874
EMS
495 if self.pays:
496 results = results.filter_pays(self.pays)
497 if self.nord_sud:
498 results = results.filter_nord_sud(self.nord_sud)
499 if self.genre:
500 results = results.filter_genre(self.genre)
501 if self.activites_francophonie == 'instance_auf':
502 results = results.filter(membre_instance_auf=True)
503 elif self.activites_francophonie == 'expert_oif':
504 results = results.filter(expert_oif=True)
505 elif self.activites_francophonie == 'association_francophone':
506 results = results.filter(membre_association_francophone=True)
507 elif self.activites_francophonie == 'reseau_institutionnel':
508 results = results.filter(membre_reseau_institutionnel=True)
4b89a7df
EMS
509 if min_date:
510 results = results.filter_date_modification(min=min_date)
511 if max_date:
512 results = results.filter_date_modification(max=max_date)
fdcf5874
EMS
513 return results.all()
514
515 def url(self):
516 qs = self.query_string()
517 return url('chercheurs') + ('?' + qs if qs else '')
da5bf7e9
EMS
518
519 def rss_url(self):
520 qs = self.query_string()
521 return url('rss_chercheurs') + ('?' + qs if qs else '')
4b89a7df
EMS
522
523 def get_email_alert_content(self, results):
524 content = ''
525 for chercheur in results:
526 content += u'- [%s %s](%s%s) \n' % (chercheur.nom.upper(),
527 chercheur.prenom,
528 settings.SITE_ROOT_URL,
529 chercheur.get_absolute_url())
530 content += u' %s\n\n' % chercheur.etablissement_display
531 return content
cdaadee3
PP
532
533class GroupeSearch(Search):
534
535 class Meta:
536 verbose_name = 'recherche de groupe'
537 verbose_name_plural = 'recherches de groupes'
538
539 def run(self):
540 results = Groupe.objects
541 if self.q:
542 results = results.search(self.q)
543 return results.all()
544
545 #def url(self):
546 # qs = self.query_string()
547 # return url('groupes') + ('?' + qs if qs else '')
548
549 #def rss_url(self):
550 # qs = self.query_string()
551 # return url('rss_groupes') + ('?' + qs if qs else '')
2048049e
PP
552
553class Message(models.Model):
554
555 chercheur = models.ForeignKey('Chercheur', db_column='chercheur')
556 groupe = models.ForeignKey('Groupe', db_column='groupe')
557 titre = models.CharField(max_length=255)
558 contenu = models.TextField()
559
fd6352ea 560 date_creation = models.DateTimeField(auto_now_add=True, db_column='date_creation')
2048049e 561
bf2904f0
PP
562 class Meta:
563 ordering = ['-date_creation']
564
2048049e
PP
565 def __unicode__(self):
566 return u"%s - %s" % (self.chercheur, self.titre)
c8d6b979 567
bf2904f0
PP
568 def get_absolute_url(self):
569 return url('groupe_messages', kwargs={'id': self.groupe.id})
570