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
):
24 form
= super(OffreEmploiAdmin
, self
).get_form(request
, obj
, **kwargs
)
25 if form
.declared_fields
.has_key('region'):
26 region_field
= form
.declared_fields
['region']
28 region_field
= form
.base_fields
['region']
30 user
= UserProfile
.objects
.get(user
=request
.user
)
31 region_ids
= [g
.id for g
in user
.regions
.all()]
32 region_field
.queryset
= Region
.objects
.filter(id__in
=region_ids
)
35 def queryset(self
, request
):
37 Spécifie un queryset limité, autrement Django exécute un
38 select_related() sans paramètre, ce qui a pour effet de charger tous
39 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
40 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
41 génération d'une requête infinie.
43 qs
= self
.model
._default_manager
.get_query_set()
45 user
= UserProfile
.objects
.get(user
=request
.user
)
46 except UserProfile
.DoesNotExist
:
49 region_ids
= [g
.id for g
in user
.regions
.all()]
50 return qs
.select_related('offre_emploi').filter(region__in
=region_ids
)
52 class ProxyCandidatPiece(CandidatPiece
):
54 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
59 verbose_name
= "pièce jointe"
60 verbose_name_plural
= "pièces jointes"
62 class CandidatPieceInline(admin
.TabularInline
):
63 model
= ProxyCandidatPiece
64 fields
= ('candidat', 'nom', 'path', )
67 class ProxyEvaluateur(UserProfile
.candidats
.through
):
69 Ce proxy sert uniquement dans l'admin à disposer d'un libellé
74 verbose_name
= "évaluateur"
76 class EvaluateurInline(admin
.TabularInline
):
77 model
= ProxyEvaluateur
80 class CandidatAdmin(VersionAdmin
):
81 date_hierarchy
= 'date_creation'
82 list_display
= ('nom', 'prenom', 'offre_emploi','statut', '_actions',
84 list_filter
= ('offre_emploi', )
87 'fields': ('offre_emploi', )
89 ('Informations personnelles', {
90 'fields': ('prenom','nom','genre', 'nationalite', 'date_naissance',
91 'situation_famille', 'nombre_dependant',)
94 'fields': ('adresse', 'ville', 'etat_province', 'pays', )
96 ('Informations professionnelles', {
97 'fields': ('niveau_diplome','employeur_actuel',
98 'poste_actuel', 'domaine_professionnel',)
100 ('Options avancées', {
101 'classes': ('collapse',),
102 'fields': ('actif', 'statut', )
110 # Affecter un évaluateurs à des candidats
111 actions
= ['affecter_candidats_evaluateur']
112 def affecter_candidats_evaluateur(modeladmin
, obj
, candidats
):
114 selected
= obj
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
116 return HttpResponseRedirect(reverse('affecter_evaluateurs_candidats')+
117 "?ids=%s" % (",".join(selected
)))
118 affecter_candidats_evaluateur
.short_description
= "Affecter evaluateur"
120 # Évaluer un candidat
121 def evaluer_candidat(self
, obj
):
122 return "<a href='%s?id=%s'>Évaluer le candidat \
123 </a>" % (reverse('evaluer_candidat'), obj
.id)
124 evaluer_candidat
.allow_tags
= True
125 evaluer_candidat
.short_description
= "Évaluer"
127 def get_form(self
, request
, obj
=None, **kwargs
):
128 form
= super(CandidatAdmin
, self
).get_form(request
, obj
, **kwargs
)
129 if form
.declared_fields
.has_key('offre_emploi'):
130 region_field
= form
.declared_fields
['offre_emploi']
132 region_field
= form
.base_fields
['offre_emploi']
135 user
= UserProfile
.objects
.get(user
=request
.user
)
136 except UserProfile
.DoesNotExist
:
137 region_field
.queryset
= region_field
.queryset
.none()
140 region_ids
= [g
.id for g
in user
.regions
.all()]
141 region_field
.queryset
= OffreEmploi
.objects
.filter(region__in
=region_ids
)
144 def queryset(self
, obj
):
146 Spécifie un queryset limité, autrement Django exécute un
147 select_related() sans paramètre, ce qui a pour effet de charger tous
148 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
149 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
150 génération d'une requête infinie.
153 qs
= self
.model
._default_manager
.get_query_set()
155 user
= UserProfile
.objects
.get(user
=obj
.user
)
156 except UserProfile
.DoesNotExist
:
159 ids
= [c
.id for c
in user
.candidats
.all()]
160 return qs
.select_related('candidats').filter(id__in
=ids
)
162 def _actions(self
, obj
):
163 return "<a href='%s?id=%s'>Voir l'offre d'emploi</a> \
164 " % (reverse('admin:recrutement_offreemploi_changelist'),
166 _actions
.allow_tags
= True
167 _actions
.short_description
= "Offre d'emploi"
169 class CandidatPieceAdmin(admin
.ModelAdmin
):
170 list_display
= ('nom', 'candidat', )
172 def queryset(self
, request
):
174 Spécifie un queryset limité, autrement Django exécute un
175 select_related() sans paramètre, ce qui a pour effet de charger tous
176 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
177 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
178 génération d'une requête infinie.
180 qs
= self
.model
._default_manager
.get_query_set()
181 return qs
.select_related('candidat')
183 class EvaluateurAdmin(VersionAdmin
):
185 (None, {'fields': ('user', 'regions')}),
186 (None, {'fields': ('candidats',)}),
189 class CandidatEvaluationAdmin(VersionAdmin
):
190 list_display
= ('candidat', 'evaluateur', 'note', 'commentaire', 'date', )
192 def queryset(self
, obj
):
194 Spécifie un queryset limité, autrement Django exécute un
195 select_related() sans paramètre, ce qui a pour effet de charger tous
196 les objets FK, sans limite de profondeur. Dès qu'on arrive, dans les
197 modèles de Region, il existe plusieurs boucles, ce qui conduit à la
198 génération d'une requête infinie.
200 qs
= self
.model
._default_manager
.get_query_set()
201 return qs
.select_related('offre_emploi')
203 admin
.site
.register(OffreEmploi
, OffreEmploiAdmin
)
204 admin
.site
.register(Candidat
, CandidatAdmin
)
205 admin
.site
.register(CandidatPiece
, CandidatPieceAdmin
)
206 admin
.site
.register(UserProfile
, EvaluateurAdmin
)
207 admin
.site
.register(CandidatEvaluation
, CandidatEvaluationAdmin
)