From 06618006c2ba1aaf41b708b85d05fcec25d3e3a9 Mon Sep 17 00:00:00 2001 From: pablohashescobar <118773738+pablohashescobar@users.noreply.github.com> Date: Fri, 19 May 2023 13:00:38 +0530 Subject: [PATCH] fix: cycle date check endpoint (#1074) --- apiserver/plane/api/views/cycle.py | 28 ++++++++++++++++++++-------- 1 file changed, 20 insertions(+), 8 deletions(-) diff --git a/apiserver/plane/api/views/cycle.py b/apiserver/plane/api/views/cycle.py index ee85f22e1..b12b49b2f 100644 --- a/apiserver/plane/api/views/cycle.py +++ b/apiserver/plane/api/views/cycle.py @@ -3,7 +3,17 @@ import json # Django imports from django.db import IntegrityError -from django.db.models import OuterRef, Func, F, Q, Exists, OuterRef, Count, Prefetch, Sum +from django.db.models import ( + OuterRef, + Func, + F, + Q, + Exists, + OuterRef, + Count, + Prefetch, + Sum, +) from django.core import serializers from django.utils import timezone from django.utils.decorators import method_decorator @@ -433,7 +443,7 @@ class CycleDateCheckEndpoint(BaseAPIView): try: start_date = request.data.get("start_date", False) end_date = request.data.get("end_date", False) - + cycle_id = request.data.get("cycle_id") if not start_date or not end_date: return Response( {"error": "Start date and end date both are required"}, @@ -441,12 +451,14 @@ class CycleDateCheckEndpoint(BaseAPIView): ) cycles = Cycle.objects.filter( - Q(start_date__lte=start_date, end_date__gte=start_date) - | Q(start_date__lte=end_date, end_date__gte=end_date) - | Q(start_date__gte=start_date, end_date__lte=end_date), - workspace__slug=slug, - project_id=project_id, - ) + Q(workspace__slug=slug) + & Q(project_id=project_id) + & ( + Q(start_date__lte=start_date, end_date__gte=start_date) + | Q(start_date__lte=end_date, end_date__gte=end_date) + | Q(start_date__gte=start_date, end_date__lte=end_date) + ) + ).exclude(pk=cycle_id) if cycles.exists(): return Response(