Add habitat image endpoint, view and serializer

This commit is contained in:
Dana Lambert 2021-11-05 14:22:07 +13:00
parent 29b9051773
commit c79d287384
5 changed files with 95 additions and 24 deletions

View file

@ -0,0 +1,29 @@
# Generated by Django 3.2.8 on 2021-11-04 22:46
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
('api', '0004_alter_habitatimage_habitat'),
]
operations = [
migrations.AlterField(
model_name='zone',
name='redirect_habitat',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='zone_redirects', to='api.habitatimage'),
),
migrations.AlterField(
model_name='zoneimagesegment',
name='habitat_image',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='image_segments', to='api.habitatimage'),
),
migrations.AlterField(
model_name='zoneimagesegment',
name='zone',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='image_segments', to='api.zone'),
),
]

View file

@ -52,6 +52,7 @@ class ToleranceLevel(models.Model):
def __str__(self): def __str__(self):
return self.level return self.level
class Habitat(models.Model): class Habitat(models.Model):
name = models.CharField(max_length=50) name = models.CharField(max_length=50)
@ -74,7 +75,7 @@ class Zone(models.Model):
variant = models.CharField(null=True, blank=True, max_length=50) variant = models.CharField(null=True, blank=True, max_length=50)
refined_variant = models.CharField(null=True, blank=True, max_length=100) refined_variant = models.CharField(null=True, blank=True, max_length=100)
redirect_habitat = models.ForeignKey( redirect_habitat = models.ForeignKey(
Habitat, blank=True, null=True, on_delete=models.CASCADE, related_name='redirect_habitat') HabitatImage, blank=True, null=True, on_delete=models.CASCADE, related_name='zone_redirects')
def __str__(self): def __str__(self):
refined_variant_str = f", {self.refined_variant}" if self.refined_variant is not None else "" refined_variant_str = f", {self.refined_variant}" if self.refined_variant is not None else ""
@ -84,15 +85,18 @@ class Zone(models.Model):
class ZoneImageSegment(models.Model): class ZoneImageSegment(models.Model):
zone = models.ForeignKey( zone = models.ForeignKey(
Zone, on_delete=models.CASCADE, related_name='zone') Zone, on_delete=models.CASCADE, related_name='image_segments')
habitat_image = models.ForeignKey( habitat_image = models.ForeignKey(
HabitatImage, on_delete=models.CASCADE, related_name='habitat_image') HabitatImage, on_delete=models.CASCADE, related_name='image_segments')
segment_order = models.PositiveIntegerField(default=0) segment_order = models.PositiveIntegerField(default=0)
segment_percentage_width = models.PositiveIntegerField(default=0) segment_percentage_width = models.PositiveIntegerField(default=0)
def __str__(self): def __str__(self):
return f"{self.habitat_image.name}, {self.zone.name}" return f"{self.habitat_image.name}, {self.zone.name}"
class Meta:
ordering = ['segment_order', 'id']
class Plant(models.Model): class Plant(models.Model):
name = models.CharField(unique=True, max_length=50) name = models.CharField(unique=True, max_length=50)
@ -117,4 +121,4 @@ class Plant(models.Model):
zones = models.ManyToManyField(Zone) zones = models.ManyToManyField(Zone)
def __str__(self): def __str__(self):
return self.name return self.name

View file

@ -2,23 +2,6 @@ from rest_framework import serializers
from right_tree.api.models import * from right_tree.api.models import *
class HabitatImageSerializer(serializers.HyperlinkedModelSerializer):
id = serializers.ReadOnlyField()
class Meta:
model = HabitatImage
fields = ['id', 'name', 'image_filename']
class HabitatSerializer(serializers.HyperlinkedModelSerializer):
id = serializers.ReadOnlyField()
images = HabitatImageSerializer(many=True)
class Meta:
model = Habitat
fields = ['id', 'name', 'images']
class ToleranceLevelSerializer(serializers.HyperlinkedModelSerializer): class ToleranceLevelSerializer(serializers.HyperlinkedModelSerializer):
class Meta: class Meta:
model = ToleranceLevel model = ToleranceLevel
@ -57,9 +40,17 @@ class SoilVariantSerializer(serializers.HyperlinkedModelSerializer):
fields = ['name'] fields = ['name']
class SimpleHabitatImageSerializer(serializers.HyperlinkedModelSerializer):
id = serializers.ReadOnlyField()
class Meta:
model = HabitatImage
fields = ['id', 'name', 'image_filename']
class ZoneSerializer(serializers.HyperlinkedModelSerializer): class ZoneSerializer(serializers.HyperlinkedModelSerializer):
id = serializers.ReadOnlyField() id = serializers.ReadOnlyField()
redirect_habitat = HabitatSerializer() redirect_habitat = SimpleHabitatImageSerializer()
class Meta: class Meta:
model = Zone model = Zone
@ -67,6 +58,34 @@ class ZoneSerializer(serializers.HyperlinkedModelSerializer):
'refined_variant', 'redirect_habitat'] 'refined_variant', 'redirect_habitat']
class ZoneImageSegmentSerializer(serializers.HyperlinkedModelSerializer):
id = serializers.ReadOnlyField()
zone = ZoneSerializer()
class Meta:
model = ZoneImageSegment
fields = ['id', 'zone',
'segment_order', 'segment_percentage_width']
class HabitatImageSerializer(serializers.HyperlinkedModelSerializer):
id = serializers.ReadOnlyField()
image_segments = ZoneImageSegmentSerializer(many=True)
class Meta:
model = HabitatImage
fields = ['id', 'name', 'image_filename', 'image_segments']
class HabitatSerializer(serializers.HyperlinkedModelSerializer):
id = serializers.ReadOnlyField()
images = HabitatImageSerializer(many=True)
class Meta:
model = Habitat
fields = ['id', 'name', 'images']
class LocationDetailsSerializer(serializers.Serializer): class LocationDetailsSerializer(serializers.Serializer):
ecologic_1 = serializers.CharField(max_length=50) ecologic_1 = serializers.CharField(max_length=50)
ecologic_2 = serializers.CharField(max_length=50) ecologic_2 = serializers.CharField(max_length=50)

View file

@ -3,12 +3,13 @@ import json
from django.contrib.gis.geos import Point from django.contrib.gis.geos import Point
from django.contrib.gis.db import models from django.contrib.gis.db import models
from django.http import HttpResponseBadRequest from django.http import HttpResponseBadRequest
from django.shortcuts import get_object_or_404
from rest_framework import viewsets from rest_framework import viewsets
from rest_framework.response import Response from rest_framework.response import Response
from right_tree.api.models import Habitat, Plant, EcologicalDistrictLayer, SoilOrder from right_tree.api.models import Habitat, HabitatImage, Plant, EcologicalDistrictLayer, SoilOrder
from right_tree.api.serializers import HabitatSerializer, PlantSerializer, SoilOrderSerializer, EcologicalDistrictLayerSerializer, AddressSerializer from right_tree.api.serializers import HabitatImageSerializer, HabitatSerializer, PlantSerializer, SoilOrderSerializer, EcologicalDistrictLayerSerializer, AddressSerializer
from .filters import * from .filters import *
from .utils import get_address_from_coordinates from .utils import get_address_from_coordinates
@ -85,3 +86,20 @@ class HabitatViewSet(viewsets.ModelViewSet):
""" """
serializer_class = HabitatSerializer serializer_class = HabitatSerializer
queryset = Habitat.objects.all() queryset = Habitat.objects.all()
class HabitatImageViewSet(viewsets.ViewSet):
"""
Viewset for a habitat image.
"""
def list(self, request):
queryset = HabitatImage.objects.all()
serializer = HabitatImageSerializer(queryset, many=True)
return Response(serializer.data)
def retrieve(self, request, pk=None):
queryset = HabitatImage.objects.all()
habitat_image = get_object_or_404(queryset, pk=pk)
serializer = HabitatImageSerializer(habitat_image)
return Response(serializer.data)

View file

@ -25,6 +25,7 @@ router.register(r'soil', views.SoilOrderViewSet, basename='soil')
router.register(r'ecologicaldistrict', views.EcologicalDistrictViewSet, basename='ecologicaldistrict') router.register(r'ecologicaldistrict', views.EcologicalDistrictViewSet, basename='ecologicaldistrict')
router.register(r'address', views.LINZPropertyViewSet, basename='address') router.register(r'address', views.LINZPropertyViewSet, basename='address')
router.register(r'habitats', views.HabitatViewSet, basename='habitats') router.register(r'habitats', views.HabitatViewSet, basename='habitats')
router.register(r'habitatimage', views.HabitatImageViewSet,basename='habitatimage')
urlpatterns = [ urlpatterns = [
path('admin/', admin.site.urls), path('admin/', admin.site.urls),