chore: update issue search for cycle and modules (#1314)

* chore: update issue search for cycle and modules

* dev: return state name, group and color in search

* dev: sub issue search
This commit is contained in:
pablohashescobar 2023-06-20 10:27:45 +05:30 committed by GitHub
parent 7a991720a8
commit d7097330ef
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -206,8 +206,12 @@ class IssueSearchEndpoint(BaseAPIView):
def get(self, request, slug, project_id): def get(self, request, slug, project_id):
try: try:
query = request.query_params.get("search", False) query = request.query_params.get("search", False)
parent = request.query_params.get("parent", False) parent = request.query_params.get("parent", "false")
blocker_blocked_by = request.query_params.get("blocker_blocked_by", False) blocker_blocked_by = request.query_params.get("blocker_blocked_by", "false")
cycle = request.query_params.get("cycle", "false")
module = request.query_params.get("module", "false")
sub_issue = request.query_params.get("sub_issue", "false")
issue_id = request.query_params.get("issue_id", False) issue_id = request.query_params.get("issue_id", False)
issues = Issue.issue_objects.filter( issues = Issue.issue_objects.filter(
@ -235,6 +239,18 @@ class IssueSearchEndpoint(BaseAPIView):
~Q(blocked_issues__block=issue), ~Q(blocked_issues__block=issue),
~Q(blocker_issues__blocked_by=issue), ~Q(blocker_issues__blocked_by=issue),
) )
if sub_issue == "true" and issue_id:
issue = Issue.issue_objects.get(pk=issue_id)
issues = issues.filter(~Q(pk=issue_id), parent__isnull=True)
if issue.parent:
issues = issues.filter(~Q(pk=issue.parent_id))
if cycle == "true":
issues = issues.exclude(issue_cycle__isnull=False)
if module == "true":
issues = issues.exclude(issue_module__isnull=False)
return Response( return Response(
issues.values( issues.values(
@ -244,6 +260,9 @@ class IssueSearchEndpoint(BaseAPIView):
"project__identifier", "project__identifier",
"project_id", "project_id",
"workspace__slug", "workspace__slug",
"state__name",
"state__group",
"state__color",
), ),
status=status.HTTP_200_OK, status=status.HTTP_200_OK,
) )
@ -252,7 +271,7 @@ class IssueSearchEndpoint(BaseAPIView):
{"error": "Issue Does not exist"}, status=status.HTTP_400_BAD_REQUEST {"error": "Issue Does not exist"}, status=status.HTTP_400_BAD_REQUEST
) )
except Exception as e: except Exception as e:
capture_exception(e) print(e)
return Response( return Response(
{"error": "Something went wrong please try again later"}, {"error": "Something went wrong please try again later"},
status=status.HTTP_400_BAD_REQUEST, status=status.HTTP_400_BAD_REQUEST,