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 # Afficher la liste des candidats pour l'offre d'emploi
18 def _candidatsList(self
, obj
):
19 return "<a href='%s?offre_emploi__id__exact=%s'>Voir les candidats \
20 </a>" % (reverse('admin:recrutement_candidat_changelist'), obj
.id)
21 _candidatsList
.allow_tags
= True
22 _candidatsList
.short_description
= "Liste des candidats"
25 def get_form(self
, request
, obj
=None, **kwargs
):
27 Affiche la liste des régions, seulement si le user
28 connecté possède un UserProfile
30 form
= super(OffreEmploiAdmin
, self
).get_form(request
, obj
, **kwargs
)
31 if form
.declared_fields
.has_key('region'):
32 region_field
= form
.declared_fields
['region']
34 region_field
= form
.base_fields
['region']
37 user
= UserProfile
.objects
.get(user
=request
.user
)
38 except UserProfile
.DoesNotExist
:
39 region_field
.queryset
= Region
.objects
.none()
42 region_ids
= [g
.id for g
in user
.regions
.all()]
43 region_field
.queryset
= Region
.objects
.filter(id__in
=region_ids
)
46 def queryset(self
, request
):
48 N'affiche la liste de candidats que si le user connecté
49 possède un UserProfile
51 qs
= self
.model
._default_manager
.get_query_set()
53 user
= UserProfile
.objects
.get(user
=request
.user
)
54 except UserProfile
.DoesNotExist
:
57 region_ids
= [g
.id for g
in user
.regions
.all()]
58 return qs
.select_related('offre_emploi').filter(region__in
=region_ids
)
60 class ProxyCandidatPiece(CandidatPiece
):
62 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
67 verbose_name
= "pièce jointe"
68 verbose_name_plural
= "pièces jointes"
70 class CandidatPieceInline(admin
.TabularInline
):
71 model
= ProxyCandidatPiece
72 fields
= ('candidat', 'nom', 'path', )
75 class ProxyEvaluateur(UserProfile
.candidats
.through
):
77 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
82 verbose_name
= "évaluateur"
84 class EvaluateurInline(admin
.TabularInline
):
85 model
= ProxyEvaluateur
88 class CandidatAdmin(VersionAdmin
):
89 date_hierarchy
= 'date_creation'
90 list_display
= ('nom', 'prenom', 'offre_emploi','statut',
91 'voir_offre_emploi', 'evaluer_candidat', #'note_evaluateur',
92 'calculer_moyenne', 'afficher_candidat',)
93 list_filter
= ('offre_emploi', )
96 'fields': ('offre_emploi', )
98 ('Informations personnelles', {
99 'fields': ('prenom','nom','genre', 'nationalite', 'date_naissance',
100 'situation_famille', 'nombre_dependant',)
103 'fields': ('telephone', 'email', 'adresse', 'ville',
104 'etat_province', 'code_postal', 'pays', )
106 ('Informations professionnelles', {
107 'fields': ('niveau_diplome','employeur_actuel',
108 'poste_actuel', 'domaine_professionnel',)
110 ('Options avancées', {
111 'classes': ('collapse',),
112 'fields': ('actif', 'statut', )
120 actions
= ['affecter_candidats_evaluateur']
121 # Affecter un évaluateurs à des candidats
122 def affecter_candidats_evaluateur(modeladmin
, obj
, candidats
):
123 selected
= obj
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
125 return HttpResponseRedirect(reverse('affecter_evaluateurs_candidats')+
126 "?ids=%s" % (",".join(selected
)))
127 affecter_candidats_evaluateur
.short_description
= u
'Affecter évaluateur'
129 # Évaluer un candidat
130 def evaluer_candidat(self
, obj
):
131 return "<a href='%s?id=%s'>Évaluer le candidat \
132 </a>" % (reverse('evaluer_candidat'), obj
.id)
133 evaluer_candidat
.allow_tags
= True
134 evaluer_candidat
.short_description
= 'Évaluer'
136 # Afficher un candidat
137 def afficher_candidat(self
, obj
):
138 return "<a href='%s?id=%s'>Voir le candidat \
139 </a>" % (reverse('afficher_candidat'), obj
.id)
140 afficher_candidat
.allow_tags
= True
141 afficher_candidat
.short_description
= u
'Afficher les détails'
143 # Voir l'offre d'emploi
144 def voir_offre_emploi(self
, obj
):
145 return "<a href='%s?id=%s'>Voir l'offre d'emploi</a> \
146 " % (reverse('admin:recrutement_offreemploi_changelist'),
148 voir_offre_emploi
.allow_tags
= True
149 voir_offre_emploi
.short_description
= "Afficher l'offre d'emploi"
151 """ # Afficher note poster par l'évaluateur
152 def note_evaluateur(self, obj):
153 import pdb;pdb.set_trace()
154 evaluateur = UserProfile.objects.get(user=obj.user)
155 import pdb;pdb.set_trace()
156 note_eval = CandidatEvaluation.objects.filter(evaluateur=evaluateur,
159 note_evaluateur.allow_tags = True
160 note_evaluateur.short_description = "Votre note"
163 # Calculer la moyenne des notes
164 def calculer_moyenne(self
, obj
):
165 evaluations
= CandidatEvaluation
.objects
.filter(candidat
=obj
)
166 offre_emploi
= obj
.offre_emploi
168 notes
= [evaluation
.note
for evaluation
in evaluations
.all() if evaluation
.note
is not None]
170 if len(notes
) > 0 and offre_emploi
.date_limite
<= datetime
.date
.today():
171 moyenne_votes
= float(sum(notes
)) / len(notes
)
173 moyenne_votes
= "Non disponible"
175 calculer_moyenne
.allow_tags
= True
176 calculer_moyenne
.short_description
= "Moyenne des notes"
178 def get_form(self
, request
, obj
=None, **kwargs
):
180 Affiche la liste des offres d'emploi, seulement si le user
181 connecté possède un UserProfile
183 form
= super(CandidatAdmin
, self
).get_form(request
, obj
, **kwargs
)
184 if form
.declared_fields
.has_key('offre_emploi'):
185 region_field
= form
.declared_fields
['offre_emploi']
187 region_field
= form
.base_fields
['offre_emploi']
190 user
= UserProfile
.objects
.get(user
=request
.user
)
191 except UserProfile
.DoesNotExist
:
192 region_field
.queryset
= region_field
.queryset
.none()
195 region_ids
= [g
.id for g
in user
.regions
.all()]
196 region_field
.queryset
= OffreEmploi
.objects
.filter(region__in
=region_ids
)
199 def queryset(self
, obj
):
201 Spécifie un queryset limité, autrement Django exécute un
202 select_related() sans paramètre, ce qui a pour effet de charger tous
203 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
204 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
205 génération d'une requête infinie.
209 qs
= self
.model
._default_manager
.get_query_set()
211 user
= UserProfile
.objects
.get(user
=obj
.user
)
212 except UserProfile
.DoesNotExist
:
215 ids
= [c
.id for c
in user
.candidats
.all()]
216 return qs
.select_related('candidats').filter(id__in
=ids
)
218 class CandidatPieceAdmin(admin
.ModelAdmin
):
219 list_display
= ('nom', 'candidat', )
221 def queryset(self
, request
):
223 Spécifie un queryset limité, autrement Django exécute un
224 select_related() sans paramètre, ce qui a pour effet de charger tous
225 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
226 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
227 génération d'une requête infinie.
228 Affiche la liste de candidats que si le user connecté
229 possède un UserProfile
231 qs
= self
.model
._default_manager
.get_query_set()
232 return qs
.select_related('candidat')
234 class EvaluateurAdmin(VersionAdmin
):
236 (None, {'fields': ('user', 'regions')}),
237 (None, {'fields': ('candidats',)}),
240 def get_form(self
, request
, obj
=None, **kwargs
):
242 Affiche la liste des users, regions et candidats, seulement si le user
243 connecté possède un UserProfile
245 form
= super(EvaluateurAdmin
, self
).get_form(request
, obj
, **kwargs
)
246 if form
.declared_fields
.has_key('user'):
247 permission_field
= form
.declared_fields
['user']
249 permission_field
= form
.base_fields
['user']
251 if form
.declared_fields
.has_key('regions'):
252 region_field
= form
.declared_fields
['regions']
254 region_field
= form
.base_fields
['regions']
256 if form
.declared_fields
.has_key('candidats'):
257 candidats_field
= form
.declared_fields
['candidats']
259 candidats_field
= form
.base_fields
['candidats']
262 user
= UserProfile
.objects
.get(user
=request
.user
)
263 except UserProfile
.DoesNotExist
:
264 region_field
.queryset
= Region
.objects
.none()
265 permission_field
.queryset
= UserProfile
.objects
.none()
266 candidats_field
.queryset
= Candidat
.objects
.none()
271 def queryset(self
, request
):
273 Affiche la liste d'évaluateur que si le user connecté
274 possède un UserProfile
276 qs
= self
.model
._default_manager
.get_query_set()
278 user
= UserProfile
.objects
.get(user
=request
.user
)
279 except UserProfile
.DoesNotExist
:
284 class CandidatEvaluationAdmin(VersionAdmin
):
285 list_display
= ('candidat', 'evaluateur', 'note', 'commentaire', 'date', )
287 def get_form(self
, request
, obj
=None, **kwargs
):
289 Affiche la liste des candidats et évaluateur, seulement si le user
290 connecté possède un UserProfile
292 form
= super(CandidatEvaluationAdmin
, self
).get_form(request
, obj
,
294 if form
.declared_fields
.has_key('evaluateur'):
295 evaluateur_field
= form
.declared_fields
['evaluateur']
297 evaluateur_field
= form
.base_fields
['evaluateur']
299 if form
.declared_fields
.has_key('candidat'):
300 candidats_field
= form
.declared_fields
['candidat']
302 candidats_field
= form
.base_fields
['candidat']
305 user
= UserProfile
.objects
.get(user
=request
.user
)
306 except UserProfile
.DoesNotExist
:
307 evaluateur_field
.queryset
= UserProfile
.objects
.none()
308 candidats_field
.queryset
= Candidat
.objects
.none()
313 def queryset(self
, request
):
315 Affiche la liste d'évaluation que si le user connecté
316 possède un UserProfile
318 qs
= self
.model
._default_manager
.get_query_set()
320 user
= UserProfile
.objects
.get(user
=request
.user
)
321 except UserProfile
.DoesNotExist
:
324 return qs
.select_related('candidat')
326 admin
.site
.register(OffreEmploi
, OffreEmploiAdmin
)
327 admin
.site
.register(Candidat
, CandidatAdmin
)
328 admin
.site
.register(CandidatEvaluation
, CandidatEvaluationAdmin
)
329 admin
.site
.register(UserProfile
, EvaluateurAdmin
)