Taking in changes from andis
This commit is contained in:
@@ -65,7 +65,7 @@ ROOT_URLCONF = 'fet2020.urls'
|
|||||||
TEMPLATES = [
|
TEMPLATES = [
|
||||||
{
|
{
|
||||||
'BACKEND': 'django.template.backends.django.DjangoTemplates',
|
'BACKEND': 'django.template.backends.django.DjangoTemplates',
|
||||||
'DIRS': [os.path.join(BASE_DIR, 'templates_design1')],
|
'DIRS': [os.path.join(BASE_DIR, 'templates'),os.path.join(BASE_DIR, 'templates_design1')],
|
||||||
'APP_DIRS': True,
|
'APP_DIRS': True,
|
||||||
'OPTIONS': {
|
'OPTIONS': {
|
||||||
'context_processors': [
|
'context_processors': [
|
||||||
|
|||||||
@@ -13,6 +13,9 @@ from django.db.models import Q
|
|||||||
|
|
||||||
from datetime import timedelta
|
from datetime import timedelta
|
||||||
|
|
||||||
|
import logging
|
||||||
|
logger = logging.getLogger('posts')
|
||||||
|
|
||||||
#TODO: is_fetsitzung -> is_fetmeeting
|
#TODO: is_fetsitzung -> is_fetmeeting
|
||||||
|
|
||||||
############
|
############
|
||||||
@@ -108,11 +111,27 @@ class Post(models.Model):
|
|||||||
if self.image:
|
if self.image:
|
||||||
return self.image.url
|
return self.image.url
|
||||||
else:
|
else:
|
||||||
return ""
|
image=self.find_an_image()
|
||||||
|
if image:
|
||||||
|
return image.url
|
||||||
|
else:
|
||||||
|
return ""
|
||||||
|
|
||||||
def key(self):
|
def key(self):
|
||||||
return self.slug or self.id
|
return self.slug or self.id
|
||||||
|
|
||||||
|
def find_an_image(self):
|
||||||
|
"find an image via another post"
|
||||||
|
posts1=Post.objects.filter(slug__in=self.tags.names()).filter(image__isnull=False)[0:1].all() # Query all posts that have a slug that equals one of the tags
|
||||||
|
if len(posts1)>0:
|
||||||
|
return posts1.get().image
|
||||||
|
|
||||||
|
posts2=self.tags.similar_objects()
|
||||||
|
for p in posts2:
|
||||||
|
if p.image is not None:
|
||||||
|
return p.image
|
||||||
|
return None
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def url(self):
|
def url(self):
|
||||||
return reverse('posts.show', kwargs={"id":self.slug})
|
return reverse('posts.show', kwargs={"id":self.slug})
|
||||||
@@ -136,6 +155,7 @@ class PostSerializer(serializers.HyperlinkedModelSerializer):
|
|||||||
fields = ['slug', 'title', 'subtitle', 'body', 'url', 'public_date',
|
fields = ['slug', 'title', 'subtitle', 'body', 'url', 'public_date',
|
||||||
'legacy_id', 'image', 'event_start', 'event_end',
|
'legacy_id', 'image', 'event_start', 'event_end',
|
||||||
'is_fetsitzung']
|
'is_fetsitzung']
|
||||||
|
|
||||||
class News(Post):
|
class News(Post):
|
||||||
class Meta:
|
class Meta:
|
||||||
proxy = True
|
proxy = True
|
||||||
@@ -192,4 +212,4 @@ class FetMeeting(Event):
|
|||||||
if not self.event_end:
|
if not self.event_end:
|
||||||
self.event_end = self.event_start + timedelta(hours=2)
|
self.event_end = self.event_start + timedelta(hours=2)
|
||||||
|
|
||||||
super().save(*args, **kwargs)
|
super().save(*args, **kwargs)
|
||||||
|
|||||||
@@ -43,7 +43,8 @@ def show(request,id=None):
|
|||||||
p=Post.objects.get(id=int(id))
|
p=Post.objects.get(id=int(id))
|
||||||
elif id != ""and not id is None:
|
elif id != ""and not id is None:
|
||||||
p=Post.objects.get(slug=(id))
|
p=Post.objects.get(slug=(id))
|
||||||
return render(request, 'posts/show.html', {"post":p,"next":get_next_dict().get(p.slug,None)})
|
similar_posts = p.tags.similar_objects()
|
||||||
|
return render(request, 'posts/show.html', {"post":p,"next":get_next_dict().get(p.slug,None), "related_posts": similar_posts})
|
||||||
|
|
||||||
# Ajax function that is called to calculate a slug from the title
|
# Ajax function that is called to calculate a slug from the title
|
||||||
def slug_calc(request):
|
def slug_calc(request):
|
||||||
|
|||||||
Reference in New Issue
Block a user