X-Git-Url: https://git.mdrn.pl/django-migdal.git/blobdiff_plain/2be35cd176b907e93f663618d000522c2920923f..c176b125612945be925d25922a6fe1db4d1def50:/migdal/models.py
diff --git a/migdal/models.py b/migdal/models.py
index d0b16c0..7cef388 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
@@ -33,15 +33,15 @@ class Category(models.Model):
return 'migdal_category', [self.slug]
-add_translatable(Category, {
+add_translatable(Category, languages=app_settings.LANGUAGES, fields={
'title': models.CharField(max_length=64, unique=True, db_index=True),
'slug': models.SlugField(unique=True, db_index=True),
})
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)
)
@@ -77,7 +77,7 @@ class Entry(models.Model):
def save(self, *args, **kwargs):
published_now = False
- for lc, ln in settings.LANGUAGES:
+ for lc, ln in app_settings.LANGUAGES:
if (getattr(self, "published_%s" % lc)
and getattr(self, "published_at_%s" % lc) is None):
now = datetime.now()
@@ -90,7 +90,7 @@ class Entry(models.Model):
self.notify_author_published()
def clean(self):
- for lc, ln in settings.LANGUAGES:
+ for lc, ln in app_settings.LANGUAGES:
if (getattr(self, "published_%s" % lc) and
not getattr(self, "slug_%s" % lc)):
raise ValidationError(
@@ -130,15 +130,17 @@ add_translatable(Entry, languages=app_settings.OPTIONAL_LANGUAGES, fields={
default='n'),
})
-add_translatable(Entry, {
+TEXTILE_HELP = _('Use Textile syntax.')
+
+add_translatable(Entry, languages=app_settings.LANGUAGES, fields={
'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),
})
@@ -152,6 +154,14 @@ class Attachment(models.Model):
return self.file.url if self.file else ''
+class Photo(models.Model):
+ image = models.ImageField(_('image'), upload_to='entry/photo/')
+ entry = models.ForeignKey(Entry)
+
+ def url(self):
+ return self.image.url if self.image else ''
+
+
def notify_new_comment(sender, instance, created, **kwargs):
if created and isinstance(instance.content_object, Entry) and instance.content_object.author_email:
site = Site.objects.get_current()