bornhack-website/news/models.py

47 lines
1.7 KiB
Python
Raw Normal View History

2016-05-30 19:36:14 +00:00
from __future__ import unicode_literals
from django.db import models
from django.utils import encoding
from django.utils.text import slugify
2016-05-30 19:36:14 +00:00
from utils.models import CreatedUpdatedModel
2016-05-30 19:36:14 +00:00
@encoding.python_2_unicode_compatible
2016-05-30 19:36:14 +00:00
class NewsItem(CreatedUpdatedModel):
class Meta:
ordering = ['-published_at']
title = models.CharField(max_length=100)
content = models.TextField()
published_at = models.DateTimeField(null=True, blank=True)
slug = models.SlugField(max_length=255, blank=True)
archived = models.BooleanField(default=False)
2016-05-30 19:36:14 +00:00
def __str__(self):
return self.title
def save(self, **kwargs):
if self.published_at:
# if this is a new newsitem, or it doesn't have a slug, or the slug is in use on another item, create a new slug
if (not self.pk or not self.slug or NewsItem.objects.filter(slug=self.slug).count() > 1):
published_at_string = self.published_at.strftime('%Y-%m-%d')
base_slug = slugify(self.title)
slug = '{}-{}'.format(published_at_string, base_slug)
incrementer = 1
# We have to make sure that the slug won't clash with current slugs
while NewsItem.objects.filter(slug=slug).exists():
if incrementer == 1:
slug = '{}-1'.format(slug)
else:
slug = '{}-{}'.format(
'-'.join(slug.split('-')[:-1]),
incrementer
)
incrementer += 1
self.slug = slug
super(NewsItem, self).save(**kwargs)