diff options
author | lxf <sng@luxagraf.net> | 2021-01-04 15:20:56 -0500 |
---|---|---|
committer | lxf <sng@luxagraf.net> | 2021-01-04 15:20:56 -0500 |
commit | 9a699c2f11a3ba440efae086b4303fdc55e5d97f (patch) | |
tree | 84aacf0e432fdd5d9f0d070f940eb4e1414db416 /app/media | |
parent | e832d30f2674573e88ed8a930635bbcfd39df5a0 (diff) |
streamlined admin for images
Diffstat (limited to 'app/media')
-rw-r--r-- | app/media/admin.py | 23 | ||||
-rw-r--r-- | app/media/models.py | 6 |
2 files changed, 26 insertions, 3 deletions
diff --git a/app/media/admin.py b/app/media/admin.py index 9278c56..305ebd7 100644 --- a/app/media/admin.py +++ b/app/media/admin.py @@ -38,13 +38,30 @@ class LuxImageAdmin(OSMGeoAdmin): fieldsets = ( (None, { - 'fields': ('title', ('image'), 'pub_date', 'sizes', 'alt', 'caption', 'point', ('is_public'), ('photo_credit_source', 'photo_credit_url')) + 'fields': ( + 'image', + 'alt', + 'sizes', + 'caption', + 'pub_date', + 'title', + ) }), - ('Exif Data', { + ('Exif and Other Data', { 'classes': ('collapse',), - 'fields': ('exif_raw', 'exif_aperture', 'exif_make', 'exif_model', 'exif_exposure', 'exif_iso', 'exif_focal_length', 'exif_lens', 'exif_date', 'height', 'width'), + 'fields': ( + 'point', + ('is_public'), + ('photo_credit_source', 'photo_credit_url'), + 'exif_raw', 'exif_aperture', 'exif_make', 'exif_model', 'exif_exposure', 'exif_iso', 'exif_focal_length', 'exif_lens', 'exif_date', 'height', 'width'), }), ) + def save_related(self, request, form, formsets, change): + super(LuxImageAdmin, self).save_related(request, form, formsets, change) + if not form.instance.sizes.all(): + print("there are no sizes") + form.instance.sizes.add(*LuxImageSize.objects.filter(slug__in=["picwide-sm", "picwide-med", "picwide"])) + class Media: js = ('image-preview.js', 'next-prev-links.js') diff --git a/app/media/models.py b/app/media/models.py index d7b79c6..c266c4f 100644 --- a/app/media/models.py +++ b/app/media/models.py @@ -207,6 +207,12 @@ class LuxImage(models.Model): created = self.pk is None if not created: self.sizes_cache = ",".join(s.slug for s in self.sizes.all()) + if not self.point: + self.point = LuxImage.objects.latest().point + try: + self.location = Location.objects.filter(geometry__contains=self.point).get() + except Location.DoesNotExist: + raise forms.ValidationError("There is no location associated with that point, add it: %sadmin/locations/location/add/" % (settings.BASE_URL)) super(LuxImage, self).save() |