order.py 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. from dbsynce.models import Orders
  2. from django.contrib.auth.decorators import login_required
  3. from django.contrib.auth.mixins import UserPassesTestMixin
  4. from django.http import JsonResponse
  5. from django.utils.translation import gettext as _
  6. from django_tables2 import SingleTableView
  7. from sharix_admin.tables import OrdersTable
  8. from sharix_admin.utils import group_required
  9. from datetime import datetime, timedelta
  10. from dbsynce.lib.core import parse_requirements, get_admin_url
  11. from dbsynce.models import Documents
  12. from django.contrib import messages
  13. from django.db import transaction
  14. from django.urls import reverse_lazy
  15. from django.views.generic.edit import FormView
  16. from django.views.generic import DetailView
  17. from tickets.models import Ticket, TicketList
  18. from sharix_admin.forms import OrderForm
  19. from sharix_admin.utils import *
  20. from dbsynce.lib.data import *
  21. from .base import BaseView
  22. from django.db.models import Q
  23. from django.contrib.auth import get_user_model
  24. class OrdersListView(BaseView, SingleTableView):
  25. #class OrdersListView(UserPassesTestMixin, SingleTableView):
  26. table_class = OrdersTable
  27. queryset = Orders.objects.all()
  28. template_name = 'sharix_admin/orders.html'
  29. page_title = 'Заказы'
  30. page_name = 'orders'
  31. def get_context_data(self, **kwargs):
  32. context = super().get_context_data(**kwargs)
  33. context.update({
  34. 'title': _('Orders'),
  35. 'object_list': context['object_list'],
  36. })
  37. return context
  38. def get_queryset(self):
  39. queryset = super().get_queryset()
  40. search_query = self.request.GET.get('q', '').strip()
  41. if search_query:
  42. queryset = queryset.filter(
  43. Q(id__icontains=search_query) |
  44. Q(user__first_name__icontains=search_query) |
  45. Q(user__first_name__icontains=search_query) |
  46. Q(status__icontains=search_query)
  47. ).distinct()
  48. return queryset
  49. def testing(self, queryset, is_descending):
  50. queryset = queryset.annotate.order_by("-" if is_descending else "")
  51. return (queryset, True)
  52. def test_func(self) -> bool or None:
  53. return True
  54. @login_required
  55. @group_required('PARTNER-SUPERVISOR')
  56. def change_order_local_status(request):
  57. if request.method == 'POST':
  58. order_id = request.POST.get('order_local')
  59. new_status = request.POST.get('new_status')
  60. try:
  61. order = Orders.objects.get(pk=order_id)
  62. order.status = new_status
  63. order.save()
  64. return JsonResponse({'status': 'success'})
  65. except Orders.DoesNotExist:
  66. return JsonResponse({'status': 'error', 'message': 'Order not found'}, status=404)
  67. return JsonResponse({'status': 'error'}, status=400)
  68. class OrderEditView(BaseView, FormView):
  69. form_class = OrderForm
  70. template_name = "sharix_admin/order.html"
  71. success_url = reverse_lazy("sharix_admin:orders")
  72. page_title = 'Изменить заказ'
  73. page_name = 'order_edit'
  74. def test_func(self):
  75. return "CLIENT" in self.user_groups
  76. def form_valid(self, form):
  77. with transaction.atomic():
  78. instance = form.save(commit=False)
  79. instance.repr = self.request.user
  80. instance.save()
  81. #instance.ticket_status = create_ticket_order_local_activation_by_metaservice_supervisor(self.request.user, instance)
  82. instance.save()
  83. doc_codes = parse_requirements(instance.requirements)
  84. # Documents.objects.bulk_create([
  85. # Documents(
  86. # order_local=instance,
  87. # user=self.request.user,
  88. # doc_type=doc_code
  89. # ) for doc_code in doc_codes
  90. # ])
  91. messages.success(self.request, 'Заказ успешно обновлён!')
  92. return super().form_valid(form)
  93. class OrderCreateView(BaseView, FormView):
  94. form_class = OrderForm
  95. template_name = "sharix_admin/order.html"
  96. success_url = reverse_lazy("sharix_admin:orders")
  97. page_title = 'Добавить заказ'
  98. page_name = 'order/add/'
  99. def test_func(self):
  100. return "CLIENT" in self.user_groups
  101. #return not "CLIENT" in self.user_groups
  102. def form_valid(self, form):
  103. with transaction.atomic():
  104. instance = form.save(commit=False)
  105. instance.repr = self.request.user
  106. instance.save()
  107. instance.ticket_status = create_ticket_order(self.request.user, instance)
  108. #create_ticket_order_local_activation_by_partner_admin(self.request.user, instance)
  109. instance.save()
  110. # doc_codes = parse_requirements(instance.requirements)
  111. # Documents.objects.bulk_create([
  112. # Documents(
  113. # order_local=instance,
  114. # user=self.request.user,
  115. # doc_type=doc_code
  116. # ) for doc_code in doc_codes
  117. # ])
  118. messages.success(self.request, 'Заказ успешно создан!')
  119. return super().form_valid(form)
  120. class OrderDetailView(BaseView, DetailView):
  121. model = Orders
  122. template_name = 'sharix_admin/order.html'
  123. context_object_name = 'order'
  124. def get_context_data(self, **kwargs):
  125. context = super().get_context_data(**kwargs)
  126. context['title'] = _('Order Details')
  127. return context