Skip to content
Snippets Groups Projects
Unverified Commit 233bf1df authored by AuStrasser's avatar AuStrasser Committed by GitHub
Browse files

Merge pull request #6 from oser-cs/export_bdd

Export bdd
parents 304fb169 1b60258c
No related branches found
No related tags found
1 merge request!7Dev
...@@ -2,7 +2,6 @@ ...@@ -2,7 +2,6 @@
from django.contrib import admin from django.contrib import admin
from .models import Document, Address from .models import Document, Address
# Register your models here. # Register your models here.
......
...@@ -80,17 +80,6 @@ class EditionFormAdmin(admin.ModelAdmin): ...@@ -80,17 +80,6 @@ class EditionFormAdmin(admin.ModelAdmin):
list_display = ('form', 'deadline', 'recipient',) list_display = ('form', 'deadline', 'recipient',)
list_filter = ('edition', 'deadline',) list_filter = ('edition', 'deadline',)
actions = ['download_csv']
def download_csv(self, request, queryset):
"""Download entries of selected edition forms under a ZIP file."""
form_ids = queryset.values_list('form__id', flat=True)
forms = Form.objects.filter(id__in=form_ids)
return download_multiple_forms_entries(request, forms=forms)
download_csv.short_description = (
'Télécharger les résponses des formulaires sélectionnés')
@admin.register(Participation) @admin.register(Participation)
class ParticipationAdmin(admin.ModelAdmin): class ParticipationAdmin(admin.ModelAdmin):
......
...@@ -7,6 +7,8 @@ from django.utils.translation import ugettext_lazy as _ ...@@ -7,6 +7,8 @@ from django.utils.translation import ugettext_lazy as _
from visits.admin import ParticipationInline from visits.admin import ParticipationInline
from .models import User from .models import User
from django.http import HttpResponse
import csv
class UserParticipationInline(ParticipationInline): class UserParticipationInline(ParticipationInline):
"""Inline for Participation on the User admin panel. """Inline for Participation on the User admin panel.
...@@ -55,3 +57,20 @@ class CustomUserAdmin(UserAdmin): ...@@ -55,3 +57,20 @@ class CustomUserAdmin(UserAdmin):
), ),
) )
inlines = (UserParticipationInline, ) inlines = (UserParticipationInline, )
actions = ["export_as_csv"]
def export_as_csv(self, request, queryset):
meta = self.model._meta
field_names = [field.name for field in meta.fields]
response = HttpResponse(content_type='text/csv')
response['Content-Disposition'] = 'attachment; filename={}.csv'.format(
meta)
writer = csv.writer(response)
writer.writerow(field_names)
for obj in queryset:
row = writer.writerow([getattr(obj, field)
for field in field_names])
return response
export_as_csv.short_description = "Exporter au format CSV"
...@@ -5,7 +5,8 @@ from django.contrib import admin, messages ...@@ -5,7 +5,8 @@ from django.contrib import admin, messages
from django.template.defaultfilters import pluralize from django.template.defaultfilters import pluralize
from django.urls import reverse from django.urls import reverse
from django.utils.safestring import mark_safe from django.utils.safestring import mark_safe
from django.http import HttpResponse
import csv
from .models import Participation, Place, Visit from .models import Participation, Place, Visit
# Register your models here. # Register your models here.
...@@ -117,12 +118,30 @@ class ParticipationAdmin(admin.ModelAdmin): ...@@ -117,12 +118,30 @@ class ParticipationAdmin(admin.ModelAdmin):
'accepted', 'present') 'accepted', 'present')
list_filter = ('submitted', 'accepted', 'present') list_filter = ('submitted', 'accepted', 'present')
actions = [accept_selected_participations, reject_selected_participations] actions = [accept_selected_participations, reject_selected_participations]
def user_link(self, book): def user_link(self, book):
url = reverse("admin:users_user_change", args=[book.user.id]) url = reverse("admin:users_user_change", args=[book.user.id])
link = '<a href="%s">%s</a>' % (url, book.user.email) link = '<a href="%s">%s</a>' % (url, book.user.email)
return mark_safe(link) return mark_safe(link)
user_link.short_description = 'Utilisateur' user_link.short_description = 'Utilisateur'
actions = ["export_as_csv"]
def export_as_csv(self, request, queryset):
meta = self.model._meta
field_names = [field.name for field in meta.fields]
response = HttpResponse(content_type='text/csv')
response['Content-Disposition'] = 'attachment; filename={}.csv'.format(
meta)
writer = csv.writer(response)
writer.writerow(field_names)
for obj in queryset:
row = writer.writerow([getattr(obj, field)
for field in field_names])
return response
export_as_csv.short_description = "Exporter au format CSV"
@admin.register(Visit.organizers.through) @admin.register(Visit.organizers.through)
class VisitOrganizersAdmin(admin.ModelAdmin): class VisitOrganizersAdmin(admin.ModelAdmin):
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment