summaryrefslogtreecommitdiff
path: root/app/media
diff options
context:
space:
mode:
Diffstat (limited to 'app/media')
-rw-r--r--app/media/models.py33
1 files changed, 17 insertions, 16 deletions
diff --git a/app/media/models.py b/app/media/models.py
index 883d4df..bc27758 100644
--- a/app/media/models.py
+++ b/app/media/models.py
@@ -148,16 +148,15 @@ class LuxImage(models.Model):
return self.image.url
else:
luximagesize = LuxImageSize.objects.get(name=size)
- if luximagesize not in self.get_sizes:
- print("new size is "+luximagesize.name)
- self.sizes.add(luximagesize)
+ #if luximagesize not in self.get_sizes:
+ #self.sizes.add(luximagesize)
return "%s%s/%s_%s.%s" % (settings.IMAGES_URL, self.pub_date.strftime("%Y"), self.image_name, luximagesize.slug, self.image_ext)
def get_image_path_by_size(self, size="original"):
if size == "original":
return self.image.path
else:
- luximagesize = LuxImageSize.objects.get(name=size)
+ luximagesize = LuxImageSize.objects.get(slug=size)
return "%s%s/%s_%s.%s" % (settings.IMAGES_ROOT, self.pub_date.strftime("%Y"), self.image_name, luximagesize.slug, self.image_ext)
def get_thumbnail_url(self):
@@ -167,7 +166,7 @@ class LuxImage(models.Model):
return format_html('<a href="%s"><img src="%s"></a>' % (self.get_image_url_by_size(), self.get_image_url_by_size("admin-thumbnail")))
admin_thumbnail.short_description = 'Thumbnail'
- @cached_property
+ @property
def get_sizes(self):
return self.sizes_cache.split(",")
@@ -202,7 +201,7 @@ class LuxImage(models.Model):
def save(self, *args, **kwargs):
created = self.pk is None
if created:
- self.sizes.add(LuxImageSize.objects.get(name="admin-thumbnail"))
+ self.sizes.add(LuxImageSize.objects.get(name="tn"))
img = Image.open(self.image.path)
self.height = img.height
self.width = img.width
@@ -346,32 +345,34 @@ def update_photo_sizes(sender, instance, **kwargs):
# update the local cache of sizes
instance.sizes_cache = ",".join(s.slug for s in instance.sizes.all())
instance.save()
- for size in instance.sizes.all():
+ print(instance.get_sizes)
+ for size in instance.get_sizes:
# check each size and see if there's an image there already
- my_file = Path(instance.get_image_path_by_size(size.name))
+ my_file = Path(instance.get_image_path_by_size(size))
if not my_file.is_file():
print("creating new image file")
#file doesn't exist, so create it
- if size.width:
+ new_size = LuxImageSize.objects.get(slug=size)
+ if new_size.width:
img = Image.open(instance.image.path)
try:
- if size.width <= img.width:
- resize_image(img, size.width, None, size.quality, instance.get_image_path_by_size(size.name))
+ if new_size.width <= img.width:
+ resize_image(img, new_size.width, None, new_size.quality, instance.get_image_path_by_size(size))
else:
raise ValidationError({'items': ["Size is larger than source image"]})
except ImageSizeError:
m2m_changed.disconnect(update_photo_sizes, sender=LuxImage.sizes.through)
- instance.sizes.remove(size)
+ instance.sizes.remove(new_size)
m2m_changed.connect(update_photo_sizes, sender=LuxImage.sizes.through)
- if size.height:
+ if new_size.height:
try:
- if size.height <= img.height:
- resize_image(img, None, size.height, size.quality, instance.get_image_path_by_size(size.name))
+ if new_size.height <= img.height:
+ resize_image(img, None, new_size.height, new_size.quality, instance.get_image_path_by_size(size))
else:
pass
except ImageSizeError:
m2m_changed.disconnect(update_photo_sizes, sender=LuxImage.sizes.through)
- instance.sizes.remove(size)
+ instance.sizes.remove(new_size)
m2m_changed.connect(update_photo_sizes, sender=LuxImage.sizes.through)
else:
# file exists, might add something here to force it to do the above when I want