fi
This commit is contained in:
@@ -8,75 +8,99 @@ from rest_framework import serializers
|
|||||||
from core.apps.shared.models import Location, UserLocation
|
from core.apps.shared.models import Location, UserLocation
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class LocationListSerializer(serializers.ModelSerializer):
|
class LocationListSerializer(serializers.ModelSerializer):
|
||||||
district = serializers.SerializerMethodField(method_name='get_district')
|
district = serializers.SerializerMethodField(method_name="get_district")
|
||||||
place = serializers.SerializerMethodField(method_name='get_place')
|
place = serializers.SerializerMethodField(method_name="get_place")
|
||||||
doctor = serializers.SerializerMethodField(method_name='get_doctor')
|
doctor = serializers.SerializerMethodField(method_name="get_doctor")
|
||||||
pharmacy = serializers.SerializerMethodField(method_name='get_pharmacy')
|
pharmacy = serializers.SerializerMethodField(method_name="get_pharmacy")
|
||||||
user = serializers.SerializerMethodField(method_name='get_user')
|
user = serializers.SerializerMethodField(method_name="get_user")
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Location
|
model = Location
|
||||||
fields = [
|
fields = [
|
||||||
'id', 'longitude', 'latitude', 'created_at', 'user',
|
"id",
|
||||||
'district', 'place', 'doctor', 'pharmacy', 'updated_at'
|
"longitude",
|
||||||
|
"latitude",
|
||||||
|
"created_at",
|
||||||
|
"user",
|
||||||
|
"district",
|
||||||
|
"place",
|
||||||
|
"doctor",
|
||||||
|
"pharmacy",
|
||||||
|
"updated_at",
|
||||||
]
|
]
|
||||||
|
|
||||||
def get_user(self, obj):
|
def get_user(self, obj):
|
||||||
return {
|
return {
|
||||||
'id': obj.user.id,
|
"id": obj.user.id,
|
||||||
'first_name': obj.user.first_name,
|
"first_name": obj.user.first_name,
|
||||||
'last_name': obj.user.last_name,
|
"last_name": obj.user.last_name,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
def get_district(self, obj):
|
def get_district(self, obj):
|
||||||
return {
|
return (
|
||||||
'id': obj.district.id,
|
{
|
||||||
'name': obj.district.name,
|
"id": obj.district.id,
|
||||||
} if obj.district else None
|
"name": obj.district.name,
|
||||||
|
}
|
||||||
|
if obj.district
|
||||||
|
else None
|
||||||
|
)
|
||||||
|
|
||||||
def get_place(self, obj):
|
def get_place(self, obj):
|
||||||
return {
|
return (
|
||||||
'id': obj.place.id,
|
{
|
||||||
'name': obj.place.name,
|
"id": obj.place.id,
|
||||||
'longitude': obj.place.longitude,
|
"name": obj.place.name,
|
||||||
'latitude': obj.place.latitude,
|
"longitude": obj.place.longitude,
|
||||||
} if obj.place else None
|
"latitude": obj.place.latitude,
|
||||||
|
}
|
||||||
|
if obj.place
|
||||||
|
else None
|
||||||
|
)
|
||||||
|
|
||||||
def get_doctor(self, obj):
|
def get_doctor(self, obj):
|
||||||
return {
|
return (
|
||||||
'id': obj.doctor.id,
|
{
|
||||||
'first_name': obj.doctor.first_name,
|
"id": obj.doctor.id,
|
||||||
'last_name': obj.doctor.last_name,
|
"first_name": obj.doctor.first_name,
|
||||||
'longitude': obj.doctor.longitude,
|
"last_name": obj.doctor.last_name,
|
||||||
'latitude': obj.doctor.latitude,
|
"longitude": obj.doctor.longitude,
|
||||||
} if obj.doctor else None
|
"latitude": obj.doctor.latitude,
|
||||||
|
}
|
||||||
|
if obj.doctor
|
||||||
|
else None
|
||||||
|
)
|
||||||
|
|
||||||
def get_pharmacy(self, obj):
|
def get_pharmacy(self, obj):
|
||||||
return {
|
return (
|
||||||
'id': obj.pharmacy.id,
|
{
|
||||||
'name': obj.pharmacy.name,
|
"id": obj.pharmacy.id,
|
||||||
'longitude': obj.pharmacy.longitude,
|
"name": obj.pharmacy.name,
|
||||||
'latitude': obj.pharmacy.latitude,
|
"longitude": obj.pharmacy.longitude,
|
||||||
} if obj.pharmacy else None
|
"latitude": obj.pharmacy.latitude,
|
||||||
|
}
|
||||||
|
if obj.pharmacy
|
||||||
|
else None
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class UserLocationListSerializer(serializers.ModelSerializer):
|
class UserLocationListSerializer(serializers.ModelSerializer):
|
||||||
user = serializers.SerializerMethodField(method_name='get_user')
|
user = serializers.SerializerMethodField(method_name="get_user")
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = UserLocation
|
model = UserLocation
|
||||||
fields = [
|
fields = [
|
||||||
'id', 'longitude', 'latitude', 'user', 'created_at',
|
"id",
|
||||||
|
"longitude",
|
||||||
|
"latitude",
|
||||||
|
"user",
|
||||||
|
"created_at",
|
||||||
]
|
]
|
||||||
|
|
||||||
def get_user(self, obj):
|
def get_user(self, obj):
|
||||||
return {
|
return {
|
||||||
'id': obj.user.id,
|
"id": obj.user.id,
|
||||||
'first_name': obj.user.first_name,
|
"first_name": obj.user.first_name,
|
||||||
'last_name': obj.user.last_name
|
"last_name": obj.user.last_name,
|
||||||
}
|
}
|
||||||
@@ -1,14 +1,14 @@
|
|||||||
# django
|
# django
|
||||||
from django.db.models import Q
|
from django.db.models import Q
|
||||||
|
|
||||||
# rest framework
|
|
||||||
from rest_framework import viewsets, permissions
|
|
||||||
from rest_framework.decorators import action
|
|
||||||
|
|
||||||
# drf yasg
|
# drf yasg
|
||||||
from drf_yasg import openapi
|
from drf_yasg import openapi
|
||||||
from drf_yasg.utils import swagger_auto_schema
|
from drf_yasg.utils import swagger_auto_schema
|
||||||
|
|
||||||
|
# rest framework
|
||||||
|
from rest_framework import permissions, viewsets
|
||||||
|
from rest_framework.decorators import action
|
||||||
|
|
||||||
# dashboard
|
# dashboard
|
||||||
from core.apps.dashboard.serializers import location as serializers
|
from core.apps.dashboard.serializers import location as serializers
|
||||||
|
|
||||||
@@ -25,7 +25,7 @@ class LocationViewSet(viewsets.GenericViewSet, ResponseMixin):
|
|||||||
return serializers.LocationListSerializer
|
return serializers.LocationListSerializer
|
||||||
|
|
||||||
@swagger_auto_schema(
|
@swagger_auto_schema(
|
||||||
tags=['Admin Location'],
|
tags=["Admin Location"],
|
||||||
manual_parameters=[
|
manual_parameters=[
|
||||||
openapi.Parameter(
|
openapi.Parameter(
|
||||||
in_=openapi.IN_QUERY,
|
in_=openapi.IN_QUERY,
|
||||||
@@ -43,23 +43,23 @@ class LocationViewSet(viewsets.GenericViewSet, ResponseMixin):
|
|||||||
),
|
),
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
@action(detail=False, methods=['get'], url_path="list")
|
@action(detail=False, methods=["get"], url_path="list")
|
||||||
def get(self, request):
|
def get(self, request):
|
||||||
try:
|
try:
|
||||||
# params
|
# params
|
||||||
date = request.query_params.get('date', None)
|
date = request.query_params.get("date", None)
|
||||||
user_full_name = request.query_params.get('user', None)
|
user_full_name = request.query_params.get("user", None)
|
||||||
|
|
||||||
queryset = self.queryset.all()
|
queryset = self.queryset.all()
|
||||||
|
|
||||||
# filters
|
# filters
|
||||||
if date is not None:
|
if date is not None:
|
||||||
queryset = queryset.filter(date=date)
|
queryset = queryset.filter(created_at__date=date)
|
||||||
|
|
||||||
if user_full_name is not None:
|
if user_full_name is not None:
|
||||||
queryset = queryset.filter(
|
queryset = queryset.filter(
|
||||||
Q(user__first_name__istartswith=user_full_name) |
|
Q(user__first_name__istartswith=user_full_name)
|
||||||
Q(user__last_name__istartswith=user_full_name)
|
| Q(user__last_name__istartswith=user_full_name)
|
||||||
)
|
)
|
||||||
|
|
||||||
page = self.paginate_queryset(queryset)
|
page = self.paginate_queryset(queryset)
|
||||||
@@ -67,44 +67,30 @@ class LocationViewSet(viewsets.GenericViewSet, ResponseMixin):
|
|||||||
serializer = self.get_serializer(page, many=True)
|
serializer = self.get_serializer(page, many=True)
|
||||||
return self.success_response(
|
return self.success_response(
|
||||||
data=self.get_paginated_response(serializer.data).data,
|
data=self.get_paginated_response(serializer.data).data,
|
||||||
message='malumotlar fetch qilindi'
|
message="malumotlar fetch qilindi",
|
||||||
)
|
)
|
||||||
serializer = self.get_serializer(queryset, many=True)
|
serializer = self.get_serializer(queryset, many=True)
|
||||||
return self.success_response(
|
return self.success_response(
|
||||||
data=serializer.data,
|
data=serializer.data, message="malumotlar fetch qilindi"
|
||||||
message='malumotlar fetch qilindi'
|
|
||||||
)
|
)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return self.error_response(
|
return self.error_response(data=str(e), message="xatolik")
|
||||||
data=str(e),
|
|
||||||
message="xatolik"
|
|
||||||
)
|
|
||||||
|
|
||||||
@swagger_auto_schema(
|
@swagger_auto_schema(tags=["Admin Location"])
|
||||||
tags=['Admin Location']
|
@action(detail=True, methods=["delete"], url_path="delete")
|
||||||
)
|
|
||||||
@action(detail=True, methods=['delete'], url_path='delete')
|
|
||||||
def delete(self, request, pk=None):
|
def delete(self, request, pk=None):
|
||||||
try:
|
try:
|
||||||
location = Location.objects.filter(id=pk).first()
|
location = Location.objects.filter(id=pk).first()
|
||||||
if not location:
|
if not location:
|
||||||
return self.failure_response(
|
return self.failure_response(
|
||||||
data={},
|
data={}, message="location topilmadi", status_code=404
|
||||||
message="location topilmadi",
|
|
||||||
status_code=404
|
|
||||||
)
|
)
|
||||||
location.delete()
|
location.delete()
|
||||||
return self.success_response(
|
return self.success_response(
|
||||||
data={},
|
data={}, message="malumot ochirildi", status_code=204
|
||||||
message='malumot ochirildi',
|
|
||||||
status_code=204
|
|
||||||
)
|
)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return self.error_response(
|
return self.error_response(data=str(e), message="xatolik")
|
||||||
data=str(e),
|
|
||||||
message="xatolik"
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class UserLocationViewSet(viewsets.GenericViewSet, ResponseMixin):
|
class UserLocationViewSet(viewsets.GenericViewSet, ResponseMixin):
|
||||||
@@ -115,7 +101,7 @@ class UserLocationViewSet(viewsets.GenericViewSet, ResponseMixin):
|
|||||||
return serializers.UserLocationListSerializer
|
return serializers.UserLocationListSerializer
|
||||||
|
|
||||||
@swagger_auto_schema(
|
@swagger_auto_schema(
|
||||||
tags=['Admin Location'],
|
tags=["Admin Location"],
|
||||||
manual_parameters=[
|
manual_parameters=[
|
||||||
openapi.Parameter(
|
openapi.Parameter(
|
||||||
in_=openapi.IN_QUERY,
|
in_=openapi.IN_QUERY,
|
||||||
@@ -133,12 +119,12 @@ class UserLocationViewSet(viewsets.GenericViewSet, ResponseMixin):
|
|||||||
),
|
),
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
@action(detail=False, methods=['get'], url_path="list")
|
@action(detail=False, methods=["get"], url_path="list")
|
||||||
def get(self, request):
|
def get(self, request):
|
||||||
try:
|
try:
|
||||||
# params
|
# params
|
||||||
date = request.query_params.get('date', None)
|
date = request.query_params.get("date", None)
|
||||||
user_full_name = request.query_params.get('user', None)
|
user_full_name = request.query_params.get("user", None)
|
||||||
|
|
||||||
queryset = self.queryset.all()
|
queryset = self.queryset.all()
|
||||||
|
|
||||||
@@ -148,8 +134,8 @@ class UserLocationViewSet(viewsets.GenericViewSet, ResponseMixin):
|
|||||||
|
|
||||||
if user_full_name is not None:
|
if user_full_name is not None:
|
||||||
queryset = queryset.filter(
|
queryset = queryset.filter(
|
||||||
Q(user__first_name__istartswith=user_full_name) |
|
Q(user__first_name__istartswith=user_full_name)
|
||||||
Q(user__last_name__istartswith=user_full_name)
|
| Q(user__last_name__istartswith=user_full_name)
|
||||||
)
|
)
|
||||||
|
|
||||||
page = self.paginate_queryset(queryset)
|
page = self.paginate_queryset(queryset)
|
||||||
@@ -157,42 +143,27 @@ class UserLocationViewSet(viewsets.GenericViewSet, ResponseMixin):
|
|||||||
serializer = self.get_serializer(page, many=True)
|
serializer = self.get_serializer(page, many=True)
|
||||||
return self.success_response(
|
return self.success_response(
|
||||||
data=self.get_paginated_response(serializer.data).data,
|
data=self.get_paginated_response(serializer.data).data,
|
||||||
message='malumotlar fetch qilindi'
|
message="malumotlar fetch qilindi",
|
||||||
)
|
)
|
||||||
serializer = self.get_serializer(queryset, many=True)
|
serializer = self.get_serializer(queryset, many=True)
|
||||||
return self.success_response(
|
return self.success_response(
|
||||||
data=serializer.data,
|
data=serializer.data, message="malumotlar fetch qilindi"
|
||||||
message='malumotlar fetch qilindi'
|
|
||||||
)
|
)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return self.error_response(
|
return self.error_response(data=str(e), message="xatolik")
|
||||||
data=str(e),
|
|
||||||
message="xatolik"
|
|
||||||
)
|
|
||||||
|
|
||||||
@swagger_auto_schema(
|
@swagger_auto_schema(tags=["Admin Location"])
|
||||||
tags=['Admin Location']
|
@action(detail=True, methods=["delete"], url_path="delete")
|
||||||
)
|
|
||||||
@action(detail=True, methods=['delete'], url_path='delete')
|
|
||||||
def delete(self, request, pk=None):
|
def delete(self, request, pk=None):
|
||||||
try:
|
try:
|
||||||
location = Location.objects.filter(id=pk).first()
|
location = Location.objects.filter(id=pk).first()
|
||||||
if not location:
|
if not location:
|
||||||
return self.failure_response(
|
return self.failure_response(
|
||||||
data={},
|
data={}, message="location topilmadi", status_code=404
|
||||||
message="location topilmadi",
|
|
||||||
status_code=404
|
|
||||||
)
|
)
|
||||||
location.delete()
|
location.delete()
|
||||||
return self.success_response(
|
return self.success_response(
|
||||||
data={},
|
data={}, message="malumot ochirildi", status_code=204
|
||||||
message='malumot ochirildi',
|
|
||||||
status_code=204
|
|
||||||
)
|
)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return self.error_response(
|
return self.error_response(data=str(e), message="xatolik")
|
||||||
data=str(e),
|
|
||||||
message="xatolik"
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user