partner.py 11 KB

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