admin uchun ham plan apilar ozgartirildi

This commit is contained in:
behruz-dev
2025-12-03 16:52:57 +05:00
parent 676d9c5dcd
commit f24a2760a9

View File

@@ -5,13 +5,15 @@ from django.db import transaction
from rest_framework import serializers from rest_framework import serializers
# shared # shared
from core.apps.shared.models import Plan from core.apps.shared.models import Plan, Doctor, Pharmacy
# accounts # accounts
from core.apps.accounts.models import User from core.apps.accounts.models import User
class PlanListSerializer(serializers.ModelSerializer): class PlanListSerializer(serializers.ModelSerializer):
user = serializers.SerializerMethodField(method_name='get_user') user = serializers.SerializerMethodField(method_name='get_user')
doctor = serializers.SerializerMethodField(method_name='get_doctor')
pharmacy = serializers.SerializerMethodField(method_name='get_pharmacy')
class Meta: class Meta:
model = Plan model = Plan
@@ -20,9 +22,14 @@ class PlanListSerializer(serializers.ModelSerializer):
'title', 'title',
'description', 'description',
'date', 'date',
'comment',
'doctor',
'pharmacy',
'user', 'user',
'is_done', 'longitude',
'created_at' 'latitude',
'extra_location',
'created_at',
] ]
def get_user(self, obj): def get_user(self, obj):
@@ -32,18 +39,48 @@ class PlanListSerializer(serializers.ModelSerializer):
'last_name': obj.user.last_name, 'last_name': obj.user.last_name,
} }
def get_doctor(self, obj):
return {
"id": obj.doctor.id,
"first_name": obj.doctor.first_name,
"last_name": obj.doctor.last_name
} if obj.doctor is not None else None
def get_pharmacy(self, obj):
return {
"id": obj.pharmacy.id,
"name": obj.pharmacy.name,
} if obj.pharmacy is not None else None
class AdminPlanCreateSerializer(serializers.Serializer): class AdminPlanCreateSerializer(serializers.Serializer):
title = serializers.CharField() title = serializers.CharField()
description = serializers.CharField() description = serializers.CharField()
date = serializers.DateField() date = serializers.DateField()
user_id = serializers.IntegerField() user_id = serializers.IntegerField()
doctor_id = serializers.IntegerField(required=False, allow_null=True)
pharmacy_id = serializers.IntegerField(required=False, allow_null=True)
longitude = serializers.FloatField(required=False, default=0.0)
latitude = serializers.FloatField(required=False, default=0.0)
extra_location = serializers.JSONField(required=False, allow_null=True)
def validate(self, data): def validate(self, data):
user = User.objects.filter(id=data['user_id']).first() user = User.objects.filter(id=data['user_id']).first()
if not user: if not user:
raise serializers.ValidationError({"user_id": "Foydalanuvchi topilmadi"}) raise serializers.ValidationError({"user_id": "Foydalanuvchi topilmadi"})
data['user'] = user data['user'] = user
if data.get('doctor_id'):
doctor = Doctor.objects.filter(id=data.get('doctor_id')).first()
if not doctor:
raise serializers.ValidationError({"doctor": "Doctor not found"})
data['doctor'] = doctor
if data.get('pharmacy_id'):
pharmacy = Pharmacy.objects.filter(id=data.get('pharmacy_id')).first()
if not pharmacy:
raise serializers.ValidationError({"pharmacy_id": "Pharmacy not found"})
data['pharmacy'] = pharmacy
return data return data
def create(self, validated_data): def create(self, validated_data):
@@ -53,6 +90,11 @@ class AdminPlanCreateSerializer(serializers.Serializer):
description=validated_data.get('description'), description=validated_data.get('description'),
user=validated_data.get('user'), user=validated_data.get('user'),
date=validated_data.get('date'), date=validated_data.get('date'),
doctor=validated_data.get('doctor'),
pharmacy=validated_data.get('pharmacy'),
longitude=validated_data.get('longitude'),
latitude=validated_data.get('latitude'),
extra_location=validated_data.get('extra_location'),
) )
@@ -60,10 +102,9 @@ class PlanUpdateSerializer(serializers.ModelSerializer):
class Meta: class Meta:
model = Plan model = Plan
fields = [ fields = [
'title', 'title', 'description', 'date',
'description', 'comment', 'doctor', 'pharmacy',
'date', 'longitude', 'latitude', 'extra_location',
'user',
] ]
extra_kwargs = { extra_kwargs = {
"user": {"required": False} "user": {"required": False}
@@ -71,10 +112,8 @@ class PlanUpdateSerializer(serializers.ModelSerializer):
def update(self, instance, validated_data): def update(self, instance, validated_data):
with transaction.atomic(): with transaction.atomic():
instance.title = validated_data.get('title', instance.title) for field, value in validated_data.items():
instance.description = validated_data.get('description', instance.description) setattr(instance, field, value)
instance.user = validated_data.get('user', instance.user)
instance.date = validated_data.get('date', instance.date)
instance.save() instance.save()
return instance return instance