diff --git a/core/apps/shared/migrations/0006_plan_is_done.py b/core/apps/shared/migrations/0006_plan_is_done.py new file mode 100644 index 0000000..6ac8ebf --- /dev/null +++ b/core/apps/shared/migrations/0006_plan_is_done.py @@ -0,0 +1,18 @@ +# Generated by Django 5.2 on 2025-11-24 10:45 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('shared', '0005_doctor_pharmacy_plan'), + ] + + operations = [ + migrations.AddField( + model_name='plan', + name='is_done', + field=models.BooleanField(default=False), + ), + ] diff --git a/core/apps/shared/models/plan.py b/core/apps/shared/models/plan.py index bfe7eed..8b1255f 100644 --- a/core/apps/shared/models/plan.py +++ b/core/apps/shared/models/plan.py @@ -10,6 +10,7 @@ class Plan(BaseModel): title = models.CharField(max_length=200) description = models.TextField() date = models.DateField() + is_done = models.BooleanField(default=False) # relations user = models.ForeignKey(User, on_delete=models.CASCADE, related_name='plans') diff --git a/core/apps/shared/serializers/plan.py b/core/apps/shared/serializers/plan.py new file mode 100644 index 0000000..e50e893 --- /dev/null +++ b/core/apps/shared/serializers/plan.py @@ -0,0 +1,25 @@ +# django +from django.db import transaction + +# rest framework +from rest_framework import serializers + +# shared +from core.apps.shared.models import Plan + + +class PlanSerializer(serializers.ModelSerializer): + class Meta: + model = Plan + fields = [ + 'id', 'title', 'description', 'date', 'is_done', 'created_at' + ] + + def create(self, validated_data): + with transaction.atomic(): + return Plan.objects.create( + title=validated_data.get('title'), + description=validated_data.get('description'), + date=validated_data.get('date'), + user=self.context.get('user'), + ) \ No newline at end of file diff --git a/core/apps/shared/urls.py b/core/apps/shared/urls.py index 3b8690e..7a86934 100644 --- a/core/apps/shared/urls.py +++ b/core/apps/shared/urls.py @@ -10,6 +10,8 @@ from core.apps.shared.views import place as pl_view from core.apps.shared.views import doctor as dc_view # shared pharmacy view from core.apps.shared.views import pharmacy as ph_view +# shared plan view +from core.apps.shared.views import plan as plan_view urlpatterns = [ # region @@ -48,4 +50,10 @@ urlpatterns = [ path('create/', ph_view.PharmacyCreateApiView.as_view(), name='pharmacy-create-api'), ] )), + path('plan/', include( + [ + path('', plan_view.PlanApiView.as_view(), name='plan-create-list-api'), + path('/complite/', plan_view.ComplitePlanApiView.as_view(), name='complite-plan-api'), + ] + )), ] \ No newline at end of file diff --git a/core/apps/shared/views/plan.py b/core/apps/shared/views/plan.py new file mode 100644 index 0000000..ca60ab0 --- /dev/null +++ b/core/apps/shared/views/plan.py @@ -0,0 +1,86 @@ +# django +from django.shortcuts import get_object_or_404 +# rest framework +from rest_framework import generics, permissions + +# drf yasg +from drf_yasg.utils import swagger_auto_schema + +# shared +from core.apps.shared.models import Plan +from core.apps.shared.serializers.base import BaseResponseSerializer, SuccessResponseSerializer +from core.apps.shared.serializers.plan import PlanSerializer +from core.apps.shared.utils.response_mixin import ResponseMixin + + + +class PlanApiView(generics.GenericAPIView, ResponseMixin): + serializer_class = PlanSerializer + queryset = Plan.objects.all() + permission_classes = [permissions.IsAuthenticated] + + @swagger_auto_schema( + operation_description="date boyicha filter bor, ?date=date", + responses={ + 200: SuccessResponseSerializer(), + 400: BaseResponseSerializer(), + 500: BaseResponseSerializer(), + } + ) + def get(self, request): + try: + date = request.query_params.get('date') + queryset = self.queryset.filter(user=request.user) + if date: + queryset = queryset.filter(date=date) + serializer = self.serializer_class(queryset, many=True) + return self.success_response(data=serializer.data, message='malumotlar fetch qilindi') + except Exception as e: + return self.error_response(data=str(e), message='xatolik') + + @swagger_auto_schema( + responses={ + 201: SuccessResponseSerializer(), + 400: BaseResponseSerializer(), + 500: BaseResponseSerializer(), + } + ) + def post(self, request): + try: + serializer = self.serializer_class(data=request.data, context={'user': request.user}) + if serializer.is_valid(): + obj = serializer.save() + created_data = PlanSerializer(obj).data + return self.success_response( + data=created_data, + message='malumot qoshildi', + status_code=201 + ) + return self.failure_response(data=serializer.errors, message='malumot qoshilmadi') + except Exception as e: + return self.error_response(data=str(e), message='xatolik') + + +class ComplitePlanApiView(generics.GenericAPIView, ResponseMixin): + serializer_class = None + queryset = Plan.objects.all() + permission_classes = [permissions.IsAuthenticated] + + @swagger_auto_schema( + responses={ + 200: SuccessResponseSerializer(), + 400: BaseResponseSerializer(), + 500: BaseResponseSerializer(), + } + ) + def post(self, request, id): + try: + obj = get_object_or_404(Plan, id=id, user=request.user) + obj.is_done = True + obj.save() + return self.success_response( + data=PlanSerializer(obj).data, + message='malumot yangilandi' + ) + except Exception as e: + return self.error_response(data=str(e), message='xatolik') \ No newline at end of file