place uchun crud qoshildi
This commit is contained in:
@@ -41,7 +41,7 @@ class PlaceListSerializer(serializers.ModelSerializer):
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class PlaceCreateSerializer(serializers.Serializer):
|
class AdminPlaceCreateSerializer(serializers.Serializer):
|
||||||
district_id = serializers.IntegerField()
|
district_id = serializers.IntegerField()
|
||||||
user_id = serializers.IntegerField()
|
user_id = serializers.IntegerField()
|
||||||
|
|
||||||
@@ -61,7 +61,7 @@ class PlaceCreateSerializer(serializers.Serializer):
|
|||||||
|
|
||||||
data['user'] = user
|
data['user'] = user
|
||||||
data['district'] = district
|
data['district'] = district
|
||||||
return
|
return data
|
||||||
|
|
||||||
def create(self, validated_data):
|
def create(self, validated_data):
|
||||||
with transaction.atomic():
|
with transaction.atomic():
|
||||||
|
|||||||
@@ -15,6 +15,8 @@ from core.apps.dashboard.views.doctor import DoctorViewSet
|
|||||||
from core.apps.dashboard.views import region as region_views
|
from core.apps.dashboard.views import region as region_views
|
||||||
# plan
|
# plan
|
||||||
from core.apps.dashboard.views.plan import PlanViewSet
|
from core.apps.dashboard.views.plan import PlanViewSet
|
||||||
|
# place
|
||||||
|
from core.apps.dashboard.views.place import PlaceViewSet
|
||||||
|
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
# -------------- user --------------
|
# -------------- user --------------
|
||||||
@@ -52,5 +54,6 @@ urlpatterns = [
|
|||||||
router = DefaultRouter()
|
router = DefaultRouter()
|
||||||
router.register("doctor", DoctorViewSet)
|
router.register("doctor", DoctorViewSet)
|
||||||
router.register("plan", PlanViewSet)
|
router.register("plan", PlanViewSet)
|
||||||
|
router.register("place", PlaceViewSet)
|
||||||
|
|
||||||
urlpatterns += router.urls
|
urlpatterns += router.urls
|
||||||
177
core/apps/dashboard/views/place.py
Normal file
177
core/apps/dashboard/views/place.py
Normal file
@@ -0,0 +1,177 @@
|
|||||||
|
# django
|
||||||
|
from django.db.models import Q
|
||||||
|
|
||||||
|
# rest framework
|
||||||
|
from rest_framework import viewsets, permissions
|
||||||
|
from rest_framework.decorators import action
|
||||||
|
|
||||||
|
# drf yasg
|
||||||
|
from drf_yasg import openapi
|
||||||
|
from drf_yasg.utils import swagger_auto_schema
|
||||||
|
|
||||||
|
# dashboard
|
||||||
|
from core.apps.dashboard.serializers import place as serializers
|
||||||
|
|
||||||
|
# shared
|
||||||
|
from core.apps.shared.models import Place
|
||||||
|
from core.apps.shared.utils.response_mixin import ResponseMixin
|
||||||
|
|
||||||
|
|
||||||
|
class PlaceViewSet(viewsets.GenericViewSet, ResponseMixin):
|
||||||
|
permission_classes = [permissions.IsAdminUser]
|
||||||
|
queryset = Place.objects.all()
|
||||||
|
|
||||||
|
def get_serializer_class(self):
|
||||||
|
if self.action == "post":
|
||||||
|
return serializers.AdminPlaceCreateSerializer
|
||||||
|
elif self.action in ["patch", "put"]:
|
||||||
|
return serializers.PlaceUpdateSerializer
|
||||||
|
else:
|
||||||
|
return serializers.PlaceListSerializer
|
||||||
|
|
||||||
|
@swagger_auto_schema(
|
||||||
|
tags=['Admin Places'],
|
||||||
|
manual_parameters=[
|
||||||
|
openapi.Parameter(
|
||||||
|
in_=openapi.IN_QUERY,
|
||||||
|
name="name",
|
||||||
|
description="name bo'yicha filter",
|
||||||
|
required=False,
|
||||||
|
type=openapi.TYPE_STRING,
|
||||||
|
),
|
||||||
|
openapi.Parameter(
|
||||||
|
in_=openapi.IN_QUERY,
|
||||||
|
name="district",
|
||||||
|
description="tuman name bo'yicha filter",
|
||||||
|
required=False,
|
||||||
|
type=openapi.TYPE_STRING,
|
||||||
|
),
|
||||||
|
openapi.Parameter(
|
||||||
|
in_=openapi.IN_QUERY,
|
||||||
|
name="user",
|
||||||
|
description="qo'shgan foydalanuvchini ism va familiyasi bo'yicha qidirish",
|
||||||
|
required=False,
|
||||||
|
type=openapi.TYPE_STRING,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
)
|
||||||
|
@action(detail=False, methods=['get'], url_path="list")
|
||||||
|
def get(self, request):
|
||||||
|
try:
|
||||||
|
# params
|
||||||
|
name = request.query_params.get('name', None)
|
||||||
|
district_name = request.query_params.get('district', None)
|
||||||
|
user_full_name = request.query_params.get('user', None)
|
||||||
|
|
||||||
|
queryset = self.queryset.all()
|
||||||
|
|
||||||
|
# filters
|
||||||
|
if name is not None:
|
||||||
|
queryset = queryset.filter(name__istartswith=name)
|
||||||
|
|
||||||
|
if district_name is not None:
|
||||||
|
queryset = queryset.filter(district__name__istartswith=district_name)
|
||||||
|
|
||||||
|
if user_full_name is not None:
|
||||||
|
queryset = queryset.filter(
|
||||||
|
Q(user__first_name__istartswith=user_full_name) |
|
||||||
|
Q(user__last_name__istartswith=user_full_name)
|
||||||
|
)
|
||||||
|
|
||||||
|
page = self.paginate_queryset(queryset)
|
||||||
|
if page is not None:
|
||||||
|
serializer = self.get_serializer(page, many=True)
|
||||||
|
return self.success_response(
|
||||||
|
data=self.get_paginated_response(serializer.data).data,
|
||||||
|
message='malumotlar fetch qilindi'
|
||||||
|
)
|
||||||
|
serializer = self.get_serializer(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(
|
||||||
|
tags=['Admin Places']
|
||||||
|
)
|
||||||
|
@action(detail=False, methods=['post'], url_path='create')
|
||||||
|
def post(self, request):
|
||||||
|
try:
|
||||||
|
serializer = self.get_serializer(data=request.data)
|
||||||
|
if serializer.is_valid():
|
||||||
|
obj = serializer.save()
|
||||||
|
return self.success_response(
|
||||||
|
data=serializers.PlaceListSerializer(obj).data,
|
||||||
|
message='malumot qoshildi'
|
||||||
|
)
|
||||||
|
return self.failure_response(
|
||||||
|
data=serializer.errors,
|
||||||
|
message='malumot qoshilmadi'
|
||||||
|
)
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(
|
||||||
|
data=str(e),
|
||||||
|
message="xatolik"
|
||||||
|
)
|
||||||
|
|
||||||
|
@swagger_auto_schema(
|
||||||
|
tags=['Admin Places']
|
||||||
|
)
|
||||||
|
@action(detail=True, methods=['patch'], url_path='update')
|
||||||
|
def update_doctor(self, request, pk=None):
|
||||||
|
try:
|
||||||
|
place = Place.objects.filter(id=pk).first()
|
||||||
|
if not place:
|
||||||
|
return self.failure_response(
|
||||||
|
data={},
|
||||||
|
message="plan topilmadi",
|
||||||
|
status_code=404
|
||||||
|
)
|
||||||
|
serializer = self.get_serializer(data=request.data, instance=place)
|
||||||
|
if serializer.is_valid():
|
||||||
|
obj = serializer.save()
|
||||||
|
return self.success_response(
|
||||||
|
data=serializers.PlaceListSerializer(obj).data,
|
||||||
|
message='malumot tahrirlandi'
|
||||||
|
)
|
||||||
|
return self.failure_response(
|
||||||
|
data=serializer.errors,
|
||||||
|
message='malumot tahrirlandi'
|
||||||
|
)
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(
|
||||||
|
data=str(e),
|
||||||
|
message="xatolik"
|
||||||
|
)
|
||||||
|
|
||||||
|
@swagger_auto_schema(
|
||||||
|
tags=['Admin Places']
|
||||||
|
)
|
||||||
|
@action(detail=True, methods=['delete'], url_path='delete')
|
||||||
|
def delete(self, request, pk=None):
|
||||||
|
try:
|
||||||
|
place = Place.objects.filter(id=pk).first()
|
||||||
|
if not place:
|
||||||
|
return self.failure_response(
|
||||||
|
data={},
|
||||||
|
message="place topilmadi",
|
||||||
|
status_code=404
|
||||||
|
)
|
||||||
|
place.delete()
|
||||||
|
return self.success_response(
|
||||||
|
data={},
|
||||||
|
message='malumot ochirildi',
|
||||||
|
status_code=204
|
||||||
|
)
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(
|
||||||
|
data=str(e),
|
||||||
|
message="xatolik"
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
Reference in New Issue
Block a user