Commit 53e09ba4 authored by Gladys Forte's avatar Gladys Forte

awaiting fix

parent af2e1c27
......@@ -175,19 +175,7 @@ class ChangeRequestFormsViewset(viewsets.ModelViewSet):
awaiting_filtered = change_request.filter_awaiting(self.queryset, id_number)
# awaiting = awaiting_filtered.count()
awaiting = 0
for awaits in awaiting_filtered:
if awaits.status.lower() == 'rejected':
print("rejected")
elif awaits.status.lower() == 'closed':
print("closed")
elif awaits.status.lower() == 'cancelled':
print("cancelled")
else:
awaiting = awaiting + 1
awaiting = awaiting_filtered.count()
overdue_filtered = change_request.filter_overdue(self.queryset)
......@@ -237,9 +225,12 @@ class ChangeRequestFormsViewset(viewsets.ModelViewSet):
request.query_params.get('form_type'),
)
self.queryset = self.queryset.order_by('-created')
if len(request.query_params) == 0:
queryset = self.queryset.order_by('-created')
else:
queryset = self.filter_queryset(self.queryset)
page = self.paginate_queryset(self.queryset)
page = self.paginate_queryset(queryset)
if page is not None:
serializer = self.get_serializer(page, many=True)
......@@ -269,7 +260,8 @@ class ChangeRequestFormsViewset(viewsets.ModelViewSet):
id_number = self.request.user.code
self.queryset = change_request.list_by_user(id_number)
self.queryset = change_request.list_by_user_without_dept(
id_number)
self.queryset = change_request.filter_overdue(self.queryset)
......@@ -284,8 +276,12 @@ class ChangeRequestFormsViewset(viewsets.ModelViewSet):
request.query_params.get('form_type'),
)
self.queryset = self.queryset.order_by('-created')
page = self.paginate_queryset(self.queryset)
if len(request.query_params) == 0:
queryset = self.queryset.order_by('-created')
else:
queryset = self.filter_queryset(self.queryset)
page = self.paginate_queryset(queryset)
if page is not None:
serializer = self.get_serializer(page, many=True)
......@@ -315,7 +311,7 @@ class ChangeRequestFormsViewset(viewsets.ModelViewSet):
id_number = self.request.user.code
self.queryset = change_request.list_by_user(id_number)
self.queryset = change_request.list_by_user_without_dept(id_number)
self.queryset = change_request.filter_awaiting(
self.queryset, id_number)
......@@ -331,13 +327,12 @@ class ChangeRequestFormsViewset(viewsets.ModelViewSet):
request.query_params.get('form_type'),
)
self.queryset = self.queryset.filter(
~Q(status='Rejected') |
~Q(status='Closed') |
~Q(status='Cancelled'))
if len(request.query_params) == 0:
queryset = self.queryset.order_by('-created')
else:
queryset = self.filter_queryset(self.queryset)
self.queryset = self.queryset.order_by('-created')
page = self.paginate_queryset(self.queryset)
page = self.paginate_queryset(queryset)
if page is not None:
serializer = self.get_serializer(page, many=True)
......
......@@ -34,7 +34,27 @@ def list_by_user(user_id_number):
return_queryset = models.ChangeRequestFormHeader.objects.filter(
Q(frm_approvers__user__code=user_id_number) |
Q(frm_stakes__user__code=user_id_number) |
Q(requested_to_department__in=priviledgeCrs) |
Q(requested_by_user=user_id_number) |
Q(requested_to_department__in=priviledgeCrs)
).exclude(
Q(status__icontains='Draft') &
~Q(requested_by_user=user_id_number)
).distinct()
return return_queryset
except Exception as e:
return_queryset = None
return return_queryset
def list_by_user_without_dept(user_id_number):
try:
return_queryset = models.ChangeRequestFormHeader.objects.filter(
Q(frm_approvers__user__code=user_id_number) |
Q(frm_stakes__user__code=user_id_number) |
Q(requested_by_user=user_id_number)
).exclude(
Q(status__icontains='Draft') &
......@@ -178,25 +198,29 @@ def filter_awaiting(base_queryset,
no_actions = models.ChangeRequestFormApprovers.objects.filter(
Q(form_code=query.form_code) &
(Q(action='') | Q(action=None))
) # .aggregate(Min('level'))
print("hello")
).order_by("level")
for no_action in no_actions:
print(no_action.level)
check_with_same_level = models.ChangeRequestFormApprovers.objects.filter(
Q(form_code=query.form_code) &
Q(level=int(no_action.level))
).exclude(Q(action='') | Q(action=None))
print(check_with_same_level)
if not check_with_same_level:
print("pumasok")
if no_action.user.code == user_id_number:
awaiting_included.append(query.form_code)
break
else:
break
return_queryset = return_queryset.filter(
form_code__in=awaiting_included)
form_code__in=awaiting_included
).exclude(
(Q(status__icontains='Rejected') |
Q(status__icontains='Closed') |
Q(status__icontains='Cancelled') |
Q(status__icontains='Draft'))
)
except Exception as e:
pass
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment