10472/expiry-date-to-entry #2

Merged
mravi merged 3 commits from 10472/expiry-date-to-entry into master 2022-05-04 08:32:29 +00:00
3 changed files with 33 additions and 3 deletions

View file

@ -0,0 +1,18 @@
# Generated by Django 3.2.13 on 2022-05-03 10:09
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('feedler', '0008_auto_20171117_1647'),
]
operations = [
migrations.AddField(
model_name='entry',
name='expire_at',
field=models.DateTimeField(blank=True, null=True, verbose_name='expiry date/time'),
),
]

View file

@ -1,9 +1,10 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
import datetime
from django.db import models from django.db import models
from django.utils import translation from django.utils import translation
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
from django.utils.translation import gettext_lazy as _
from wagtail.core.models import Page, Orderable from wagtail.core.models import Page, Orderable
from wagtail.admin.edit_handlers import FieldPanel from wagtail.admin.edit_handlers import FieldPanel
from wagtail.core.fields import RichTextField from wagtail.core.fields import RichTextField
@ -39,6 +40,11 @@ class Entry(models.Model):
lang = models.CharField(max_length=2, blank=True, default='', choices=LANGUAGE_CHOICES) lang = models.CharField(max_length=2, blank=True, default='', choices=LANGUAGE_CHOICES)
content = models.TextField() content = models.TextField()
tags = models.TextField(blank=True) tags = models.TextField(blank=True)
expire_at = models.DateTimeField(
verbose_name=_("expiry date/time"),
blank=True,
null=True
)
stream = models.ForeignKey(Stream, stream = models.ForeignKey(Stream,
blank=False, on_delete=models.CASCADE, blank=False, on_delete=models.CASCADE,
@ -68,7 +74,9 @@ class FeedPage(Page):
@property @property
def feedentries(self): def feedentries(self):
if self.stream: if self.stream:
entries = Entry.objects.filter(stream=self.stream) entries = Entry.objects.filter(stream=self.stream).filter(
models.Q(expire_at__isnull=True) | models.Q(expire_at__gt=datetime.datetime.now())
)
else: else:
entries = Entry.objects.all() entries = Entry.objects.all()
# Filter out by chosen language # Filter out by chosen language

View file

@ -2,6 +2,8 @@
from __future__ import unicode_literals from __future__ import unicode_literals
import datetime
from django.db import models from django.db import models
from django.utils import translation from django.utils import translation
from django.conf import settings from django.conf import settings
@ -320,7 +322,9 @@ class HomePage(Page):
@property @property
def newsentries(self): def newsentries(self):
# Get the last few news entries for the home page # Get the last few news entries for the home page
entries = Entry.objects.all().order_by('-published') entries = Entry.objects.filter(
models.Q(expire_at__isnull=True) | models.Q(expire_at__gt=datetime.datetime.now())
).all().order_by('-published')
# Filter out by current language # Filter out by current language
curlang = translation.get_language() curlang = translation.get_language()
if curlang in ['de']: if curlang in ['de']: