2014-01-04 16:07:09 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from cms.models import PlaceholderField, CMSPlugin
|
|
|
|
from cmsplugin_filer_image.models import ThumbnailOption
|
|
|
|
from django.contrib.auth.models import User
|
2014-01-08 21:33:20 +00:00
|
|
|
from django.contrib.sites.models import Site
|
2014-01-04 16:07:09 +00:00
|
|
|
from django.core.urlresolvers import reverse
|
|
|
|
from django.db import models
|
|
|
|
from django.utils import timezone
|
|
|
|
from django.utils.text import slugify
|
|
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
from djangocms_text_ckeditor.fields import HTMLField
|
|
|
|
from filer.fields.image import FilerImageField
|
|
|
|
from hvad.models import TranslatableModel, TranslatedFields
|
|
|
|
from taggit_autosuggest.managers import TaggableManager
|
|
|
|
|
|
|
|
from .managers import GenericDateTaggedManager
|
|
|
|
from . import settings
|
|
|
|
|
|
|
|
|
|
|
|
class BlogCategory(TranslatableModel):
|
|
|
|
"""
|
|
|
|
Blog category
|
|
|
|
"""
|
|
|
|
parent = models.ForeignKey('self', verbose_name=_('parent'), null=True,
|
|
|
|
blank=True)
|
|
|
|
date_created = models.DateTimeField(_('created at'), auto_now_add=True)
|
|
|
|
date_modified = models.DateTimeField(_('modified at'), auto_now=True)
|
|
|
|
|
|
|
|
translations = TranslatedFields(
|
|
|
|
name=models.CharField(_('name'), max_length=255),
|
|
|
|
slug=models.SlugField(_('slug'), blank=True),
|
|
|
|
)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
verbose_name = _('blog category')
|
|
|
|
verbose_name_plural = _('blog categories')
|
2014-01-08 21:33:20 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def count(self):
|
|
|
|
return self.blog_posts.count()
|
2014-01-04 16:07:09 +00:00
|
|
|
|
|
|
|
def __unicode__(self):
|
|
|
|
return self.lazy_translation_getter('name')
|
|
|
|
|
|
|
|
def save(self, *args, **kwargs):
|
|
|
|
super(BlogCategory, self).save(*args, **kwargs)
|
|
|
|
for item in self._meta.translations_model.objects.filter(master__pk=self.pk):
|
|
|
|
title = getattr(item, "name", False)
|
|
|
|
if title and not item.slug:
|
|
|
|
item.slug = slugify(title)
|
|
|
|
item.save()
|
|
|
|
|
|
|
|
|
|
|
|
class Post(TranslatableModel):
|
|
|
|
"""
|
|
|
|
Blog post
|
|
|
|
"""
|
|
|
|
author = models.ForeignKey(User)
|
|
|
|
|
|
|
|
date_created = models.DateTimeField(auto_now_add=True)
|
|
|
|
date_modified = models.DateTimeField(auto_now=True)
|
|
|
|
date_published = models.DateTimeField(_('Published Since'),
|
|
|
|
default=timezone.now)
|
|
|
|
date_published_end = models.DateTimeField(_('Published Until'), null=True,
|
|
|
|
blank=True)
|
|
|
|
publish = models.BooleanField(default=False)
|
|
|
|
categories = models.ManyToManyField(BlogCategory, verbose_name=_('category'),
|
|
|
|
related_name='blog_posts',)
|
|
|
|
main_image = FilerImageField(blank=True, null=True)
|
|
|
|
main_image_thumbnail = models.ForeignKey(ThumbnailOption,
|
|
|
|
related_name='blog_post_thumbnail',
|
|
|
|
blank=True, null=True)
|
|
|
|
main_image_full = models.ForeignKey(ThumbnailOption,
|
2014-01-04 20:13:25 +00:00
|
|
|
related_name='blog_post_full',
|
|
|
|
blank=True, null=True)
|
2014-01-04 16:07:09 +00:00
|
|
|
|
|
|
|
translations = TranslatedFields(
|
|
|
|
title=models.CharField(max_length=255),
|
|
|
|
slug=models.SlugField(_('slug'), blank=True),
|
|
|
|
abstract=HTMLField(),
|
|
|
|
|
|
|
|
)
|
|
|
|
content = PlaceholderField("post_content")
|
|
|
|
|
|
|
|
objects = GenericDateTaggedManager()
|
|
|
|
tags = TaggableManager(blank=True)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
verbose_name = _('blog post')
|
|
|
|
verbose_name_plural = _('blog post')
|
|
|
|
|
|
|
|
def __unicode__(self):
|
|
|
|
return self.lazy_translation_getter('title')
|
|
|
|
|
|
|
|
def save(self, *args, **kwargs):
|
|
|
|
super(Post, self).save(*args, **kwargs)
|
|
|
|
for item in self._meta.translations_model.objects.filter(master__pk=self.pk):
|
|
|
|
title = getattr(item, "title", False)
|
|
|
|
if title and not item.slug:
|
|
|
|
item.slug = slugify(title)
|
|
|
|
item.save()
|
|
|
|
|
|
|
|
def get_absolute_url(self):
|
|
|
|
kwargs = {'year': self.date_published.year,
|
|
|
|
'month': self.date_published.month,
|
|
|
|
'day': self.date_published.day,
|
|
|
|
'slug': self.slug}
|
|
|
|
return reverse('djangocms_blog:post-detail', kwargs=kwargs)
|
|
|
|
|
|
|
|
def thumbnail_options(self):
|
|
|
|
if self.main_image_thumbnail_id:
|
2014-01-04 20:13:25 +00:00
|
|
|
return self.main_image_thumbnail.as_dict
|
2014-01-04 16:07:09 +00:00
|
|
|
else:
|
|
|
|
return settings.BLOG_IMAGE_THUMBNAIL_SIZE
|
2014-01-08 21:33:20 +00:00
|
|
|
|
|
|
|
def get_full_url(self):
|
|
|
|
s = Site.objects.get_current()
|
|
|
|
if s.domain.find('http') > -1:
|
|
|
|
return "%s%s" % (s.domain, self.get_absolute_url())
|
|
|
|
else:
|
|
|
|
return "http://%s%s" % (s.domain, self.get_absolute_url())
|
|
|
|
|
2014-01-04 16:07:09 +00:00
|
|
|
|
|
|
|
def full_image_options(self):
|
|
|
|
if self.main_image_fulll_id:
|
2014-01-04 20:13:25 +00:00
|
|
|
return self.main_image_full.as_dict
|
2014-01-04 16:07:09 +00:00
|
|
|
else:
|
|
|
|
return settings.BLOG_IMAGE_FULL_SIZE
|
|
|
|
|
|
|
|
|
|
|
|
class LatestPostsPlugin(CMSPlugin):
|
|
|
|
|
|
|
|
latest_posts = models.IntegerField(default=5, help_text=_('The number of latests posts to be displayed.'))
|
|
|
|
tags = models.ManyToManyField('taggit.Tag', blank=True, help_text=_('Show only the blog posts tagged with chosen tags.'))
|
2014-01-08 06:25:18 +00:00
|
|
|
categories = models.ManyToManyField('BlogCategory', blank=True, help_text=_('Show only the blog posts tagged with chosen tags.'))
|
2014-01-04 16:07:09 +00:00
|
|
|
|
|
|
|
def __unicode__(self):
|
|
|
|
return u"%s latest post by tag" % self.latest_posts
|
|
|
|
|
|
|
|
def copy_relations(self, oldinstance):
|
|
|
|
self.tags = oldinstance.tags.all()
|
|
|
|
|
|
|
|
def get_posts(self):
|
|
|
|
posts = Post.objects.published()
|
|
|
|
tags = list(self.tags.all())
|
|
|
|
if tags:
|
|
|
|
posts = posts.filter(tags__in=tags)
|
|
|
|
return posts[:self.latest_posts]
|
|
|
|
|
|
|
|
|
|
|
|
class AuthorEntriesPlugin(CMSPlugin):
|
|
|
|
authors = models.ManyToManyField(User, verbose_name=_('Authors'))
|
|
|
|
latest_posts = models.IntegerField(default=5, help_text=_('The number of author entries to be displayed.'))
|
|
|
|
|
|
|
|
def __unicode__(self):
|
|
|
|
return u"%s latest post by author" % self.latest_posts
|
|
|
|
|
|
|
|
def copy_relations(self, oldinstance):
|
|
|
|
self.authors = oldinstance.authors.all()
|
|
|
|
|
|
|
|
def get_posts(self):
|
|
|
|
posts = (Post.objects.published().filter(author__in=self.authors.all()))
|
|
|
|
return posts[:self.latest_posts]
|
|
|
|
|
|
|
|
def get_authors(self):
|
|
|
|
authors = self.authors.all()
|
|
|
|
return authors
|