1 # -*- encoding: utf-8 -*-
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
8 from reversion
.admin
import VersionAdmin
9 from datamaster_modeles
.models
import Employe
, Implantation
, Region
11 from recrutement
.models
import *
13 class OffreEmploiAdmin(VersionAdmin
):
14 date_hierarchy
= 'date_creation'
15 list_display
= ('nom', 'resume', 'date_limite', 'region', '_candidatsList')
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"
24 def get_form(self
, request
, obj
=None, **kwargs
):
26 Affiche la liste des régions, seulement si le user
27 connecté possède un UserProfile
29 form
= super(OffreEmploiAdmin
, self
).get_form(request
, obj
, **kwargs
)
30 if form
.declared_fields
.has_key('region'):
31 region_field
= form
.declared_fields
['region']
33 region_field
= form
.base_fields
['region']
36 user
= UserProfile
.objects
.get(user
=request
.user
)
37 except UserProfile
.DoesNotExist
:
38 region_field
.queryset
= Region
.objects
.none()
41 region_ids
= [g
.id for g
in user
.regions
.all()]
42 region_field
.queryset
= Region
.objects
.filter(id__in
=region_ids
)
45 def queryset(self
, request
):
47 N'affiche la liste de candidats que si le user connecté
48 possède un UserProfile
50 qs
= self
.model
._default_manager
.get_query_set()
52 user
= UserProfile
.objects
.get(user
=request
.user
)
53 except UserProfile
.DoesNotExist
:
56 region_ids
= [g
.id for g
in user
.regions
.all()]
57 return qs
.select_related('offre_emploi').filter(region__in
=region_ids
)
59 class ProxyCandidatPiece(CandidatPiece
):
61 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
66 verbose_name
= "pièce jointe"
67 verbose_name_plural
= "pièces jointes"
69 class CandidatPieceInline(admin
.TabularInline
):
70 model
= ProxyCandidatPiece
71 fields
= ('candidat', 'nom', 'path', )
74 class ProxyEvaluateur(UserProfile
.candidats
.through
):
76 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
81 verbose_name
= "évaluateur"
83 class EvaluateurInline(admin
.TabularInline
):
84 model
= ProxyEvaluateur
87 class CandidatAdmin(VersionAdmin
):
88 date_hierarchy
= 'date_creation'
89 list_display
= ('nom', 'prenom', 'offre_emploi','statut',
90 'voir_offre_emploi', 'evaluer_candidat', 'calculer_moyenne',
92 list_filter
= ('offre_emploi', )
95 'fields': ('offre_emploi', )
97 ('Informations personnelles', {
98 'fields': ('prenom','nom','genre', 'nationalite', 'date_naissance',
99 'situation_famille', 'nombre_dependant',)
102 'fields': ('telephone', 'email', 'adresse', 'ville',
103 'etat_province', 'code_postal', 'pays', )
105 ('Informations professionnelles', {
106 'fields': ('niveau_diplome','employeur_actuel',
107 'poste_actuel', 'domaine_professionnel',)
109 ('Options avancées', {
110 'classes': ('collapse',),
111 'fields': ('actif', 'statut', )
119 actions
= ['affecter_candidats_evaluateur']
120 # Affecter un évaluateurs à des candidats
121 def affecter_candidats_evaluateur(modeladmin
, obj
, candidats
):
122 selected
= obj
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
124 return HttpResponseRedirect(reverse('affecter_evaluateurs_candidats')+
125 "?ids=%s" % (",".join(selected
)))
126 affecter_candidats_evaluateur
.short_description
= u
'Affecter évaluateur'
128 # Évaluer un candidat
129 def evaluer_candidat(self
, obj
):
130 return "<a href='%s?id=%s'>Évaluer le candidat \
131 </a>" % (reverse('evaluer_candidat'), obj
.id)
132 evaluer_candidat
.allow_tags
= True
133 evaluer_candidat
.short_description
= 'Évaluer'
135 # Afficher un candidat
136 def afficher_candidat(self
, obj
):
137 return "<a href='%s?id=%s'>Voir le candidat \
138 </a>" % (reverse('afficher_candidat'), obj
.id)
139 afficher_candidat
.allow_tags
= True
140 afficher_candidat
.short_description
= u
'Afficher les détails'
142 def get_form(self
, request
, obj
=None, **kwargs
):
144 Affiche la liste des offres d'emploi, seulement si le user
145 connecté possède un UserProfile
147 form
= super(CandidatAdmin
, self
).get_form(request
, obj
, **kwargs
)
148 if form
.declared_fields
.has_key('offre_emploi'):
149 region_field
= form
.declared_fields
['offre_emploi']
151 region_field
= form
.base_fields
['offre_emploi']
154 user
= UserProfile
.objects
.get(user
=request
.user
)
155 except UserProfile
.DoesNotExist
:
156 region_field
.queryset
= region_field
.queryset
.none()
159 region_ids
= [g
.id for g
in user
.regions
.all()]
160 region_field
.queryset
= OffreEmploi
.objects
.filter(region__in
=region_ids
)
163 def queryset(self
, obj
):
165 Spécifie un queryset limité, autrement Django exécute un
166 select_related() sans paramètre, ce qui a pour effet de charger tous
167 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
168 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
169 génération d'une requête infinie.
173 qs
= self
.model
._default_manager
.get_query_set()
175 user
= UserProfile
.objects
.get(user
=obj
.user
)
176 except UserProfile
.DoesNotExist
:
179 ids
= [c
.id for c
in user
.candidats
.all()]
180 return qs
.select_related('candidats').filter(id__in
=ids
)
182 # Voir l'offre d'emploi
183 def voir_offre_emploi(self
, obj
):
184 return "<a href='%s?id=%s'>Voir l'offre d'emploi</a> \
185 " % (reverse('admin:recrutement_offreemploi_changelist'),
187 voir_offre_emploi
.allow_tags
= True
188 voir_offre_emploi
.short_description
= "Afficher l'offre d'emploi"
190 #Calculer la moyenne des notes
191 def calculer_moyenne(self
, obj
):
192 evaluations
= CandidatEvaluation
.objects
.filter(candidat
=obj
)
193 offre_emploi
= obj
.offre_emploi
195 notes
= [evaluation
.note
for evaluation
in evaluations
.all() if evaluation
.note
is not None]
197 if len(notes
) > 0 and offre_emploi
.date_limite
<= datetime
.date
.today():
198 moyenne_votes
= float(sum(notes
)) / len(notes
)
200 moyenne_votes
= "Non disponible"
202 calculer_moyenne
.allow_tags
= True
203 calculer_moyenne
.short_description
= "Moyenne des notes"
205 class CandidatPieceAdmin(admin
.ModelAdmin
):
206 list_display
= ('nom', 'candidat', )
208 def queryset(self
, request
):
210 Spécifie un queryset limité, autrement Django exécute un
211 select_related() sans paramètre, ce qui a pour effet de charger tous
212 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
213 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
214 génération d'une requête infinie.
215 Affiche la liste de candidats que si le user connecté
216 possède un UserProfile
218 qs
= self
.model
._default_manager
.get_query_set()
219 return qs
.select_related('candidat')
221 class EvaluateurAdmin(VersionAdmin
):
223 (None, {'fields': ('user', 'regions')}),
224 (None, {'fields': ('candidats',)}),
227 def get_form(self
, request
, obj
=None, **kwargs
):
229 Affiche la liste des users, regions et candidats, seulement si le user
230 connecté possède un UserProfile
232 form
= super(EvaluateurAdmin
, self
).get_form(request
, obj
, **kwargs
)
233 if form
.declared_fields
.has_key('user'):
234 permission_field
= form
.declared_fields
['user']
236 permission_field
= form
.base_fields
['user']
238 if form
.declared_fields
.has_key('regions'):
239 region_field
= form
.declared_fields
['regions']
241 region_field
= form
.base_fields
['regions']
243 if form
.declared_fields
.has_key('candidats'):
244 candidats_field
= form
.declared_fields
['candidats']
246 candidats_field
= form
.base_fields
['candidats']
249 user
= UserProfile
.objects
.get(user
=request
.user
)
250 except UserProfile
.DoesNotExist
:
251 region_field
.queryset
= Region
.objects
.none()
252 permission_field
.queryset
= UserProfile
.objects
.none()
253 candidats_field
.queryset
= Candidat
.objects
.none()
258 def queryset(self
, request
):
260 Affiche la liste d'évaluateur que si le user connecté
261 possède un UserProfile
263 qs
= self
.model
._default_manager
.get_query_set()
265 user
= UserProfile
.objects
.get(user
=request
.user
)
266 except UserProfile
.DoesNotExist
:
271 class CandidatEvaluationAdmin(VersionAdmin
):
272 list_display
= ('candidat', 'evaluateur', 'note', 'commentaire', 'date', )
274 def get_form(self
, request
, obj
=None, **kwargs
):
276 Affiche la liste des candidats et évaluateur, seulement si le user
277 connecté possède un UserProfile
279 form
= super(CandidatEvaluationAdmin
, self
).get_form(request
, obj
,
281 if form
.declared_fields
.has_key('evaluateur'):
282 evaluateur_field
= form
.declared_fields
['evaluateur']
284 evaluateur_field
= form
.base_fields
['evaluateur']
286 if form
.declared_fields
.has_key('candidat'):
287 candidats_field
= form
.declared_fields
['candidat']
289 candidats_field
= form
.base_fields
['candidat']
292 user
= UserProfile
.objects
.get(user
=request
.user
)
293 except UserProfile
.DoesNotExist
:
294 evaluateur_field
.queryset
= UserProfile
.objects
.none()
295 candidats_field
.queryset
= Candidat
.objects
.none()
300 def queryset(self
, request
):
302 Affiche la liste d'évaluation que si le user connecté
303 possède un UserProfile
305 qs
= self
.model
._default_manager
.get_query_set()
307 user
= UserProfile
.objects
.get(user
=request
.user
)
308 except UserProfile
.DoesNotExist
:
311 return qs
.select_related('candidat')
313 admin
.site
.register(OffreEmploi
, OffreEmploiAdmin
)
314 admin
.site
.register(Candidat
, CandidatAdmin
)
315 admin
.site
.register(CandidatEvaluation
, CandidatEvaluationAdmin
)
316 admin
.site
.register(UserProfile
, EvaluateurAdmin
)