721748c1942e70dd471a6681b15598f10c5def8e
[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', '_actions',
89 'evaluer_candidat', )
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', 'evaluer_plusieurs_candidats']
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 plusieurs candidats
126 def evaluer_plusieurs_candidats(modeladmin, obj, candidats):
127 selected = obj.POST.getlist(admin.ACTION_CHECKBOX_NAME)
128
129 return HttpResponseRedirect(reverse('evaluer_candidats')+
130 "?ids=%s" % (",".join(selected)))
131 evaluer_plusieurs_candidats.short_description = u'Évaluer plusieurs \
132 candidats'
133
134 # Évaluer un candidat
135 def evaluer_candidat(self, obj):
136 return "<a href='%s?id=%s'>Évaluer le candidat \
137 </a>" % (reverse('evaluer_candidat'), obj.id)
138 evaluer_candidat.allow_tags = True
139 evaluer_candidat.short_description = 'Évaluer'
140
141 def get_form(self, request, obj=None, **kwargs):
142 """
143 Affiche la liste des offres d'emploi, seulement si le user
144 connecté possède un UserProfile
145 """
146 form = super(CandidatAdmin, self).get_form(request, obj, **kwargs)
147 if form.declared_fields.has_key('offre_emploi'):
148 region_field = form.declared_fields['offre_emploi']
149 else:
150 region_field = form.base_fields['offre_emploi']
151
152 try:
153 user = UserProfile.objects.get(user=request.user)
154 except UserProfile.DoesNotExist:
155 region_field.queryset = region_field.queryset.none()
156 return form
157
158 region_ids = [g.id for g in user.regions.all()]
159 region_field.queryset = OffreEmploi.objects.filter(region__in=region_ids)
160 return form
161
162 def queryset(self, obj):
163 """
164 Spécifie un queryset limité, autrement Django exécute un
165 select_related() sans paramètre, ce qui a pour effet de charger tous
166 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
167 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
168 génération d'une requête infinie.
169
170 """
171
172 qs = self.model._default_manager.get_query_set()
173 try:
174 user = UserProfile.objects.get(user=obj.user)
175 except UserProfile.DoesNotExist:
176 return qs.none()
177
178 ids = [c.id for c in user.candidats.all()]
179 return qs.select_related('candidats').filter(id__in=ids)
180
181 def _actions(self, obj):
182 return "<a href='%s?id=%s'>Voir l'offre d'emploi</a> \
183 " % (reverse('admin:recrutement_offreemploi_changelist'),
184 obj.offre_emploi.id)
185 _actions.allow_tags = True
186 _actions.short_description = "Offre d'emploi"
187
188 class CandidatPieceAdmin(admin.ModelAdmin):
189 list_display = ('nom', 'candidat', )
190
191 def queryset(self, request):
192 """
193 Spécifie un queryset limité, autrement Django exécute un
194 select_related() sans paramètre, ce qui a pour effet de charger tous
195 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
196 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
197 génération d'une requête infinie.
198 Affiche la liste de candidats que si le user connecté
199 possède un UserProfile
200 """
201 qs = self.model._default_manager.get_query_set()
202 return qs.select_related('candidat')
203
204 class EvaluateurAdmin(VersionAdmin):
205 fieldsets = (
206 (None, {'fields': ('user', 'regions')}),
207 (None, {'fields': ('candidats',)}),
208 )
209
210 def get_form(self, request, obj=None, **kwargs):
211 """
212 Affiche la liste des users, regions et candidats, seulement si le user
213 connecté possède un UserProfile
214 """
215 form = super(EvaluateurAdmin, self).get_form(request, obj, **kwargs)
216 if form.declared_fields.has_key('user'):
217 permission_field = form.declared_fields['user']
218 else:
219 permission_field = form.base_fields['user']
220
221 if form.declared_fields.has_key('regions'):
222 region_field = form.declared_fields['regions']
223 else:
224 region_field = form.base_fields['regions']
225
226 if form.declared_fields.has_key('candidats'):
227 candidats_field = form.declared_fields['candidats']
228 else:
229 candidats_field = form.base_fields['candidats']
230
231 try:
232 user = UserProfile.objects.get(user=request.user)
233 except UserProfile.DoesNotExist:
234 region_field.queryset = Region.objects.none()
235 permission_field.queryset = UserProfile.objects.none()
236 candidats_field.queryset = Candidat.objects.none()
237 return form
238
239 return form
240
241 def queryset(self, request):
242 """
243 Affiche la liste d'évaluateur que si le user connecté
244 possède un UserProfile
245 """
246 qs = self.model._default_manager.get_query_set()
247 try:
248 user = UserProfile.objects.get(user=request.user)
249 except UserProfile.DoesNotExist:
250 return qs.none()
251
252 return qs
253
254 class CandidatEvaluationAdmin(VersionAdmin):
255 list_display = ('candidat', 'evaluateur', 'note', 'commentaire', 'date', )
256
257 def get_form(self, request, obj=None, **kwargs):
258 """
259 Affiche la liste des candidats et évaluateur, seulement si le user
260 connecté possède un UserProfile
261 """
262 form = super(CandidatEvaluationAdmin, self).get_form(request, obj,
263 **kwargs)
264 if form.declared_fields.has_key('evaluateur'):
265 evaluateur_field = form.declared_fields['evaluateur']
266 else:
267 evaluateur_field = form.base_fields['evaluateur']
268
269 if form.declared_fields.has_key('candidat'):
270 candidats_field = form.declared_fields['candidat']
271 else:
272 candidats_field = form.base_fields['candidat']
273
274 try:
275 user = UserProfile.objects.get(user=request.user)
276 except UserProfile.DoesNotExist:
277 evaluateur_field.queryset = UserProfile.objects.none()
278 candidats_field.queryset = Candidat.objects.none()
279 return form
280
281 return form
282
283 def queryset(self, request):
284 """
285 Affiche la liste d'évaluation que si le user connecté
286 possède un UserProfile
287 """
288 qs = self.model._default_manager.get_query_set()
289 try:
290 user = UserProfile.objects.get(user=request.user)
291 except UserProfile.DoesNotExist:
292 return qs.none()
293
294 return qs.select_related('candidat')
295
296 admin.site.register(OffreEmploi, OffreEmploiAdmin)
297 admin.site.register(Candidat, CandidatAdmin)
298 admin.site.register(CandidatEvaluation, CandidatEvaluationAdmin)
299 admin.site.register(UserProfile, EvaluateurAdmin)