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