partner.py 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. from dbsynce.models import Company, Documents, DocumentFile
  2. from django.contrib import messages
  3. from django.core.files.storage import default_storage
  4. from django.db import transaction
  5. from django.shortcuts import get_object_or_404, redirect
  6. from django.urls import reverse_lazy
  7. from django.views.generic import DetailView
  8. from django.views.generic.edit import FormView
  9. from sharix_admin.forms import CompanyForm, DocumentUploadForm
  10. from sharix_admin.utils import *
  11. from .base import BaseView
  12. from django.contrib.auth.mixins import UserPassesTestMixin
  13. from django_tables2 import SingleTableView
  14. from sharix_admin.tables import PartnersTable
  15. from django.contrib.auth.decorators import login_required
  16. from django.http import JsonResponse
  17. from django.utils.translation import gettext as _
  18. from django_tables2 import SingleTableView
  19. from sharix_admin.tables import PartnersTable
  20. from sharix_admin.utils import group_required
  21. class MyPartnerBaseView(BaseView):
  22. page_name = 'partner'
  23. # Проверяем состояит ли текущий пользователь в группе PARTNER-ADMIN
  24. def test_func(self):
  25. return "PARTNER-ADMIN" in self.user_groups
  26. class PartnerDetailView(BaseView, DetailView):
  27. model = Company
  28. template_name = 'sharix_admin/partner_detail.html'
  29. #template_name = 'sharix_admin/partner.html'
  30. context_object_name = 'company'
  31. page_title = 'О партнере'
  32. page_name = 'partner_detail'
  33. def detail_view(request, primary_key):
  34. try:
  35. company = Company.objects.get(pk=primary_key)
  36. except Company.DoesNotExist:
  37. raise Http404('Company does not exist')
  38. return render(request, template_name, context={'company': company})
  39. class MyPartnerDetailView(MyPartnerBaseView, DetailView):
  40. model = Company
  41. template_name = 'sharix_admin/partner.html'
  42. context_object_name = 'company'
  43. page_title = 'О партнере'
  44. def get_object(self, queryset=None):
  45. return get_object_or_404(Company, repr=self.request.user)
  46. def get_context_data(self, **kwargs):
  47. context = super().get_context_data(**kwargs)
  48. if not pk:
  49. docs = Documents.objects.filter(
  50. user=pk,
  51. company=company.objects.filter(user=pk)
  52. ).prefetch_related('files').order_by('doc_type')
  53. #user=self.request.user,
  54. #company=self.object
  55. #).prefetch_related('files').order_by('doc_type')
  56. context.update({"docs": docs})
  57. else:
  58. docs = Documents.objects.filter(
  59. user=self.request.user,
  60. company=self.object
  61. ).prefetch_related('files').order_by('doc_type')
  62. context.update({"docs": docs})
  63. return context
  64. class PartnerEditView(MyPartnerBaseView, FormView):
  65. template_name = 'sharix_admin/partner_edit.html'
  66. form_class = CompanyForm
  67. success_url = reverse_lazy('partner_detail')
  68. page_title = 'Изменение данных партнера'
  69. def get_form_kwargs(self):
  70. kwargs = super().get_form_kwargs()
  71. kwargs['instance'] = get_object_or_404(Company, repr=self.request.user)
  72. return kwargs
  73. def form_valid(self, form):
  74. with transaction.atomic():
  75. # Сохраняем изменения
  76. form.save()
  77. # Получаем текущий объект компании и деактивируем ее
  78. current_company = form.instance
  79. current_company.deactivate()
  80. # Выполняем пересоздание тикета на активацию партнера
  81. current_company.ticket_status.archive()
  82. create_ticket_company_activation(self.request.user, current_company)
  83. # Отправляем полAьзователю уведомление на страницу об успехе операции
  84. messages.success(self.request, 'Данные успешно изменены и теперь проходят проверку!')
  85. return super().form_valid(form)
  86. class PartnerDocUploadView(MyPartnerBaseView, FormView):
  87. # FIXME: Загрузка новых документов должна деактивировать текущего партнера (предварительно это работа обработчиков)
  88. template_name = 'sharix_admin/partner/doc_upload.html'
  89. form_class = DocumentUploadForm
  90. success_url = reverse_lazy('partner_detail')
  91. def dispatch(self, request, *args, **kwargs):
  92. self.company = get_object_or_404(Company, repr=self.request.user)
  93. self.doc = Documents.objects.filter(
  94. user=self.request.user,
  95. company=self.company,
  96. doc_type=kwargs.get('doc_code')
  97. ).first()
  98. self.doc_name = self.doc.get_doc_type_display()
  99. self.page_title = "Изменение документа партнера: " + self.doc_name
  100. return super().dispatch(request, *args, **kwargs)
  101. def form_valid(self, form):
  102. with transaction.atomic():
  103. # Удаляем существующие файлы и записи из базы данных
  104. existing_files = DocumentFile.objects.filter(document=self.doc)
  105. for existing_file in existing_files:
  106. # Удаляем файл с сервера
  107. if default_storage.exists(existing_file.file.path):
  108. default_storage.delete(existing_file.file.path)
  109. # Удаляем запись о файле из базы данных
  110. existing_file.delete()
  111. # Загрузка новых файлов
  112. doc_file = self.request.FILES.getlist("doc_file")
  113. for file in doc_file:
  114. DocumentFile.objects.create(
  115. document=self.doc,
  116. file=file
  117. )
  118. # Создание нового тикета и архивация старого
  119. if self.doc.ticket_status:
  120. self.doc.ticket_status.archive()
  121. self.doc.expire_date = self.request.POST.get('doc_expire_date') if self.request.POST[
  122. 'doc_expire_date'] else None
  123. self.doc.ticket_status = create_ticket_company_docs_verification(self.request.user, self.company, self.doc)
  124. self.doc.save()
  125. # Отправляем пользователю уведомление на страницу об успехе операции
  126. messages.success(self.request,
  127. f'Файлы документа "{self.doc_name}" успешно загружены и теперь проходят проверку!')
  128. return super().form_valid(form)
  129. class PartnerDocView(BaseView, DetailView):
  130. #class PartnerDocView(PartnerBaseView, DetailView):
  131. model = Documents
  132. template_name = 'sharix_admin/partner/doc.html'
  133. context_object_name = 'doc'
  134. def dispatch(self, request, *args, **kwargs):
  135. self.company = get_object_or_404(Company, repr=self.request.user)
  136. self.doc = Documents.objects.filter(
  137. user=self.request.user,
  138. company=self.company,
  139. doc_type=kwargs.get('doc_code')
  140. ).first()
  141. if not self.doc:
  142. return self.handle_no_permission()
  143. self.doc_name = self.doc.get_doc_type_display()
  144. self.page_title = _("Детали документа: ") + self.doc_name
  145. return super().dispatch(request, *args, **kwargs)
  146. def get_object(self, queryset=None):
  147. return self.doc
  148. def get_context_data(self, **kwargs):
  149. context = super().get_context_data(**kwargs)
  150. doc_files = DocumentFile.objects.filter(document=self.doc)
  151. context.update({"doc_files": doc_files})
  152. return context
  153. class PartnersListView(BaseView, UserPassesTestMixin, SingleTableView):
  154. page_title = _('Партнеры')
  155. page_name = 'partners'
  156. table_class = PartnersTable
  157. queryset = Company.objects.all()
  158. template_name = 'sharix_admin/partners.html'
  159. def get_queryset(self):
  160. queryset = super().get_queryset()
  161. search_query = self.request.GET.get('q', '').strip()
  162. if search_query:
  163. queryset = queryset.filter(
  164. Q(id__icontains=search_query) |
  165. Q(legalname__icontains=search_query) |
  166. Q(inn__icontains=search_query) |
  167. Q(orgn__icontains=search_query) |
  168. Q(address__icontains=search_query)
  169. ).distinct()
  170. return queryset
  171. def get_context_data(self, **kwargs):
  172. context = super().get_context_data(**kwargs)
  173. context.update({
  174. 'object_list': context['object_list'],
  175. })
  176. return context
  177. def testing(self, queryset, is_descending):
  178. queryset = queryset.annotate.order_by("-" if is_descending else "")
  179. return (queryset, True)
  180. # def get_context_data(self, **kwargs):
  181. # context = super().get_context_data(**kwargs)
  182. # context.update(get_context(self.request, {
  183. # 'title': _('Performers'),
  184. # 'object_list': context['object_list'],
  185. # }))
  186. # return context
  187. def test_func(self) -> bool or None:
  188. # group_names = ('PARTNER-ADMIN')
  189. # if bool(self.request.user.groups.filter(name=group_names)) or self.request.user.is_superuser:
  190. # return True
  191. # return False
  192. return True
  193. @login_required
  194. @group_required('METASERVICE-ADMIN')
  195. def change_partner_status(request):
  196. if request.method == 'POST':
  197. partners_id = request.POST.get('partners_id')
  198. new_status = request.POST.get('new_status')
  199. partners = Company.objects.get(pk=partners_id)
  200. partners.status = new_status
  201. partners.save()
  202. return JsonResponse({'status': 'success'})
  203. else:
  204. return JsonResponse({'status': 'error'})