Vladislav MelenchukMay 26, 2020, 9:26 a.m.

Templatetags из GenericForeign

Django

Всем привет, не подскажете как сделать templatetags на вывод последних комментариев в сайдбаре для постов? Именно для постов.

@register.simple_tag()
def get_last_comments():
    return Comment.objects.all()

Пробовал из Post.comments.all
Выводит:

'ReverseGenericManyToOneDescriptor' object has no attribute 'all'

Сам шаблон:

{% load core_tags %}

{% get_last_comments as comments %}
{% for comment in comments %}
<div class="card-body pt-1 p-0">
   <!-- Header -->
   <div class="mb-3">
      <div class="row align-items-center">
         <div class="col-auto">
            <!-- Avatar -->
            <div class="avatar avatar-sm">
               <img src="{% if comment.user.avatar %}{{ comment.user.avatar.url }}{% else %}/static/templates/images/noavatar.png{% endif %}" alt="Аватар" class="avatar-img rounded-circle">
            </div>
         </div>
         <div class="col ml-n3">
            <!-- Title -->
            <h6 class="mb-1 small font-weight-bold">
               {{ comment.user }}
               <button role="button" class="btn ml-1 btn-xs btn-white">{{ comment.user.first_name }}</button>
            </h6>
            <!-- Time -->
            <p class="card-text small text-muted">
               <span class="far fa-clock"></span> <time>{{ comment.pub_date }}</time>
            </p>
         </div>
      </div>
   </div>
   <!-- Text -->
   <div class="mb-3 comment-body-last p-2 card-text">
      {{ comment.text|safe|truncatechars:200 }}
   </div>
   <a href="{{ comment.post.get_absolute_url }}" class="small text-muted"><span class="fa fa-arrow-right"></span> {{ comment.post.title }} </a>
</div>
<hr>
{% endfor %}
We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
8

Как-то та должен выглядеть запрос к базе данных для GenericForeignKey

@register.simple_tag()
def get_last_comments():
    return Comment.objects.all(content_type=ContentType.objects.get_for_model(Post))[:5]

all() got an unexpected keyword argument 'content_type'

Конечно же filter

@register.simple_tag()
def get_last_comments():
    return Comment.objects.filter(content_type=ContentType.objects.get_for_model(Post))[:5]

Хм, ещё одна загвостка, а как мне вывести в шаблоне последних комментариев ссылку на пост этого комментария и название самого поста? Ранее писал {{ comment.post.title }}

Думаю, что в твоём случае так сработает {{ comment.content_object.title }}, если по джанговской документации всё делал.

О да, сработало! Отлично! Сейчас мучаюсь с фильтрацией ответов на коммент. Думаю как сделать. Раньше делал для простых комментов по related_name:

models.py for Post
# Вложенность
    def get_comments_article(self):
        return self.comments_article.filter(parent__isnull=True)

Как сейчас быть не знаешь?

Сделал так:

    def get_comments(self):
        return self.comments.filter(parent__isnull=True)

В шаблоне пропали комменты с parent. Щас буду выводить parent комменты. Ещё бы было бы сохранение какого-нибудь сдвига, как у тебя в гайде по комментам. Но хз как к себе прикрутить, тоже на pg сижу.

Прикрутил в шаблоне:

    {% for child_comment in comment.comment_set.all %}
        {{ child_comment.text }}
        {% endfor %}

Ну сохранение сдвига лучше всё-таки делать через materialized path, как и в статье сделано, тогда можно одним запросом выбирать все комментарии.
Там же просто последовательно сохраняются все id парент комментариев в цепочке.
Но если честно, мне не особо нравится такой подход. Пространство недостаточно эффективно используется в данном случае.
Главное в комментарии ещё делать внешний ключ на саму модель комментариев. У меня это поле answer_to.

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Timeweb

Let me recommend you the excellent hosting on which EVILEG is located.

For many years, Timeweb has been proving his stability.

For projects on Django I recommend VDS hosting

View Hosting
NI

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:90points,
  • Rating points8
NI

C++ - Тест 003. Условия и циклы

  • Result:92points,
  • Rating points8
NI

C++ - Test 001. The first program and data types

  • Result:80points,
  • Rating points4
Last comments
D

Django - Tutorial 001. Deploying a site on Django + PostgreSQL + Gunicorn + Nginx

А почему нельзя? Где можно об этом почитать? Киньте, пожалуйста, в меня ссылкой.
D

Django - Tutoral 049. Optimizing Django Performance with a Real Project

Огромное спасибо вам за статью! Для меня стали открытием select_related и prefetch_related
t
  • t1m4
  • Feb. 24, 2021, 2:56 a.m.

Django - Tutorial 052. Redefining a User Model

В данном случае я заходил под superuser но все равно не появлялись эти поля

Django - Tutorial 001. Deploying a site on Django + PostgreSQL + Gunicorn + Nginx

Поднял сервис с помощью systemd, вот по этому мануалу: https://habr.com/ru/post/501414/
t
  • t1m4
  • Feb. 23, 2021, 7:11 a.m.

Django - Tutorial 052. Redefining a User Model

А как дать ему эти права?
Now discuss on the forum
S

Помощь в проекте qt, qml

Доброго времени суток! Хотелось бы получить консультативную помощь по проекту, т.к. имеются определенные затыки, которые своими силами преодолеть не получается. За труды по наущению меня ум…

Добавление данных в модель из textEdit

ознакомьтесь с этим и этим для понимания принципов работы с моделями, и поймете что у вас не так
  • BlinCT
  • March 6, 2021, 10:57 a.m.

Работа с QJsonObject и получение данных из него

Вопрос решен. Оказалось что я не очень внимательно прочитал описание метода root.take("devices") Оказывается он удаляте ключ, а занчит и все данные по нему. И по этому после этого…

Как совместить таблицу и дерево в Qt

Добрый день. Имеется таблица QTableView, нужно у некоторых строк сделать возможность раскрытий, как в QTreeVidget и отоборажать в них аналогичные строки. Скажите пожалуйста, как это мо…
KM

не получаеться добавить списки в списокб ошибка в петле

решение: с line 99: listy = [] lista = [] for single_lp in max_list_from_all_plates: suma = 0 lists = [] for sign in single_lp: Highest_score=0 bigl…
About
Services
© EVILEG 2015-2020
Recommend hosting TIMEWEB