3ff90492f354b7242a2fd11487da69dc83b901fc
[auf_rh_dae.git] / project / recrutement / admin.py
1 # -*- encoding: utf-8 -*-
2
3 from django.core.urlresolvers import reverse
4 from django.http import HttpResponseRedirect
5 from django.contrib import admin
6 from django.shortcuts import get_object_or_404
7
8 from reversion.admin import VersionAdmin
9 from datamaster_modeles.models import Employe, Implantation, Region
10
11 from recrutement.models import *
12
13 class OffreEmploiAdmin(VersionAdmin):
14 date_hierarchy = 'date_creation'
15 list_display = ('nom', 'resume', 'date_limite', '_candidatsList', 'region')
16
17 def _candidatsList(self, obj):
18 return "<a href='%s?offre_emploi__id__exact=%s'>Voir les candidats \
19 </a>" % (reverse('admin:recrutement_candidat_changelist'), obj.id)
20 _candidatsList.allow_tags = True
21 _candidatsList.short_description = "Liste des candidats"
22
23 def get_form(self, request, obj=None, **kwargs):
24 """
25 Affiche la liste des régions, seulement si le user
26 connecté possède un UserProfile
27 """
28 form = super(OffreEmploiAdmin, self).get_form(request, obj, **kwargs)
29 if form.declared_fields.has_key('region'):
30 region_field = form.declared_fields['region']
31 else:
32 region_field = form.base_fields['region']
33
34 try:
35 user = UserProfile.objects.get(user=request.user)
36 except UserProfile.DoesNotExist:
37 region_field.queryset = Region.objects.none()
38 return form
39
40 region_ids = [g.id for g in user.regions.all()]
41 region_field.queryset = Region.objects.filter(id__in=region_ids)
42 return form
43
44 def queryset(self, request):
45 """
46 N'affiche la liste de candidats que si le user connecté
47 possède un UserProfile
48 """
49 qs = self.model._default_manager.get_query_set()
50 try:
51 user = UserProfile.objects.get(user=request.user)
52 except UserProfile.DoesNotExist:
53 return qs.none()
54
55 region_ids = [g.id for g in user.regions.all()]
56 return qs.select_related('offre_emploi').filter(region__in=region_ids)
57
58 class ProxyCandidatPiece(CandidatPiece):
59 """
60 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
61 plus ergonomique.
62 """
63 class Meta:
64 proxy = True
65 verbose_name = "pièce jointe"
66 verbose_name_plural = "pièces jointes"
67
68 class CandidatPieceInline(admin.TabularInline):
69 model = ProxyCandidatPiece
70 fields = ('candidat', 'nom', 'path', )
71 extra = 1
72
73 class ProxyEvaluateur(UserProfile.candidats.through):
74 """
75 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
76 plus ergonomique.
77 """
78 class Meta:
79 proxy = True
80 verbose_name = "évaluateur"
81
82 class EvaluateurInline(admin.TabularInline):
83 model = ProxyEvaluateur
84 extra = 1
85
86 class CandidatAdmin(VersionAdmin):
87 date_hierarchy = 'date_creation'
88 list_display = ('nom', 'prenom', 'offre_emploi','statut',
89 'voir_offre_emploi', 'evaluer_candidat', 'calculer_moyenne')
90 list_filter = ('offre_emploi', )
91 fieldsets = (
92 ("Offre d'emploi", {
93 'fields': ('offre_emploi', )
94 }),
95 ('Informations personnelles', {
96 'fields': ('prenom','nom','genre', 'nationalite', 'date_naissance',
97 'situation_famille', 'nombre_dependant',)
98 }),
99 ('Adresse', {
100 'fields': ('adresse', 'ville', 'etat_province', 'pays', )
101 }),
102 ('Informations professionnelles', {
103 'fields': ('niveau_diplome','employeur_actuel',
104 'poste_actuel', 'domaine_professionnel',)
105 }),
106 ('Options avancées', {
107 'classes': ('collapse',),
108 'fields': ('actif', 'statut', )
109 }),
110 )
111 inlines = [
112 CandidatPieceInline,
113 EvaluateurInline,
114 ]
115
116 actions = ['affecter_candidats_evaluateur']
117 # Affecter un évaluateurs à des candidats
118 def affecter_candidats_evaluateur(modeladmin, obj, candidats):
119 selected = obj.POST.getlist(admin.ACTION_CHECKBOX_NAME)
120
121 return HttpResponseRedirect(reverse('affecter_evaluateurs_candidats')+
122 "?ids=%s" % (",".join(selected)))
123 affecter_candidats_evaluateur.short_description = u'Affecter évaluateur'
124
125 # Évaluer un candidat
126 def evaluer_candidat(self, obj):
127 return "<a href='%s?id=%s'>Évaluer le candidat \
128 </a>" % (reverse('evaluer_candidat'), obj.id)
129 evaluer_candidat.allow_tags = True
130 evaluer_candidat.short_description = 'Évaluer'
131
132 def get_form(self, request, obj=None, **kwargs):
133 """
134 Affiche la liste des offres d'emploi, seulement si le user
135 connecté possède un UserProfile
136 """
137 form = super(CandidatAdmin, self).get_form(request, obj, **kwargs)
138 if form.declared_fields.has_key('offre_emploi'):
139 region_field = form.declared_fields['offre_emploi']
140 else:
141 region_field = form.base_fields['offre_emploi']
142
143 try:
144 user = UserProfile.objects.get(user=request.user)
145 except UserProfile.DoesNotExist:
146 region_field.queryset = region_field.queryset.none()
147 return form
148
149 region_ids = [g.id for g in user.regions.all()]
150 region_field.queryset = OffreEmploi.objects.filter(region__in=region_ids)
151 return form
152
153 def queryset(self, obj):
154 """
155 Spécifie un queryset limité, autrement Django exécute un
156 select_related() sans paramètre, ce qui a pour effet de charger tous
157 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
158 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
159 génération d'une requête infinie.
160
161 """
162
163 qs = self.model._default_manager.get_query_set()
164 try:
165 user = UserProfile.objects.get(user=obj.user)
166 except UserProfile.DoesNotExist:
167 return qs.none()
168
169 ids = [c.id for c in user.candidats.all()]
170 return qs.select_related('candidats').filter(id__in=ids)
171
172 # Voir l'offre d'emploi
173 def voir_offre_emploi(self, obj):
174 return "<a href='%s?id=%s'>Voir l'offre d'emploi</a> \
175 " % (reverse('admin:recrutement_offreemploi_changelist'),
176 obj.offre_emploi.id)
177 voir_offre_emploi.allow_tags = True
178 voir_offre_emploi.short_description = "Offre d'emploi"
179
180 #Calculer la moyenne des notes
181 def calculer_moyenne(self, obj):
182 evaluations = CandidatEvaluation.objects.filter(candidat=obj)
183
184 notes = [evaluation.note for evaluation in evaluations.all() if evaluation.note is not None]
185 #import pdb;pdb.set_trace()
186 if len(notes) > 0:
187 moyenne_votes = float(sum(notes)) / len(notes)
188 else:
189 moyenne_votes = 0
190 return moyenne_votes
191 calculer_moyenne.allow_tags = True
192 calculer_moyenne.short_description = "Moyenne des notes"
193
194 class CandidatPieceAdmin(admin.ModelAdmin):
195 list_display = ('nom', 'candidat', )
196
197 def queryset(self, request):
198 """
199 Spécifie un queryset limité, autrement Django exécute un
200 select_related() sans paramètre, ce qui a pour effet de charger tous
201 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
202 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
203 génération d'une requête infinie.
204 Affiche la liste de candidats que si le user connecté
205 possède un UserProfile
206 """
207 qs = self.model._default_manager.get_query_set()
208 return qs.select_related('candidat')
209
210 class EvaluateurAdmin(VersionAdmin):
211 fieldsets = (
212 (None, {'fields': ('user', 'regions')}),
213 (None, {'fields': ('candidats',)}),
214 )
215
216 def get_form(self, request, obj=None, **kwargs):
217 """
218 Affiche la liste des users, regions et candidats, seulement si le user
219 connecté possède un UserProfile
220 """
221 form = super(EvaluateurAdmin, self).get_form(request, obj, **kwargs)
222 if form.declared_fields.has_key('user'):
223 permission_field = form.declared_fields['user']
224 else:
225 permission_field = form.base_fields['user']
226
227 if form.declared_fields.has_key('regions'):
228 region_field = form.declared_fields['regions']
229 else:
230 region_field = form.base_fields['regions']
231
232 if form.declared_fields.has_key('candidats'):
233 candidats_field = form.declared_fields['candidats']
234 else:
235 candidats_field = form.base_fields['candidats']
236
237 try:
238 user = UserProfile.objects.get(user=request.user)
239 except UserProfile.DoesNotExist:
240 region_field.queryset = Region.objects.none()
241 permission_field.queryset = UserProfile.objects.none()
242 candidats_field.queryset = Candidat.objects.none()
243 return form
244
245 return form
246
247 def queryset(self, request):
248 """
249 Affiche la liste d'évaluateur que si le user connecté
250 possède un UserProfile
251 """
252 qs = self.model._default_manager.get_query_set()
253 try:
254 user = UserProfile.objects.get(user=request.user)
255 except UserProfile.DoesNotExist:
256 return qs.none()
257
258 return qs
259
260 class CandidatEvaluationAdmin(VersionAdmin):
261 list_display = ('candidat', 'evaluateur', 'note', 'commentaire', 'date', )
262
263 def get_form(self, request, obj=None, **kwargs):
264 """
265 Affiche la liste des candidats et évaluateur, seulement si le user
266 connecté possède un UserProfile
267 """
268 form = super(CandidatEvaluationAdmin, self).get_form(request, obj,
269 **kwargs)
270 if form.declared_fields.has_key('evaluateur'):
271 evaluateur_field = form.declared_fields['evaluateur']
272 else:
273 evaluateur_field = form.base_fields['evaluateur']
274
275 if form.declared_fields.has_key('candidat'):
276 candidats_field = form.declared_fields['candidat']
277 else:
278 candidats_field = form.base_fields['candidat']
279
280 try:
281 user = UserProfile.objects.get(user=request.user)
282 except UserProfile.DoesNotExist:
283 evaluateur_field.queryset = UserProfile.objects.none()
284 candidats_field.queryset = Candidat.objects.none()
285 return form
286
287 return form
288
289 def queryset(self, request):
290 """
291 Affiche la liste d'évaluation que si le user connecté
292 possède un UserProfile
293 """
294 qs = self.model._default_manager.get_query_set()
295 try:
296 user = UserProfile.objects.get(user=request.user)
297 except UserProfile.DoesNotExist:
298 return qs.none()
299
300 return qs.select_related('candidat')
301
302 admin.site.register(OffreEmploi, OffreEmploiAdmin)
303 admin.site.register(Candidat, CandidatAdmin)
304 admin.site.register(UserProfile, EvaluateurAdmin)