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"
24 def queryset(self
, request
):
26 N'affiche la liste de candidats que si le user connecté
29 qs
= self
.model
._default_manager
.get_query_set()
31 user
= Evaluateur
.objects
.get(user
=request
.user
)
32 except Evaluateur
.DoesNotExist
:
35 region_ids
= [g
.id for g
in user
.regions
.all()]
36 return qs
.select_related('offre_emploi').filter(region__in
=region_ids
)
38 class ProxyCandidatPiece(CandidatPiece
):
40 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
45 verbose_name
= "pièce jointe"
46 verbose_name_plural
= "pièces jointes"
48 class CandidatPieceInline(admin
.TabularInline
):
49 model
= ProxyCandidatPiece
50 fields
= ('candidat', 'nom', 'path', )
53 class ProxyEvaluateur(Evaluateur
.candidats
.through
):
55 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
60 verbose_name
= "évaluateur"
62 class EvaluateurInline(admin
.TabularInline
):
63 model
= ProxyEvaluateur
66 class CandidatAdmin(VersionAdmin
):
67 date_hierarchy
= 'date_creation'
68 list_display
= ('nom', 'prenom', 'offre_emploi','statut',
69 'voir_offre_emploi', 'evaluer_candidat', #'note_evaluateur',
70 'calculer_moyenne', 'afficher_candidat',)
71 list_filter
= ('offre_emploi', )
74 'fields': ('offre_emploi', )
76 ('Informations personnelles', {
77 'fields': ('prenom','nom','genre', 'nationalite', 'date_naissance',
78 'situation_famille', 'nombre_dependant',)
81 'fields': ('telephone', 'email', 'adresse', 'ville',
82 'etat_province', 'code_postal', 'pays', )
84 ('Informations professionnelles', {
85 'fields': ('niveau_diplome','employeur_actuel',
86 'poste_actuel', 'domaine_professionnel',)
88 ('Options avancées', {
89 'classes': ('collapse',),
90 'fields': ('actif', 'statut', )
98 actions
= ['affecter_candidats_evaluateur', 'envoyer_courriel_candidats']
99 # Affecter un évaluateurs à des candidats
100 def affecter_candidats_evaluateur(modeladmin
, obj
, candidats
):
101 selected
= obj
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
103 return HttpResponseRedirect(reverse('affecter_evaluateurs_candidats')+
104 "?ids=%s" % (",".join(selected
)))
105 affecter_candidats_evaluateur
.short_description
= u
'Affecter évaluateur'
107 # Envoyer un courriel à des candidats
108 def envoyer_courriel_candidats(modeladmin
, obj
, candidats
):
109 selected
= obj
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
111 return HttpResponseRedirect(reverse('envoyer_courriel_candidats')+
112 "?ids=%s" % (",".join(selected
)))
113 envoyer_courriel_candidats
.short_description
= u
'Envoyer courriel'
115 # Évaluer un candidat
116 def evaluer_candidat(self
, obj
):
117 return "<a href='%s?id=%s'>Évaluer le candidat \
118 </a>" % (reverse('evaluer_candidat'), obj
.id)
119 evaluer_candidat
.allow_tags
= True
120 evaluer_candidat
.short_description
= 'Évaluer'
122 # Afficher un candidat
123 def afficher_candidat(self
, obj
):
124 return "<a href='%s?id=%s'>Voir le candidat \
125 </a>" % (reverse('afficher_candidat'), obj
.id)
126 afficher_candidat
.allow_tags
= True
127 afficher_candidat
.short_description
= u
'Afficher les détails'
129 # Voir l'offre d'emploi
130 def voir_offre_emploi(self
, obj
):
131 return "<a href='%s?id=%s'>Voir l'offre d'emploi</a> \
132 " % (reverse('admin:recrutement_offreemploi_changelist'),
134 voir_offre_emploi
.allow_tags
= True
135 voir_offre_emploi
.short_description
= "Afficher l'offre d'emploi"
137 """ # Afficher note poster par l'évaluateur
138 def note_evaluateur(self, obj):
139 import pdb;pdb.set_trace()
140 evaluateur = Evaluateur.objects.get(user=obj.user)
141 import pdb;pdb.set_trace()
142 note_eval = CandidatEvaluation.objects.filter(evaluateur=evaluateur,
145 note_evaluateur.allow_tags = True
146 note_evaluateur.short_description = "Votre note"
149 # Calculer la moyenne des notes
150 def calculer_moyenne(self
, obj
):
151 evaluations
= CandidatEvaluation
.objects
.filter(candidat
=obj
)
152 offre_emploi
= obj
.offre_emploi
154 notes
= [evaluation
.note
for evaluation
in evaluations
.all() if evaluation
.note
is not None]
156 if len(notes
) > 0 and offre_emploi
.date_limite
<= datetime
.date
.today():
157 moyenne_votes
= float(sum(notes
)) / len(notes
)
159 moyenne_votes
= "Non disponible"
161 calculer_moyenne
.allow_tags
= True
162 calculer_moyenne
.short_description
= "Moyenne des notes"
164 def get_form(self
, request
, obj
=None, **kwargs
):
166 Affiche la liste des offres d'emploi, seulement si le user
167 connecté possède un Evaluateur
169 form
= super(CandidatAdmin
, self
).get_form(request
, obj
, **kwargs
)
170 if form
.declared_fields
.has_key('offre_emploi'):
171 region_field
= form
.declared_fields
['offre_emploi']
173 region_field
= form
.base_fields
['offre_emploi']
176 user
= Evaluateur
.objects
.get(user
=request
.user
)
177 except Evaluateur
.DoesNotExist
:
178 region_field
.queryset
= region_field
.queryset
.none()
181 region_ids
= [g
.id for g
in user
.regions
.all()]
182 region_field
.queryset
= OffreEmploi
.objects
.filter(region__in
=region_ids
)
185 def queryset(self
, obj
):
187 Spécifie un queryset limité, autrement Django exécute un
188 select_related() sans paramètre, ce qui a pour effet de charger tous
189 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
190 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
191 génération d'une requête infinie.
195 qs
= self
.model
._default_manager
.get_query_set()
197 user
= Evaluateur
.objects
.get(user
=obj
.user
)
198 except Evaluateur
.DoesNotExist
:
201 ids
= [c
.id for c
in user
.candidats
.all()]
202 return qs
.select_related('candidats').filter(id__in
=ids
)
204 class CandidatPieceAdmin(admin
.ModelAdmin
):
205 list_display
= ('nom', 'candidat', )
207 def queryset(self
, request
):
209 Spécifie un queryset limité, autrement Django exécute un
210 select_related() sans paramètre, ce qui a pour effet de charger tous
211 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
212 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
213 génération d'une requête infinie.
214 Affiche la liste de candidats que si le user connecté
215 possède un Evaluateur
217 qs
= self
.model
._default_manager
.get_query_set()
218 return qs
.select_related('candidat')
220 class EvaluateurAdmin(VersionAdmin
):
222 (None, {'fields': ('user', )}),#'regions')}),
223 (None, {'fields': ('candidats',)}),
226 '''def get_form(self, request, obj=None, **kwargs):
228 Affiche la liste des users, regions et candidats, seulement si le user
229 connecté possède un Evaluateur
231 form = super(EvaluateurAdmin, self).get_form(request, obj, **kwargs)
232 if form.declared_fields.has_key('user'):
233 permission_field = form.declared_fields['user']
235 permission_field = form.base_fields['user']
237 #if form.declared_fields.has_key('regions'):
238 # region_field = form.declared_fields['regions']
240 # region_field = form.base_fields['regions']
242 if form.declared_fields.has_key('candidats'):
243 candidats_field = form.declared_fields['candidats']
245 candidats_field = form.base_fields['candidats']
248 user = Evaluateur.objects.get(user=request.user)
249 except Evaluateur.DoesNotExist:
250 #region_field.queryset = Region.objects.none()
251 permission_field.queryset = Evaluateur.objects.none()
252 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 Evaluateur
263 qs
= self
.model
._default_manager
.get_query_set()
265 user
= Evaluateur
.objects
.get(user
=request
.user
)
266 except Evaluateur
.DoesNotExist
:
271 class AdministrateurRegionalAdmin(VersionAdmin
):
274 class CandidatEvaluationAdmin(VersionAdmin
):
275 list_display
= ('candidat', 'evaluateur', 'note', 'commentaire', 'date', )
277 def get_form(self
, request
, obj
=None, **kwargs
):
279 Affiche la liste des candidats et évaluateur, seulement si le user
280 connecté possède un Evaluateur
282 form
= super(CandidatEvaluationAdmin
, self
).get_form(request
, obj
,
284 if form
.declared_fields
.has_key('evaluateur'):
285 evaluateur_field
= form
.declared_fields
['evaluateur']
287 evaluateur_field
= form
.base_fields
['evaluateur']
289 if form
.declared_fields
.has_key('candidat'):
290 candidats_field
= form
.declared_fields
['candidat']
292 candidats_field
= form
.base_fields
['candidat']
295 user
= Evaluateur
.objects
.get(user
=request
.user
)
296 except Evaluateur
.DoesNotExist
:
297 evaluateur_field
.queryset
= Evaluateur
.objects
.none()
298 candidats_field
.queryset
= Candidat
.objects
.none()
303 def queryset(self
, request
):
305 Affiche la liste d'évaluation que si le user connecté
306 possède un Evaluateur
308 qs
= self
.model
._default_manager
.get_query_set()
310 user
= Evaluateur
.objects
.get(user
=request
.user
)
311 except Evaluateur
.DoesNotExist
:
314 return qs
.select_related('candidat')
316 class CourrielTemplateAdmin(VersionAdmin
):
319 admin
.site
.register(OffreEmploi
, OffreEmploiAdmin
)
320 admin
.site
.register(Candidat
, CandidatAdmin
)
321 admin
.site
.register(CourrielTemplate
, CourrielTemplateAdmin
)
322 admin
.site
.register(Evaluateur
, EvaluateurAdmin
)
323 admin
.site
.register(AdministrateurRegional
, AdministrateurRegionalAdmin
)