1 # -*- coding: utf-8 -*-
2 from django
.db
import models
3 from django
.db
.models
import Q
4 from django
.contrib
import admin
5 from django
.core
.urlresolvers
import reverse
as url
6 from django
.forms
.models
import BaseInlineFormSet
7 from django
.http
import HttpResponseRedirect
8 from django
.utils
.encoding
import smart_str
9 from django_exportateur
.exportateur
import exportateur
11 from chercheurs
.models
import Chercheur
, Publication
, Groupe
, ChercheurGroupe
, ChercheurQuerySet
, These
13 class ChercheurAdmin(admin
.ModelAdmin
):
14 list_filter
= ['genre']
16 actions
= ('remove_from_group', 'export_as_ods', 'export_as_csv')
17 search_fields
= ('nom', 'prenom')
19 def lookup_allowed(self
, lookup
):
20 return lookup
in ['genre', 'statut', 'membre_reseau_institutionnel',
21 'membre_instance_auf', 'discipline', 'region', 'pays',
22 'groupes', 'nord_sud'] or \
23 admin
.ModelAdmin
.lookup_allowed(self
, lookup
)
25 def remove_from_group(self
, request
, queryset
):
26 groupe_id
= request
.GET
.get('groupes__id__exact')
27 chercheur_ids
= queryset
.values_list('id', flat
=True)
28 matches
= ChercheurGroupe
.objects
.filter(groupe
=groupe_id
, chercheur__in
=chercheur_ids
)
30 return HttpResponseRedirect(url('admin:chercheurs_chercheur_changelist') + '?groupes__id__exact=' + groupe_id
)
32 def get_actions(self
, request
):
33 actions
= super(ChercheurAdmin
, self
).get_actions(request
)
35 # Si on filtre par groupe de recherche, offrir d'en retirer les
36 # chercheurs sélectionnés.
37 groupe_id
= request
.GET
.get('groupes__id__exact')
39 groupe
= Groupe
.objects
.get(id=groupe_id
)
40 action_desc
= actions
['remove_from_group']
41 actions
['remove_from_group'] = (action_desc
[0], action_desc
[1], u
'Retirer du domaine de recherche « %s »' % groupe
.nom
)
43 del actions
['remove_from_group']
46 def queryset(self
, request
):
47 return ChercheurAdminQuerySet(Chercheur
)
49 def export(self
, queryset
, type):
50 if queryset
.count() == 0:
53 headers
= ['Nom', 'Prénom', 'Genre', 'Courriel', 'Téléphone', 'Adresse postale',
54 'Statut', 'Diplôme', 'Établissement', 'Pays', 'Domaines de recherche',
55 'Thèse', 'Directeur', 'Discipline', 'Thèmes de recherche', 'Groupe de recherche', 'Mots-clés',
56 'Site web', 'Blog', 'Réseau social',
57 'Membre instance AUF', "Sollicité par l'OIF", 'Membre société francophone',
58 'Membre instance réseau institutionnel AUF', 'Expertises', 'Solliciter pour expertises',
65 row
.append(c
.get_genre_display())
66 row
.append(c
.courriel
)
67 row
.append(c
.telephone
)
68 row
.append(c
.adresse_postale
)
69 row
.append(c
.get_statut_display())
71 row
.append(c
.nom_etablissement
)
73 row
.append(', '.join(g
.nom
for g
in c
.groupes
.all()))
76 row
.append('%s, %s, %s, %s pages.' % (t
.titre
, t
.etablissement
, t
.annee
, t
.nb_pages
))
77 row
.append(t
.directeur
)
78 except These
.DoesNotExist
:
81 row
.append(c
.discipline
.nom
if c
.discipline
else '')
82 row
.append(c
.theme_recherche
)
83 row
.append(c
.groupe_recherche
)
84 row
.append(c
.mots_cles
)
85 row
.append(c
.url_site_web
)
86 row
.append(c
.url_blog
)
87 row
.append(c
.url_reseau_social
)
88 if c
.membre_instance_auf
:
89 row
.append(', '.join([c
.membre_instance_auf_nom
, c
.membre_instance_auf_fonction
, c
.membre_instance_auf_dates
]))
93 row
.append(', '.join([c
.expert_oif_details
, c
.expert_oif_dates
]))
96 if c
.membre_association_francophone
:
97 row
.append(c
.membre_association_francophone_details
)
100 if c
.membre_reseau_institutionnel
:
101 row
.append(', '.join([c
.membre_reseau_institutionnel_nom
, c
.membre_reseau_institutionnel_fonction
, c
.membre_reseau_institutionnel_dates
]))
104 row
.append('; '.join(', '.join([e
.nom
, e
.date
, e
.organisme_demandeur
]) for e
in c
.expertises
.all()))
105 if c
.expertises_auf
is None:
108 row
.append('Oui' if c
.expertises_auf
else 'Non')
109 row
.append('; '.join(p
.publication_affichage
if p
.publication_affichage
else
110 '%s, %s, %s, %s, %s, %s, %s pages.' %
111 (p
.auteurs
, p
.titre
, p
.revue
, p
.annee
, p
.editeur
, p
.lieu_edition
, p
.nb_pages
)
112 for p
in c
.publications
.all()))
113 data
.append([smart_str(x
) if x
else '' for x
in row
])
114 return exportateur(headers
, data
, type, filename
='chercheurs.%s' % type)
116 def export_as_csv(self
, request
, queryset
):
117 return self
.export(queryset
, 'csv')
118 export_as_csv
.short_description
= 'Export CSV'
120 def export_as_ods(self
, request
, queryset
):
121 return self
.export(queryset
, 'ods')
122 export_as_ods
.short_description
= 'Export ODS'
124 class ChercheurAdminQuerySet(ChercheurQuerySet
):
126 def filter(self
, *args
, **kwargs
):
127 """Gère des filtres supplémentaires pour l'admin.
129 C'est la seule façon que j'ai trouvée de contourner les mécanismes
130 de recherche de l'admin."""
132 pays
= kwargs
.pop('pays', None)
133 region
= kwargs
.pop('region', None)
134 nord_sud
= kwargs
.pop('nord_sud', None)
135 expert
= kwargs
.pop('expert', None)
137 qs
= qs
.filter(Q(etablissement__pays
=pays
) |
138 (Q(etablissement
=None) & Q(etablissement_autre_pays
=pays
)))
139 elif region
is not None:
140 qs
= qs
.filter(Q(etablissement__pays__region
=region
) |
141 (Q(etablissement
=None) & Q(etablissement_autre_pays__region
=region
)))
142 elif nord_sud
is not None:
143 qs
= qs
.filter(Q(etablissement__pays__nord_sud
=nord_sud
) |
144 (Q(etablissement
=None) & Q(etablissement_autre_pays__nord_sud
=nord_sud
)))
145 if expert
is not None:
146 if expert
in ['1', 1, True]:
147 qs
= qs
.exclude(expertises
=None)
149 qs
= qs
.filter(expertises
=None)
151 return super(ChercheurAdminQuerySet
, qs
).filter(*args
, **kwargs
)
153 admin
.site
.register(Chercheur
, ChercheurAdmin
)
154 admin
.site
.register(Publication
)
155 admin
.site
.register(Groupe
)