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', '_candidatsList', 'region')
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"
23 def get_form(self
, request
, obj
=None, **kwargs
):
25 Affiche la liste des régions, seulement si le user
26 connecté possède un UserProfile
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']
32 region_field
= form
.base_fields
['region']
35 user
= UserProfile
.objects
.get(user
=request
.user
)
36 except UserProfile
.DoesNotExist
:
37 region_field
.queryset
= Region
.objects
.none()
40 region_ids
= [g
.id for g
in user
.regions
.all()]
41 region_field
.queryset
= Region
.objects
.filter(id__in
=region_ids
)
44 def queryset(self
, request
):
46 N'affiche la liste de candidats que si le user connecté
47 possède un UserProfile
49 qs
= self
.model
._default_manager
.get_query_set()
51 user
= UserProfile
.objects
.get(user
=request
.user
)
52 except UserProfile
.DoesNotExist
:
55 region_ids
= [g
.id for g
in user
.regions
.all()]
56 return qs
.select_related('offre_emploi').filter(region__in
=region_ids
)
58 class ProxyCandidatPiece(CandidatPiece
):
60 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
65 verbose_name
= "pièce jointe"
66 verbose_name_plural
= "pièces jointes"
68 class CandidatPieceInline(admin
.TabularInline
):
69 model
= ProxyCandidatPiece
70 fields
= ('candidat', 'nom', 'path', )
73 class ProxyEvaluateur(UserProfile
.candidats
.through
):
75 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
80 verbose_name
= "évaluateur"
82 class EvaluateurInline(admin
.TabularInline
):
83 model
= ProxyEvaluateur
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', )
93 'fields': ('offre_emploi', )
95 ('Informations personnelles', {
96 'fields': ('prenom','nom','genre', 'nationalite', 'date_naissance',
97 'situation_famille', 'nombre_dependant',)
100 'fields': ('adresse', 'ville', 'etat_province', 'pays', )
102 ('Informations professionnelles', {
103 'fields': ('niveau_diplome','employeur_actuel',
104 'poste_actuel', 'domaine_professionnel',)
106 ('Options avancées', {
107 'classes': ('collapse',),
108 'fields': ('actif', 'statut', )
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
)
121 return HttpResponseRedirect(reverse('affecter_evaluateurs_candidats')+
122 "?ids=%s" % (",".join(selected
)))
123 affecter_candidats_evaluateur
.short_description
= u
'Affecter évaluateur'
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'
132 def get_form(self
, request
, obj
=None, **kwargs
):
134 Affiche la liste des offres d'emploi, seulement si le user
135 connecté possède un UserProfile
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']
141 region_field
= form
.base_fields
['offre_emploi']
144 user
= UserProfile
.objects
.get(user
=request
.user
)
145 except UserProfile
.DoesNotExist
:
146 region_field
.queryset
= region_field
.queryset
.none()
149 region_ids
= [g
.id for g
in user
.regions
.all()]
150 region_field
.queryset
= OffreEmploi
.objects
.filter(region__in
=region_ids
)
153 def queryset(self
, obj
):
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.
163 qs
= self
.model
._default_manager
.get_query_set()
165 user
= UserProfile
.objects
.get(user
=obj
.user
)
166 except UserProfile
.DoesNotExist
:
169 ids
= [c
.id for c
in user
.candidats
.all()]
170 return qs
.select_related('candidats').filter(id__in
=ids
)
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'),
177 voir_offre_emploi
.allow_tags
= True
178 voir_offre_emploi
.short_description
= "Offre d'emploi"
180 #Calculer la moyenne des notes
181 def calculer_moyenne(self
, obj
):
182 evaluations
= CandidatEvaluation
.objects
.filter(candidat
=obj
)
184 notes
= [evaluation
.note
for evaluation
in evaluations
.all() if evaluation
.note
is not None]
185 #import pdb;pdb.set_trace()
187 moyenne_votes
= float(sum(notes
)) / len(notes
)
191 calculer_moyenne
.allow_tags
= True
192 calculer_moyenne
.short_description
= "Moyenne des notes"
194 class CandidatPieceAdmin(admin
.ModelAdmin
):
195 list_display
= ('nom', 'candidat', )
197 def queryset(self
, request
):
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
207 qs
= self
.model
._default_manager
.get_query_set()
208 return qs
.select_related('candidat')
210 class EvaluateurAdmin(VersionAdmin
):
212 (None, {'fields': ('user', 'regions')}),
213 (None, {'fields': ('candidats',)}),
216 def get_form(self
, request
, obj
=None, **kwargs
):
218 Affiche la liste des users, regions et candidats, seulement si le user
219 connecté possède un UserProfile
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']
225 permission_field
= form
.base_fields
['user']
227 if form
.declared_fields
.has_key('regions'):
228 region_field
= form
.declared_fields
['regions']
230 region_field
= form
.base_fields
['regions']
232 if form
.declared_fields
.has_key('candidats'):
233 candidats_field
= form
.declared_fields
['candidats']
235 candidats_field
= form
.base_fields
['candidats']
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()
247 def queryset(self
, request
):
249 Affiche la liste d'évaluateur que si le user connecté
250 possède un UserProfile
252 qs
= self
.model
._default_manager
.get_query_set()
254 user
= UserProfile
.objects
.get(user
=request
.user
)
255 except UserProfile
.DoesNotExist
:
260 class CandidatEvaluationAdmin(VersionAdmin
):
261 list_display
= ('candidat', 'evaluateur', 'note', 'commentaire', 'date', )
263 def get_form(self
, request
, obj
=None, **kwargs
):
265 Affiche la liste des candidats et évaluateur, seulement si le user
266 connecté possède un UserProfile
268 form
= super(CandidatEvaluationAdmin
, self
).get_form(request
, obj
,
270 if form
.declared_fields
.has_key('evaluateur'):
271 evaluateur_field
= form
.declared_fields
['evaluateur']
273 evaluateur_field
= form
.base_fields
['evaluateur']
275 if form
.declared_fields
.has_key('candidat'):
276 candidats_field
= form
.declared_fields
['candidat']
278 candidats_field
= form
.base_fields
['candidat']
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()
289 def queryset(self
, request
):
291 Affiche la liste d'évaluation que si le user connecté
292 possède un UserProfile
294 qs
= self
.model
._default_manager
.get_query_set()
296 user
= UserProfile
.objects
.get(user
=request
.user
)
297 except UserProfile
.DoesNotExist
:
300 return qs
.select_related('candidat')
302 admin
.site
.register(OffreEmploi
, OffreEmploiAdmin
)
303 admin
.site
.register(Candidat
, CandidatAdmin
)
304 admin
.site
.register(UserProfile
, EvaluateurAdmin
)