1 # -*- encoding: utf-8 -*-
4 from django
.core
.urlresolvers
import reverse
as url
5 from django
.db
import models
6 from django
.contrib
import admin
7 from django
.contrib
.auth
.admin
import UserAdmin
8 from django
.contrib
.auth
.models
import User
9 from django
.contrib
.admin
.filterspecs
import RelatedFilterSpec
, FilterSpec
10 from django
.utils
.safestring
import mark_safe
11 from django
.utils
.translation
import ugettext
as _
12 from django
.utils
.encoding
import smart_unicode
, iri_to_uri
13 from django
.http
import HttpResponseRedirect
15 from models
import SourceActualite
, Actualite
, Discipline
, Evenement
, Record
, ListSet
, HarvestLog
, Profile
16 from savoirs
.globals import META
18 admin
.site
.register(SourceActualite
)
20 class ListSetFilterSpec(RelatedFilterSpec
):
22 Filtre custom automatiquement lié à un field nommé 'listsets'. Il a pour but de s'afficher
23 lorsqu'un server a déjà été présélectionné. Dans ce cas, il affiche une liste qui contient les
24 listsets de ce server.
26 def __init__(self
, f
, request
, params
, model
, model_admin
):
27 super(ListSetFilterSpec
, self
).__init__(f
, request
, params
, model
, model_admin
)
28 self
.server_name
= request
.GET
.get('server', None)
31 return self
.server_name
is not None
33 FilterSpec
.filter_specs
.insert(0, (lambda f
: f
.name
== 'listsets', ListSetFilterSpec
))
35 # Ces deux classes permettent d'implémenter la possibilité d'avoir un champs readonly_fields
36 # dans l.administration.
37 # Ce champs est devenu natif à partir de la version 1.2
38 # http://docs.djangoproject.com/en/dev/ref/contrib/admin/#django.contrib.admin.ModelAdmin.readonly_fields
39 from django
import forms
40 class ReadOnlyWidget(forms
.Widget
):
41 def __init__(self
, original_value
, display_value
):
42 self
.original_value
= original_value
43 self
.display_value
= display_value
45 super(ReadOnlyWidget
, self
).__init__()
47 def render(self
, name
, value
, attrs
=None):
48 if self
.display_value
is not None:
49 output
= self
.display_value
51 output
= unicode(self
.original_value
)
55 output
= ", ".join([ls
.name
for ls
in self
.original_value
.get_query_set()])
59 is_url
= re
.match('http[s]?://(?:[a-zA-Z]|[0-9]|[$-_@.&+]|[!*\(\),]|(?:%[0-9a-fA-F][0-9a-fA-F]))+', output
)
61 output
= "<a target='_blank' href='%s'>%s</a>" % (output
, output
)
63 return mark_safe(output
)
65 def value_from_datadict(self
, data
, files
, name
):
66 return self
.original_value
68 class ReadOnlyAdminFields(object):
69 def get_form(self
, request
, obj
=None):
70 form
= super(ReadOnlyAdminFields
, self
).get_form(request
, obj
)
72 if hasattr(self
, 'readonly_fields'):
73 for field_name
in self
.readonly_fields
:
74 if field_name
in form
.base_fields
:
76 if hasattr(obj
, 'get_%s_display' % field_name
):
77 display_value
= getattr(obj
, 'get_%s_display' % field_name
)()
81 form
.base_fields
[field_name
].widget
= ReadOnlyWidget(getattr(obj
, field_name
, ''), display_value
)
82 form
.base_fields
[field_name
].required
= False
86 class RecordAdmin(ReadOnlyAdminFields
, admin
.ModelAdmin
):
137 #SEP 2 (aucune données récoltées)
147 actions
= ['valider_references',
148 'invalider_references',
151 'assigner_disciplines',
152 'assigner_thematiques']
154 # fonctions pour présenter l'information
155 def __init__(self
, *args
, **kwargs
):
156 """Surcharge l'initialisation pour définir les champs de recherche dynamiquement,
157 et les champs en lecture seule uniquement."""
158 self
.search_fields
= META
.keys()
159 self
.readonly_fields
= META
.keys()
160 self
.readonly_fields
.append('listsets')
161 super(RecordAdmin
, self
).__init__(*args
, **kwargs
)
163 def est_complet(self
, obj
):
165 v
= obj
.est_complet()
166 return '<img src="/admin_media/img/admin/icon-%s.gif" alt="%d"/>' % (('no','yes')[v
], v
)
167 est_complet
.allow_tags
= True
171 return "<a target='_blank' href='%s'>%s</a>" % (obj
.uri
, obj
.uri
)
172 _uri
.allow_tags
= True
174 def _description(self
, obj
):
177 if obj
.description
is not None and len(obj
.description
) > max:
178 return "%s..." % obj
.description
[:max]
180 return obj
.description
183 def valider_references(self
, request
, queryset
):
184 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
185 return HttpResponseRedirect("/admin/confirmation/%s/%s?ids=%s" % ('record', 'valider', ",".join(selected
)))
187 def invalider_references(self
, request
, queryset
):
188 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
189 return HttpResponseRedirect("/admin/confirmation/%s/%s/?ids=%s" % ('record', 'invalider', ",".join(selected
)))
191 def assigner_pays(self
, request
, queryset
):
192 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
193 return HttpResponseRedirect("/admin/assigner_%s?ids=%s" % ('pays', ",".join(selected
)))
195 def assigner_regions(self
, request
, queryset
):
196 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
197 return HttpResponseRedirect(url('assigner_regions', kwargs
=dict(app_name
='savoirs', model_name
='record')) + '?ids=' + ','.join(selected
))
198 assigner_regions
.short_description
= u
'Assigner des régions'
200 def assigner_thematiques(self
, request
, queryset
):
201 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
202 return HttpResponseRedirect("/admin/assigner_%s?ids=%s" % ('thematiques', ",".join(selected
)))
204 def assigner_disciplines(self
, request
, queryset
):
205 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
206 return HttpResponseRedirect(url('assigner_disciplines', kwargs
=dict(app_name
='savoirs', model_name
='record')) + '?ids=' + ','.join(selected
))
207 assigner_disciplines
.short_description
= u
'Assigner des disciplines'
209 admin
.site
.register(Record
, RecordAdmin
)
211 class ListSetAdmin(ReadOnlyAdminFields
, admin
.ModelAdmin
):
212 fields
= ['spec', 'name', 'server', 'validated' ]
213 list_display
= fields
214 readonly_fields
= ['spec', 'name', 'server',]
215 list_filter
= ('server',)
217 admin
.site
.register(ListSet
, ListSetAdmin
)
219 class HarvestLogAdmin(ReadOnlyAdminFields
, admin
.ModelAdmin
):
220 fields
= ['context', 'name', 'added', 'updated', 'processed', 'record']
221 list_display
= fields
+ ['date']
222 admin_order_fields
= ['date']
223 search_fields
= fields
224 readonly_fields
= fields
225 list_filter
= ('context',)
227 admin
.site
.register(HarvestLog
, HarvestLogAdmin
)
229 class ProfileInline(admin
.TabularInline
):
234 class UserProfileAdmin(UserAdmin
):
235 inlines
= [ProfileInline
, ]
237 admin
.site
.unregister(User
)
238 admin
.site
.register(User
, UserProfileAdmin
)
240 class ActualiteAdmin(admin
.ModelAdmin
):
241 list_filter
= ('visible',)
242 list_display
= ('titre', 'source', 'date', 'visible')
243 actions
= ['rendre_visible', 'rendre_invisible', 'assigner_regions', 'assigner_disciplines']
246 def rendre_visible(self
, request
, queryset
):
247 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
248 return HttpResponseRedirect("/admin/confirmation/%s/%s?ids=%s" % ('actualite', 'visible', ",".join(selected
)))
250 def rendre_invisible(self
, request
, queryset
):
251 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
252 return HttpResponseRedirect("/admin/confirmation/%s/%s?ids=%s" % ('actualite', 'invisible', ",".join(selected
)))
254 def assigner_regions(self
, request
, queryset
):
255 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
256 return HttpResponseRedirect(url('assigner_regions', kwargs
=dict(app_name
='savoirs', model_name
='actualite')) + '?ids=' + ','.join(selected
))
257 assigner_regions
.short_description
= u
'Assigner des régions'
259 def assigner_disciplines(self
, request
, queryset
):
260 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
261 return HttpResponseRedirect(url('assigner_disciplines', kwargs
=dict(app_name
='savoirs', model_name
='actualite')) + '?ids=' + ','.join(selected
))
262 assigner_disciplines
.short_description
= u
'Assigner des disciplines'
264 admin
.site
.register(Actualite
, ActualiteAdmin
)
267 class EvenementAdminForm(forms
.ModelForm
):
272 cleaned_data
= self
.cleaned_data
273 debut
= cleaned_data
.get("debut")
274 fin
= cleaned_data
.get("fin")
276 raise forms
.ValidationError("La date de fin ne doit pas être antérieure à la date de début")
279 class EvenementAdmin(admin
.ModelAdmin
):
280 form
= EvenementAdminForm
281 list_filter
= ('approuve',)
282 list_display
= ('titre', 'debut', 'fin', 'lieu', 'approuve')
283 fields
= ['titre', 'discipline', 'discipline_secondaire', 'mots_cles',
284 'type', 'fuseau', 'debut', 'fin', 'lieu', 'regions',
285 'description', 'contact', 'url', 'approuve']
286 actions
= ['assigner_regions', 'assigner_disciplines']
288 def assigner_regions(self
, request
, queryset
):
289 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
290 return HttpResponseRedirect(url('assigner_regions', kwargs
=dict(app_name
='savoirs', model_name
='evenement')) + '?ids=' + ','.join(selected
))
291 assigner_regions
.short_description
= u
'Assigner des régions'
293 def assigner_disciplines(self
, request
, queryset
):
294 selected
= request
.POST
.getlist(admin
.ACTION_CHECKBOX_NAME
)
295 return HttpResponseRedirect(url('assigner_disciplines', kwargs
=dict(app_name
='savoirs', model_name
='evenement')) + '?ids=' + ','.join(selected
))
296 assigner_disciplines
.short_description
= u
'Assigner des disciplines'
298 admin
.site
.register(Evenement
, EvenementAdmin
)