فهرست منبع

adding scatch for user info page

ShariX Developer 20 ساعت پیش
والد
کامیت
d80fcfe899
2فایلهای تغییر یافته به همراه45 افزوده شده و 0 حذف شده
  1. 1 0
      sharix_admin/urls.py
  2. 44 0
      sharix_admin/views/user_info.py

+ 1 - 0
sharix_admin/urls.py

@@ -94,6 +94,7 @@ urlpatterns = [
 #    path('relationship', login_required(RelationshipListView.as_view()), name='relationship'),    
 #    path('relationship/change_status/', change_access_status, name='relationship/change_status'),
 #    path('active_users', login_required(ActiveUsersListView.as_view()), name='active_users'),
+#    path('user/detail/<int:pk>', login_required(UserDetailView.as_view()), name='user_detail'),
 #    path('active_users/change_status/', change_access_status, name='active_users/change_status'),
 #    path('changelog', login_required(ChangelogListView.as_view()), name='changelog'),
 #    path('closing-documents', login_required(ClosingDocumentsListView.as_view()), name='closing_documents'),

+ 44 - 0
sharix_admin/views/user_info.py

@@ -5,7 +5,11 @@ from django.utils.translation import gettext as _
 from django_tables2 import SingleTableView
 
 from sharix_admin.tables import UserInfoTable
+from django.views.generic import DetailView
 
+from dbsynce.models import Company, Documents, DocumentFile
+
+from .base import BaseView
 
 class UserListView(UserPassesTestMixin, SingleTableView):
     table_class = UserInfoTable
@@ -26,3 +30,43 @@ class UserListView(UserPassesTestMixin, SingleTableView):
         if bool(self.request.user.groups.filter(name=group_names)) or self.request.user.is_superuser:
             return True
         return False
+
+#TODO change to smth working
+class UserDetailView(BaseView, DetailView):
+#class UserDetailView(UserPassesTestMixin, DetailView):
+
+#class PartnerDetailView(PartnerBaseView, DetailView):
+#TODO - change to sharix user
+    model = Company
+#TODO create this template
+#    template_name = 'sharix_admin/user_detail.html'
+    template_name = 'sharix_admin/user_info.html'
+    context_object_name = 'user_detail'
+    page_title = 'Информация о пользователе'
+
+#TODO change to smth about user
+    def get_object(self, queryset=None):
+        return get_object_or_404(Company, repr=self.request.user)
+
+    def get_context_data(self, **kwargs):
+        context = super().get_context_data(**kwargs)
+
+        if not pk:
+            docs = Documents.objects.filter(
+                user=pk,
+                company=company.objects.filter(user=pk)
+                ).prefetch_related('files').order_by('doc_type')
+                #user=self.request.user,
+                #company=self.object
+            #).prefetch_related('files').order_by('doc_type')
+
+            context.update({"docs": docs})
+        else:
+            docs = Documents.objects.filter(
+                user=self.request.user,
+                company=self.object
+            ).prefetch_related('files').order_by('doc_type')
+
+            context.update({"docs": docs})
+
+        return context