360e376cbb7a460cd85eea40dd10e2b6edae80b2
[auf_rh_dae.git] / project / recrutement / models.py
1 # -=- encoding: utf-8 -=-
2
3 from auf.django.emploi import models as emploi
4 from django.contrib.auth.models import User
5 from django.db import models
6 from django.db.models.signals import pre_save, pre_delete
7 from django.dispatch import receiver
8 from south.modelsinspector import add_introspection_rules
9 from tinymce import models as tinymce_models
10
11 from project.recrutement.groups import grp_evaluateurs
12
13 ### CONSTANTES
14
15 #NOTES
16 NOTE_MIN = 1
17 NOTE_RANGE = 1
18 NOTE_MAX = 11
19 NOTES = [(i, i) for i in range(NOTE_MIN, NOTE_MAX, NOTE_RANGE)]
20
21 #HELP_TEXT
22 HELP_TEXT_NB_DEPENDANT = "Le nombre de personnes à charge"
23 HELP_TEXT_TAGS_ACCEPTES = "Pour le texte, les variables disponibles sont : \
24 {{ nom_candidat }} {{ prenom_candidat }} \
25 {{ offre_emploi }} et {{ genre_candidat }} \
26 (Pour Monsieur/Madame). Ces champs seront \
27 automatiquement remplacés par les informations de \
28 chaque candidat."
29
30 # Pour South
31 add_introspection_rules([], ["^tinymce.models.HTMLField"])
32
33
34 class Candidat(emploi.Candidat):
35
36 class Meta:
37 proxy = True
38
39 def moyenne_notes(self):
40 evaluations = CandidatEvaluation.objects.filter(candidat=self)
41 notes = [evaluation.note for evaluation in evaluations.all() \
42 if evaluation.note is not None]
43
44 if len(notes) > 0:
45 moyenne_votes = float(sum(notes)) / len(notes)
46 else:
47 moyenne_votes = "Non disponible"
48 return moyenne_votes
49
50
51 class OffreEmploiManager(models.Manager):
52
53 def get_query_set(self):
54 fkeys = ('region',)
55 return super(OffreEmploiManager, self).get_query_set().\
56 select_related(*fkeys).all()
57
58
59 class ProxyOffreEmploi(emploi.OffreEmploi):
60
61 class Meta:
62 proxy = True
63 verbose_name = u"offre d'emploi (visualisation)"
64 verbose_name_plural = u"offres d'emploi (visualisation)"
65
66 def __unicode__(self):
67 return '%s [%s] - View' % (self.nom, self.id)
68
69
70 class ProxyCandidat(emploi.Candidat):
71
72 class Meta:
73 proxy = True
74 verbose_name = u"candidat (visualisation)"
75 verbose_name_plural = u"candidats (visualisation)"
76
77 def __unicode__(self):
78 return '%s %s [%s]' % (self.prenom, self.nom, self.id)
79
80
81 class Evaluateur(models.Model):
82 user = models.ForeignKey(User, unique=True, verbose_name=u"évaluateur")
83
84 class Meta:
85 verbose_name = u"évaluateur"
86
87 def __unicode__(self):
88 return '%s %s' % (self.user.first_name, self.user.last_name)
89
90
91 # Synchro des objets évaluateurs pour mettre les users Django dans le groupe
92 # évaluateurs, afin d'y mettre des permissions
93 @receiver(pre_save, sender=Evaluateur)
94 def sync_add_groupe_evaluateur(sender, **kwargs):
95 instance = kwargs['instance']
96 if grp_evaluateurs not in instance.user.groups.all():
97 instance.user.groups.add(grp_evaluateurs)
98 instance.user.save()
99
100
101 @receiver(pre_delete, sender=Evaluateur)
102 def sync_delete_groupe_evaluateur(sender, **kwargs):
103 instance = kwargs['instance']
104 instance.user.groups.remove(grp_evaluateurs)
105 instance.user.save()
106
107
108 class CandidatEvaluation(models.Model):
109 candidat = models.ForeignKey(emploi.Candidat, db_column='candidat',
110 related_name='evaluations',)
111 evaluateur = models.ForeignKey(Evaluateur, db_column='evaluateur',
112 related_name='+', verbose_name=u'évaluateur')
113 note = models.IntegerField(choices=NOTES, blank=True, null=True)
114 commentaire = models.TextField(null=True, blank=True, default='Aucun')
115 date = models.DateField(auto_now_add=True,)
116
117 class Meta:
118 verbose_name = u'évaluation du candidat'
119 verbose_name_plural = u'évaluations des candidats'
120
121 def __unicode__(self):
122 return u"Évaluation de %s" % self.candidat
123
124 def get_appreciation(self,):
125 if self.note is None:
126 return u"non disponible"
127 return u"%s %s" % (self.note, self.commentaire,)
128
129
130 class MesCandidatEvaluation(CandidatEvaluation):
131
132 class Meta:
133 proxy = True
134 verbose_name = u"mon candidat à évaluer"
135 verbose_name_plural = u"mes candidats à évaluer"
136
137
138 #### TEMPLATE COURRIEL
139 TEMPLATE_CHOICES = (
140 ('SEL', 'Sélectionné'),
141 ('REF', 'Refusé'),
142 )
143
144
145 class CourrielTemplate(models.Model):
146 nom_modele = models.CharField(u'nom du modèle', max_length=100)
147 sujet = models.CharField(u'sujet du courriel', max_length=100)
148 plain_text = models.TextField(u'texte', help_text=HELP_TEXT_TAGS_ACCEPTES)
149
150 def __unicode__(self):
151 return self.nom_modele
152
153 class Meta:
154 ordering = ('nom_modele',)
155 verbose_name = u"modèle de courriel"
156 verbose_name_plural = u"modèles de courriel"
157
158
159 class CandidatCourriel(models.Model):
160 candidats = models.ManyToManyField(Candidat, verbose_name=u"candidats")
161 template = models.ForeignKey(
162 CourrielTemplate, db_column='template', related_name='+',
163 verbose_name=u"modèle de courriel"
164 )
165 sujet = models.CharField(
166 max_length=255, blank=True, help_text=HELP_TEXT_TAGS_ACCEPTES
167 )
168 plain_text = models.TextField(
169 u'texte', blank=True, help_text=HELP_TEXT_TAGS_ACCEPTES
170 )
171 html = tinymce_models.HTMLField(
172 verbose_name=u'texte en HTML', null=True, blank=True,
173 help_text=HELP_TEXT_TAGS_ACCEPTES
174 )
175
176 def __unicode__(self):
177 return self.titre
178
179 class Meta:
180 verbose_name = u"modèle de courriel"
181 verbose_name_plural = u"modèles de courriel"