1649: Ajouter wysiwyg pour la description d'une offre emploi
[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', 'region', '_candidatsList')
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 ('Coordonnées', {
100 'fields': ('telephone', 'email', 'adresse', 'ville',
101 'etat_province', 'code_postal', 'pays', )
102 }),
103 ('Informations professionnelles', {
104 'fields': ('niveau_diplome','employeur_actuel',
105 'poste_actuel', 'domaine_professionnel',)
106 }),
107 ('Options avancées', {
108 'classes': ('collapse',),
109 'fields': ('actif', 'statut', )
110 }),
111 )
112 inlines = [
113 CandidatPieceInline,
114 EvaluateurInline,
115 ]
116
117 actions = ['affecter_candidats_evaluateur']
118 # Affecter un évaluateurs à des candidats
119 def affecter_candidats_evaluateur(modeladmin, obj, candidats):
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 # Voir l'offre d'emploi
174 def voir_offre_emploi(self, obj):
175 return "<a href='%s?id=%s'>Voir l'offre d'emploi</a> \
176 " % (reverse('admin:recrutement_offreemploi_changelist'),
177 obj.offre_emploi.id)
178 voir_offre_emploi.allow_tags = True
179 voir_offre_emploi.short_description = "Offre d'emploi"
180
181 #Calculer la moyenne des notes
182 def calculer_moyenne(self, obj):
183 evaluations = CandidatEvaluation.objects.filter(candidat=obj)
184
185 notes = [evaluation.note for evaluation in evaluations.all() if evaluation.note is not None]
186 #import pdb;pdb.set_trace()
187 if len(notes) > 0:
188 moyenne_votes = float(sum(notes)) / len(notes)
189 else:
190 moyenne_votes = 0
191 return moyenne_votes
192 calculer_moyenne.allow_tags = True
193 calculer_moyenne.short_description = "Moyenne des notes"
194
195 class CandidatPieceAdmin(admin.ModelAdmin):
196 list_display = ('nom', 'candidat', )
197
198 def queryset(self, request):
199 """
200 Spécifie un queryset limité, autrement Django exécute un
201 select_related() sans paramètre, ce qui a pour effet de charger tous
202 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
203 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
204 génération d'une requête infinie.
205 Affiche la liste de candidats que si le user connecté
206 possède un UserProfile
207 """
208 qs = self.model._default_manager.get_query_set()
209 return qs.select_related('candidat')
210
211 class EvaluateurAdmin(VersionAdmin):
212 fieldsets = (
213 (None, {'fields': ('user', 'regions')}),
214 (None, {'fields': ('candidats',)}),
215 )
216
217 def get_form(self, request, obj=None, **kwargs):
218 """
219 Affiche la liste des users, regions et candidats, seulement si le user
220 connecté possède un UserProfile
221 """
222 form = super(EvaluateurAdmin, self).get_form(request, obj, **kwargs)
223 if form.declared_fields.has_key('user'):
224 permission_field = form.declared_fields['user']
225 else:
226 permission_field = form.base_fields['user']
227
228 if form.declared_fields.has_key('regions'):
229 region_field = form.declared_fields['regions']
230 else:
231 region_field = form.base_fields['regions']
232
233 if form.declared_fields.has_key('candidats'):
234 candidats_field = form.declared_fields['candidats']
235 else:
236 candidats_field = form.base_fields['candidats']
237
238 try:
239 user = UserProfile.objects.get(user=request.user)
240 except UserProfile.DoesNotExist:
241 region_field.queryset = Region.objects.none()
242 permission_field.queryset = UserProfile.objects.none()
243 candidats_field.queryset = Candidat.objects.none()
244 return form
245
246 return form
247
248 def queryset(self, request):
249 """
250 Affiche la liste d'évaluateur que si le user connecté
251 possède un UserProfile
252 """
253 qs = self.model._default_manager.get_query_set()
254 try:
255 user = UserProfile.objects.get(user=request.user)
256 except UserProfile.DoesNotExist:
257 return qs.none()
258
259 return qs
260
261 class CandidatEvaluationAdmin(VersionAdmin):
262 list_display = ('candidat', 'evaluateur', 'note', 'commentaire', 'date', )
263
264 def get_form(self, request, obj=None, **kwargs):
265 """
266 Affiche la liste des candidats et évaluateur, seulement si le user
267 connecté possède un UserProfile
268 """
269 form = super(CandidatEvaluationAdmin, self).get_form(request, obj,
270 **kwargs)
271 if form.declared_fields.has_key('evaluateur'):
272 evaluateur_field = form.declared_fields['evaluateur']
273 else:
274 evaluateur_field = form.base_fields['evaluateur']
275
276 if form.declared_fields.has_key('candidat'):
277 candidats_field = form.declared_fields['candidat']
278 else:
279 candidats_field = form.base_fields['candidat']
280
281 try:
282 user = UserProfile.objects.get(user=request.user)
283 except UserProfile.DoesNotExist:
284 evaluateur_field.queryset = UserProfile.objects.none()
285 candidats_field.queryset = Candidat.objects.none()
286 return form
287
288 return form
289
290 def queryset(self, request):
291 """
292 Affiche la liste d'évaluation que si le user connecté
293 possède un UserProfile
294 """
295 qs = self.model._default_manager.get_query_set()
296 try:
297 user = UserProfile.objects.get(user=request.user)
298 except UserProfile.DoesNotExist:
299 return qs.none()
300
301 return qs.select_related('candidat')
302
303 admin.site.register(OffreEmploi, OffreEmploiAdmin)
304 admin.site.register(Candidat, CandidatAdmin)
305 admin.site.register(CandidatEvaluation, CandidatEvaluationAdmin)
306 admin.site.register(UserProfile, EvaluateurAdmin)