X-Git-Url: https://git.mdrn.pl/django-migdal.git/blobdiff_plain/2be35cd176b907e93f663618d000522c2920923f..d5a0741cc7b699d6124663921b686d14f8ad6206:/migdal/models.py diff --git a/migdal/models.py b/migdal/models.py index d0b16c0..703ef21 100644 --- a/migdal/models.py +++ b/migdal/models.py @@ -12,7 +12,7 @@ from django.db import models from django.template import loader, Context from django.utils.translation import ugettext_lazy as _, ugettext from django_comments_xtd.models import XtdComment -from markupfield.fields import MarkupField +from fnpdjango.utils.fields import TextileField from fnpdjango.utils.models.translation import add_translatable, tQ from migdal import app_settings from migdal.fields import SlugNullField @@ -40,12 +40,24 @@ add_translatable(Category, { class PublishedEntryManager(models.Manager): - def get_query_set(self): - return super(PublishedEntryManager, self).get_query_set().filter( + def get_queryset(self): + return super(PublishedEntryManager, self).get_queryset().filter( tQ(published=True) ) +class PhotoGallery(models.Model): + key = models.CharField(max_length=64) + + def __unicode__(self): + return self.key + + +class Photo(models.Model): + gallery = models.ForeignKey(PhotoGallery) + image = models.ImageField(_('image'), upload_to='entry/photo/', null=True, blank=True) + + class Entry(models.Model): type = models.CharField( max_length=16, @@ -63,6 +75,7 @@ class Entry(models.Model): categories = models.ManyToManyField(Category, blank=True, verbose_name=_('categories')) first_published_at = models.DateTimeField(_('published at'), null=True, blank=True) canonical_url = models.URLField(_('canonical link'), null=True, blank=True) + gallery = models.ForeignKey(PhotoGallery, null=True, blank=True) objects = models.Manager() published_objects = PublishedEntryManager() @@ -130,15 +143,17 @@ add_translatable(Entry, languages=app_settings.OPTIONAL_LANGUAGES, fields={ default='n'), }) +TEXTILE_HELP = _('Use Textile syntax.') + add_translatable(Entry, { 'slug': SlugNullField(unique=True, db_index=True, null=True, blank=True), 'title': models.CharField(_('title'), max_length=255, null=True, blank=True), - 'lead': MarkupField( - _('lead'), markup_type='textile_pl', null=True, blank=True, - help_text=_('Use Textile syntax.')), - 'body': MarkupField( - _('body'), markup_type='textile_pl', null=True, blank=True, - help_text=_('Use Textile syntax.')), + 'lead': TextileField( + _('lead'), markup_type='textile_pl', null=True, blank=True, help_text=TEXTILE_HELP), + 'body': TextileField( + _('body'), markup_type='textile_pl', null=True, blank=True, help_text=TEXTILE_HELP), + 'place': models.CharField(_('place'), null=True, blank=True, max_length=256), + 'time': models.CharField(_('time'), null=True, blank=True, max_length=256), 'published': models.BooleanField(_('published'), default=False), 'published_at': models.DateTimeField(_('published at'), null=True, blank=True), })