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