initial OPDS catalogue support
[wolnelektury.git] / apps / sponsors / models.py
index ffad8e7..a2e3e08 100644 (file)
@@ -1,13 +1,28 @@
+# -*- coding: utf-8 -*-
+# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
+# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
+#
 from django.db import models
 from django.utils.translation import ugettext_lazy as _
+from django.template.loader import render_to_string
+
+from sorl.thumbnail.fields import ImageWithThumbnailsField
+from sponsors.fields import JSONField
 
 
 class Sponsor(models.Model):
     name = models.CharField(_('name'), max_length=120)
     _description = models.CharField(_('description'), blank=True, max_length=255)
-    logo = models.ImageField(_('logo'), upload_to='sponsors/sponsor/logo')
+    logo = ImageWithThumbnailsField(
+        _('logo'),
+        upload_to='sponsorzy/sponsor/logo',
+        thumbnail={
+            'size': (120, 120),
+            'extension': 'png',
+            'options': ['pad', 'detail'],
+        })
     url = models.URLField(_('url'), blank=True, verify_exists=False)
-    
+
     def __unicode__(self):
         return self.name
 
@@ -18,18 +33,34 @@ class Sponsor(models.Model):
             return self.name
 
 
-class SponsorGroup(models.Model):
+class SponsorPage(models.Model):
     name = models.CharField(_('name'), max_length=120)
-    order = models.IntegerField(_('order'), default=0)
-    column_width = models.PositiveIntegerField(_('column width'))
-    sponsor_ids = models.CommaSeparatedIntegerField(_('sponsors'), max_length=255)
-    
-    def sponsors(self):
-        ids = [int(pk) for pk in self.sponsor_ids.split(',')]
-        result = Sponsor.objects.in_bulk(ids)
-        return [result[pk] for pk in ids]
-    sponsors.changes_data = False
-    
+    sponsors = JSONField(_('sponsors'), default={})
+    _html = models.TextField(blank=True, editable=False)
+
+    def populated_sponsors(self):
+        result = []
+        for column in self.get_sponsors_value():
+            result_group = {'name': column['name'], 'sponsors': []}
+            sponsor_objects = Sponsor.objects.in_bulk(column['sponsors'])
+            for sponsor_pk in column['sponsors']:
+                try:
+                    result_group['sponsors'].append(sponsor_objects[sponsor_pk])
+                except KeyError:
+                    pass
+            result.append(result_group)
+        return result
+
+    def html(self):
+        return self._html
+    html = property(fget=html)
+
+    def save(self, *args, **kwargs):
+        self._html = render_to_string('sponsors/page.html', {
+            'sponsors': self.populated_sponsors(),
+        })
+        return super(SponsorPage, self).save(*args, **kwargs)
+
     def __unicode__(self):
         return self.name