|
@@ -1,4 +1,9 @@
|
|
|
from dbsynce.models import Resource
|
|
|
+
|
|
|
+from django.http import JsonResponse
|
|
|
+from django.http import Http404
|
|
|
+from django.shortcuts import render
|
|
|
+
|
|
|
from django.contrib.auth.decorators import login_required
|
|
|
from django.contrib.auth.mixins import UserPassesTestMixin
|
|
|
from django.http import JsonResponse
|
|
@@ -17,6 +22,7 @@ from django.contrib import messages
|
|
|
from django.db import transaction
|
|
|
from django.urls import reverse_lazy
|
|
|
from django.views.generic.edit import FormView
|
|
|
+from django.views.generic.edit import UpdateView
|
|
|
from tickets.models import Ticket, TicketList
|
|
|
|
|
|
from sharix_admin.forms import ResourceForm
|
|
@@ -25,13 +31,18 @@ from dbsynce.lib.data import *
|
|
|
from .base import BaseView
|
|
|
from django.db.models import Q
|
|
|
|
|
|
+from dbsynce.models import Documents, DocumentFile
|
|
|
+from sharix_admin.forms import DocumentUploadForm
|
|
|
+from django.shortcuts import get_object_or_404, redirect
|
|
|
+from django.core.files.storage import default_storage
|
|
|
+
|
|
|
from dbsynce.docs.database.resource import Resource as ResourceHelpTexts
|
|
|
from dbsynce.docs.verbose_names.resource import Resource as ResourceVerboseNames
|
|
|
|
|
|
class ResourcesListView(BaseView, UserPassesTestMixin, SingleTableView):
|
|
|
table_class = ResourcesTable
|
|
|
queryset = Resource.objects.all()
|
|
|
- template_name = 'sharix_admin/resource_list.html'
|
|
|
+ template_name = 'sharix_admin/resources.html'
|
|
|
page_title = 'Ресурсы'
|
|
|
page_name = 'resources'
|
|
|
|
|
@@ -63,27 +74,45 @@ class ResourcesListView(BaseView, UserPassesTestMixin, SingleTableView):
|
|
|
return True
|
|
|
|
|
|
|
|
|
-@login_required
|
|
|
-@group_required('PARTNER-ADMIN')
|
|
|
+#@login_required
|
|
|
+#@group_required('PARTNER-ADMIN')
|
|
|
def change_resource_status(request):
|
|
|
if request.method == 'POST':
|
|
|
- resource = request.POST.get('resource')
|
|
|
+ resource_id = request.POST.get('resource_id')
|
|
|
new_status = request.POST.get('new_status')
|
|
|
|
|
|
- resource = Resource.objects.get(pk=resource)
|
|
|
+ resource = Resource.objects.get(pk=resource_id)
|
|
|
resource.status = new_status
|
|
|
resource.save()
|
|
|
return JsonResponse({'status': 'success'})
|
|
|
else:
|
|
|
return JsonResponse({'status': 'error'})
|
|
|
|
|
|
-class ResourceEditView(BaseView, FormView):
|
|
|
+#class ResourceEditView(BaseView, FormView):
|
|
|
+class ResourceEditView(BaseView, UpdateView):
|
|
|
form_class = ResourceForm
|
|
|
+ model = Resource
|
|
|
template_name = "sharix_admin/resource.html"
|
|
|
- success_url = reverse_lazy("sharix_admin:resource_list")
|
|
|
+ success_url = reverse_lazy("sharix_admin:resources")
|
|
|
page_title = 'Изменить ресурс'
|
|
|
page_name = 'resource_edit'
|
|
|
|
|
|
+ def get_context_data(self, **kwargs):
|
|
|
+ context = super().get_context_data(**kwargs)
|
|
|
+
|
|
|
+ try:
|
|
|
+ docs = Documents.objects.filter(resource=self.object.id)
|
|
|
+ except Documents.DoesNotExist:
|
|
|
+ docs=[]
|
|
|
+
|
|
|
+ context.update({
|
|
|
+ 'title': self.page_title,
|
|
|
+ 'object': self.object,
|
|
|
+ "current_page": "sharix_admin:resources",
|
|
|
+ })
|
|
|
+ context['docs'] = docs
|
|
|
+ return context
|
|
|
+
|
|
|
# Проверяем состояит ли текущий пользователь в группе PARTNER-ADMIN
|
|
|
def test_func(self):
|
|
|
return "PARTNER-ADMIN" in self.user_groups
|
|
@@ -114,7 +143,7 @@ class ResourceEditView(BaseView, FormView):
|
|
|
doc_codes = parse_requirements(instance.requirements)
|
|
|
Documents.objects.bulk_create([
|
|
|
Documents(
|
|
|
- company=instance,
|
|
|
+ resource=instance,
|
|
|
user=self.request.user,
|
|
|
doc_type=doc_code
|
|
|
) for doc_code in doc_codes
|
|
@@ -187,13 +216,13 @@ class ResourceDetailView(BaseView, DetailView):
|
|
|
page_title = 'О ресурсе'
|
|
|
page_name = 'resource_detail'
|
|
|
|
|
|
- def detail_view(request, primary_key):
|
|
|
+ def detail_view(self, request, primary_key):
|
|
|
try:
|
|
|
resource = Resource.objects.get(pk=primary_key)
|
|
|
except Resource.DoesNotExist:
|
|
|
raise Http404('Provider does not exist')
|
|
|
|
|
|
- return render(request, template_name, context={
|
|
|
+ return render(request, self.template_name, context={
|
|
|
'help_texts': ResourceHelpTexts,
|
|
|
'captions': ResourceVerboseNames,
|
|
|
})
|
|
@@ -201,6 +230,95 @@ class ResourceDetailView(BaseView, DetailView):
|
|
|
def get_context_data(self, **kwargs):
|
|
|
context = super().get_context_data(**kwargs)
|
|
|
context['help_texts'] = ResourceHelpTexts
|
|
|
- context['captions'] = ResourceVerboseNames
|
|
|
+ context['captions'] = ResourceVerboseNames
|
|
|
return context
|
|
|
+
|
|
|
+
|
|
|
+class ResourceDocUploadView(BaseView, FormView):
|
|
|
+ # FIXME: Загрузка новых документов должна деактивировать текущего партнера (предварительно это работа обработчиков)
|
|
|
+ template_name = 'sharix_admin/include/doc_upload.html'
|
|
|
+ form_class = DocumentUploadForm
|
|
|
+ success_url = reverse_lazy('partner_detail')
|
|
|
+
|
|
|
+ def dispatch(self, request, *args, **kwargs):
|
|
|
+ self.company = get_object_or_404(Resource, repr=self.request.user)
|
|
|
+ self.doc = Documents.objects.filter(
|
|
|
+ user=self.request.user,
|
|
|
+ resource=self.resource,
|
|
|
+ doc_type=kwargs.get('doc_code')
|
|
|
+ ).first()
|
|
|
+
|
|
|
+ self.doc_name = self.doc.get_doc_type_display()
|
|
|
+ self.page_title = "Изменение документа ресурса: " + self.doc_name
|
|
|
+
|
|
|
+ return super().dispatch(request, *args, **kwargs)
|
|
|
+
|
|
|
+ def form_valid(self, form):
|
|
|
+ with transaction.atomic():
|
|
|
+ # Удаляем существующие файлы и записи из базы данных
|
|
|
+ existing_files = DocumentFile.objects.filter(document=self.doc)
|
|
|
+ for existing_file in existing_files:
|
|
|
+ # Удаляем файл с сервера
|
|
|
+ if default_storage.exists(existing_file.file.path):
|
|
|
+ default_storage.delete(existing_file.file.path)
|
|
|
+
|
|
|
+ # Удаляем запись о файле из базы данных
|
|
|
+ existing_file.delete()
|
|
|
+
|
|
|
+ # Загрузка новых файлов
|
|
|
+ doc_file = self.request.FILES.getlist("doc_file")
|
|
|
+ for file in doc_file:
|
|
|
+ DocumentFile.objects.create(
|
|
|
+ document=self.doc,
|
|
|
+ file=file
|
|
|
+ )
|
|
|
+
|
|
|
+ # Создание нового тикета и архивация старого
|
|
|
+ if self.doc.ticket_status:
|
|
|
+ self.doc.ticket_status.archive()
|
|
|
+
|
|
|
+ self.doc.expire_date = self.request.POST.get('doc_expire_date') if self.request.POST[
|
|
|
+ 'doc_expire_date'] else None
|
|
|
+ self.doc.ticket_status = create_ticket_company_docs_verification(self.request.user, self.company, self.doc)
|
|
|
+
|
|
|
+ self.doc.save()
|
|
|
+
|
|
|
+ # Отправляем пользователю уведомление на страницу об успехе операции
|
|
|
+ messages.success(self.request,
|
|
|
+ f'Файлы документа "{self.doc_name}" успешно загружены и теперь проходят проверку!')
|
|
|
+ return super().form_valid(form)
|
|
|
+
|
|
|
+
|
|
|
+class ResourceDocView(BaseView, DetailView):
|
|
|
+#class PartnerDocView(PartnerBaseView, DetailView):
|
|
|
+ model = Documents
|
|
|
+ template_name = 'sharix_admin/include/doc.html'
|
|
|
+ context_object_name = 'doc'
|
|
|
+
|
|
|
+ def dispatch(self, request, *args, **kwargs):
|
|
|
+ self.company = get_object_or_404(Resource, repr=self.request.user)
|
|
|
+
|
|
|
+ self.doc = Documents.objects.filter(
|
|
|
+ user=self.request.user,
|
|
|
+ resource=self.resource,
|
|
|
+ doc_type=kwargs.get('doc_code')
|
|
|
+ ).first()
|
|
|
+
|
|
|
+ if not self.doc:
|
|
|
+ return self.handle_no_permission()
|
|
|
+
|
|
|
+ self.doc_name = self.doc.get_doc_type_display()
|
|
|
+ self.page_title = _("Детали документа: ") + self.doc_name
|
|
|
+
|
|
|
+ return super().dispatch(request, *args, **kwargs)
|
|
|
+
|
|
|
+ def get_object(self, queryset=None):
|
|
|
+ return self.doc
|
|
|
+
|
|
|
+ def get_context_data(self, **kwargs):
|
|
|
+ context = super().get_context_data(**kwargs)
|
|
|
+ doc_files = DocumentFile.objects.filter(document=self.doc)
|
|
|
+ context.update({"doc_files": doc_files})
|
|
|
+ return context
|
|
|
+
|
|
|
|