|
| 1 | +import tablib |
| 2 | + |
1 | 3 | from django.contrib import admin |
| 4 | +from django.http import HttpResponse |
| 5 | +from django.urls import path |
| 6 | +from django.utils import timezone |
2 | 7 |
|
3 | 8 | from partner_programs.models import PartnerProgram, PartnerProgramUserProfile |
4 | 9 |
|
@@ -28,10 +33,76 @@ class PartnerProgramAdmin(admin.ModelAdmin): |
28 | 33 |
|
29 | 34 | filter_horizontal = ("users",) |
30 | 35 | date_hierarchy = "datetime_started" |
| 36 | + change_form_template = "partner_programs/admin/programs_change_form.html" |
| 37 | + |
| 38 | + def get_urls(self): |
| 39 | + default_urls = super(PartnerProgramAdmin, self).get_urls() |
| 40 | + custom_urls = [ |
| 41 | + path( |
| 42 | + "export/<int:object_id>/", |
| 43 | + self.admin_site.admin_view(self.get_export_file_view), |
| 44 | + name="export_profiles", |
| 45 | + ) |
| 46 | + ] |
| 47 | + return custom_urls + default_urls |
| 48 | + |
| 49 | + def changeform_view(self, request, object_id=None, form_url="", extra_context=None): |
| 50 | + extra_context = {"object_id": int(object_id)} |
| 51 | + res = super(PartnerProgramAdmin, self).changeform_view( |
| 52 | + request, object_id, extra_context=extra_context |
| 53 | + ) |
| 54 | + return res |
| 55 | + |
| 56 | + def get_export_file_view(self, request, object_id): |
| 57 | + program = PartnerProgram.objects.get(pk=object_id) |
| 58 | + return self.get_export_file(program) |
| 59 | + |
| 60 | + def get_export_file(self, partner_program: PartnerProgram): |
| 61 | + json_schema = partner_program.data_schema |
| 62 | + profiles = PartnerProgramUserProfile.objects.filter( |
| 63 | + partner_program=partner_program |
| 64 | + ) |
| 65 | + to_delete_from_json_scheme = [] |
| 66 | + column_names = ["Имя", "Фамилия", "Отчество", "Почта", "Дата рождения"] |
| 67 | + for field_key in json_schema: |
| 68 | + if "name" not in json_schema[field_key]: |
| 69 | + to_delete_from_json_scheme.append(field_key) |
| 70 | + else: |
| 71 | + column_names.append(json_schema[field_key]["name"]) |
| 72 | + |
| 73 | + for field_key in to_delete_from_json_scheme: |
| 74 | + del json_schema[field_key] |
| 75 | + |
| 76 | + response_data = tablib.Dataset(headers=column_names) |
| 77 | + for profile in profiles: |
| 78 | + row = [ |
| 79 | + profile.user.first_name, |
| 80 | + profile.user.last_name, |
| 81 | + profile.user.patronymic, |
| 82 | + profile.user.email, |
| 83 | + str(profile.user.birthday), |
| 84 | + ] |
| 85 | + |
| 86 | + json_data = profile.partner_program_data |
| 87 | + for key in json_schema: |
| 88 | + row.append(json_data.get(key, "")) |
| 89 | + response_data.append(row) |
| 90 | + |
| 91 | + binary_data = response_data.export("xlsx") |
| 92 | + file_name = ( |
| 93 | + f'{partner_program.name} {timezone.now().strftime("%d-%m-%Y %H:%M:%S")}' |
| 94 | + ) |
| 95 | + response = HttpResponse( |
| 96 | + content_type="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", |
| 97 | + headers={"Content-Disposition": f'attachment; filename="{file_name}.xlsx"'}, |
| 98 | + ) |
| 99 | + response.write(binary_data) |
| 100 | + return response |
31 | 101 |
|
32 | 102 |
|
33 | 103 | @admin.register(PartnerProgramUserProfile) |
34 | 104 | class PartnerProgramUserProfileAdmin(admin.ModelAdmin): |
| 105 | + |
35 | 106 | list_display = ( |
36 | 107 | "id", |
37 | 108 | "user", |
|
0 commit comments