Poste : liste dans admin + occupe_par() + is_vacant()
[auf_rh_dae.git] / project / recrutement / models.py
1 # -=- encoding: utf-8 -=-
2
3 import datetime
4 from django.contrib.auth.models import User
5 from django.core.files.storage import FileSystemStorage
6 from tinymce import models as tinymce_models
7 from django.db import models
8 import settings
9
10 from south.modelsinspector import add_introspection_rules
11 add_introspection_rules([], ["^tinymce.models.HTMLField"])
12 import datamaster_modeles.models as ref
13
14 from project.rh import models as rh
15 from recrutement.workflow import grp_evaluateurs_recrutement
16 from auf.django.emploi import models as emploi
17 from auf.django.emploi.models import TYPE_PIECE_CHOICES
18
19 from recrutement.workflow import grp_evaluateurs_recrutement
20
21 ### CONSTANTES
22 #NOTES
23 NOTE_MIN = 1
24 NOTE_RANGE = 1
25 NOTE_MAX = 11
26 NOTES = [(i, i) for i in range(NOTE_MIN, NOTE_MAX, NOTE_RANGE)]
27
28 #HELP_TEXT
29 HELP_TEXT_NB_DEPENDANT = "Le nombre de personnes à charge"
30 HELP_TEXT_TAGS_ACCEPTES = "Pour le texte, les variables disponibles sont : \
31 {{ nom_candidat }} {{ prenom_candidat }} \
32 {{ offre_emploi }} et {{ genre_candidat }} \
33 (Pour Monsieur/Madame). Ces champs seront \
34 automatiquement remplacés par les informations de \
35 chaque candidat."
36
37 # Abstracts
38 class Metadata(models.Model):
39 """Méta-données AUF.
40 Metadata.actif = flag remplaçant la suppression.
41 actif == False : objet réputé supprimé.
42 """
43 actif = models.BooleanField(default=True)
44 date_creation = models.DateField(auto_now_add=True, )
45
46 class Meta:
47 abstract = True
48
49 class Candidat(emploi.Candidat):
50 class Meta:
51 proxy = True
52
53 def moyenne_notes(self):
54 evaluations = CandidatEvaluation.objects.filter(candidat=self)
55 notes = [evaluation.note for evaluation in evaluations.all() \
56 if evaluation.note is not None]
57
58 if len(notes) > 0:
59 moyenne_votes = float(sum(notes)) / len(notes)
60 else:
61 moyenne_votes = "Non disponible"
62 return moyenne_votes
63
64 class OffreEmploi(emploi.OffreEmploi):
65 class Meta:
66 proxy = True
67
68
69 class CandidatPiece(emploi.CandidatPiece):
70 class Meta:
71 proxy = True
72
73 class OffreEmploiManager(models.Manager):
74 def get_query_set(self):
75 fkeys = ('region',)
76 return super(OffreEmploiManager, self).get_query_set().\
77 select_related(*fkeys).all()
78
79 class ProxyOffreEmploi(emploi.OffreEmploi):
80 class Meta:
81 proxy = True
82 verbose_name = u"Offre d'emploi (visualisation)"
83 verbose_name_plural = u"Offres d'emploi (visualisation)"
84
85 def __unicode__(self):
86 return '%s [%s] - View' % (self.nom, self.id)
87
88 class ProxyCandidat(emploi.Candidat):
89 class Meta:
90 proxy = True
91 verbose_name = u"Candidat (visualisation)"
92 verbose_name_plural = u"Candidats (visualisation)"
93
94 def __unicode__(self):
95 return '%s %s [%s]' % (self.prenom, self.nom, self.id)
96
97 class Evaluateur(models.Model):
98 user = models.ForeignKey(User, unique=True, verbose_name=u"Évaluateur")
99 offres_emploi = models.ManyToManyField(emploi.OffreEmploi,
100 related_name="evaluateurs", blank=True)
101
102 def save(self, *args, **kwargs):
103 """
104 Assigner automatiquement l'évaluateurs d'une offre d'emploi à un
105 nouveau candidat.
106 """
107 self.user.groups.add(grp_evaluateurs_recrutement)
108 super(Evaluateur, self).save(*args, **kwargs)
109
110 class Meta:
111 verbose_name = u"évaluateur"
112
113 def __unicode__(self):
114 return '%s %s' % (self.user.first_name, self.user.last_name)
115
116 class CandidatEvaluation(models.Model):
117 candidat = models.ForeignKey(emploi.Candidat, db_column='candidat',
118 related_name='+',)
119 evaluateur = models.ForeignKey(Evaluateur, db_column='evaluateur',
120 related_name='+', verbose_name=u'Évaluateur')
121 note = models.IntegerField(choices=NOTES, blank=True, null=True)
122 commentaire = models.TextField(null=True, blank=True, default='Aucun')
123 date = models.DateField(auto_now_add=True,)
124
125 class Meta:
126 verbose_name = u'évaluation du candidat'
127 verbose_name_plural = u'évaluations des candidats'
128
129 def __unicode__(self):
130 return u"Évaluation de %s" % self.candidat
131
132 #### TEMPLATE COURRIEL
133 TEMPLATE_CHOICES = (
134 ('SEL', 'Sélectionné'),
135 ('REF', 'Refusé'),
136 )
137
138 class CourrielTemplate(models.Model):
139 nom_modele = models.CharField(max_length=100, verbose_name=u'Nom du modèle',)
140 sujet = models.CharField(max_length=100, verbose_name=u'Sujet du courriel')
141 plain_text = models.TextField(verbose_name=u'Texte',
142 help_text=HELP_TEXT_TAGS_ACCEPTES, )
143 html = tinymce_models.HTMLField(verbose_name=u'Texte en HTML',
144 help_text=HELP_TEXT_TAGS_ACCEPTES, )
145
146
147 def __unicode__(self):
148 return u'%s' % self.nom_modele
149
150 class Meta:
151 ordering = ['nom_modele',]
152 verbose_name = "Modèle de courriel"
153 verbose_name_plural = "Modèles de courriel"
154
155 class CandidatCourriel(models.Model):
156 candidats = models.ManyToManyField(Candidat, verbose_name=u"Candidats", )
157 template = models.ForeignKey(CourrielTemplate, db_column='template',
158 related_name='+', verbose_name=u"Modèle de courriel", )
159 sujet = models.CharField(max_length=255, blank=True,
160 help_text=HELP_TEXT_TAGS_ACCEPTES, )
161 plain_text = models.TextField(verbose_name=u'Texte', blank=True,
162 help_text=HELP_TEXT_TAGS_ACCEPTES, )
163 html = tinymce_models.HTMLField(verbose_name=u'Texte en HTML', null=True,
164 blank=True, help_text=HELP_TEXT_TAGS_ACCEPTES, )
165
166 def __unicode__(self):
167 return '%s' % (self.titre)
168
169 class Meta:
170 verbose_name = u"modèle de courriel"
171 verbose_name_plural = u"modèles de courriel"