Отображение кнопок «Нравится» и «Не нравится», если пользователю понравился пост с Django - PullRequest
0 голосов
/ 14 июля 2020

спасибо, что нашли время, чтобы прочитать это.

Я работаю над проектом для CS50W, в котором я должен отображать серию сообщений, которые пользователям могут понравиться, а затем не понравиться.

Я могу успешно отобразить количество лайков, но не могу заставить кнопку «Мне нравится» измениться на «Не нравится», когда это будет сделано.

Вот соответствующий код:

просмотров .py

def index(request):
    return render(request, "network/index.html", {
        "posts": Post.objects.all().order_by('time'),
        "form": NewPost(),
        "likes": Like.objects.all(),
    })

...

def like(request, post_id):
    if request.method == "POST":
        #make sure user can't like the post more than once. 
        user = User.objects.get(username=request.user.username)
        #find whatever post is associated with like
        post = Post.objects.get(id=post_id)
        #access liked values: 

        if Like.objects.filter(user=user, post=post).exists():
            Like.alreadyLiked = True
            return HttpResponseRedirect(reverse('index'))
        else: 
            newLike = Like(user=user, post=post)
            newLike.alreadyLiked = True
            post.likes += 1
            post.save()
            newLike.save()
            return HttpResponseRedirect(reverse('index'))
    

Затем models.py

from django.contrib.auth.models import AbstractUser
from django.db import models
import datetime


class User(AbstractUser):
    pass

class Post(models.Model):
    text = models.CharField(max_length=127)
    user = models.ForeignKey(User, on_delete=models.CASCADE, related_name="author")
    time = models.TimeField(auto_now=False, auto_now_add=True)
    likes = models.PositiveIntegerField(default=0)

    def __str__(self):
        if self.likes == 1:
            return f"{self.user} ({self.time}): {self.text} - {self.likes} Like"
        elif self.likes == 0:
            return f"{self.user} ({self.time}): {self.text} - No Likes"
        else:
            return f"{self.user} ({self.time}): {self.text} - {self.likes} Likes"

class Like(models.Model):
    user = models.ForeignKey(User, on_delete=models.CASCADE, related_name="users")
    post = models.ForeignKey(Post, on_delete=models.CASCADE, related_name="posts")
    alreadyLiked = models.BooleanField(default=False)

    def __str__(self):
        return f"{self.user} liked {self.post}"

Наконец, index. html где отображается кнопка.

{% extends "network/layout.html" %}

{% block body %}



<form action="/newPost" method="post" name="newPost">
{% csrf_token %}
{{ form.content }}
<input type="submit">
</form>


{% for post in posts %}


<div id="post{{post.id}}">{{ post }}

{% if likes.post == post and likes.user == user.username %}

    <form action="{% url 'dislike' post.id  %}" method="post" name="dislike" id="dislikeform">
        {% csrf_token %}
        <button type='submit' name='dislike' value="{{ post.id }}" class="btn btn-primary">Dislike</button>
    </form>

{% else %}    

    <form action="{% url 'like' post.id  %}" method="post" name="like" id="likeform">
        {% csrf_token %}
        <button type='submit' name='like' value="{{ post.id }}" class="btn btn-primary">Like</button>
    </form>

{% endif %}

{% if follows.following == True %}

    <form action="{% url 'unfollow' post.user  %}" method="post" name="follow">
        {% csrf_token %}
        <button type='submit' name='follow' value="{{ post.user }}" class="btn btn-primary">Follow</button>
    </form>

{% else %}

    <form action="{% url 'follow' post.user  %}" method="post" name="follow">
        {% csrf_token %}
        <button type='submit' name='follow' value="{{ post.user }}" class="btn btn-primary">Follow</button>
    </form>

{% endif %}

</div>

{% endfor %}

{% endblock %}

Моя идея заключается в том, что в части формы «Нравится» и «Не нравится» шаблон django должен определять, понравилась ли уже вошедшему в систему пользователю публикация, и в этом случае вместо кнопки «Мне нравится» будет отображаться кнопка «Не нравится». Самое главное, этот сегмент:


{% if likes.post == post and likes.user == user.username %}

    <form action="{% url 'dislike' post.id  %}" method="post" name="dislike" id="dislikeform">
        {% csrf_token %}
        <button type='submit' name='dislike' value="{{ post.id }}" class="btn btn-primary">Dislike</button>
    </form>

{% else %}    

    <form action="{% url 'like' post.id  %}" method="post" name="like" id="likeform">
        {% csrf_token %}
        <button type='submit' name='like' value="{{ post.id }}" class="btn btn-primary">Like</button>
    </form>

{% endif %}

У меня аналогичная проблема с кнопками Follow и Unfollow, но я чувствую, что если я смогу реализовать первое решение проблемы, я тоже смогу применить его.

1 Ответ

0 голосов
/ 14 июля 2020

Разобрался после переосмысления отношений модели.

Я добавил новое поле в свою модель публикации:

class Post(models.Model):
    text = models.CharField(max_length=127)
    user = models.ForeignKey(User, on_delete=models.CASCADE, related_name="author")
    time = models.TimeField(auto_now=False, auto_now_add=True)
    likes = models.PositiveIntegerField(default=0)
    user_likes = models.ManyToManyField(User)

Пользователь теперь связан с публикацией как ManytoManyField, что позволяет мне для создания отношений между этими моделями.

затем в views.py:

def like(request, post_id):
    if request.method == "POST":
        #make sure user can't like the post more than once. 
        user = User.objects.get(username=request.user.username)
        #find whatever post is associated with like
        post = Post.objects.get(id=post_id)

        newLike = Like(user=user, post=post)
        newLike.alreadyLiked = True

        post.likes += 1
        #adds user to Post 
        post.user_likes.add(user)
        post.save()
        newLike.save()
        return HttpResponseRedirect(reverse('index'))

Я сделал то же самое для неприязни и попробую то же самое для подписки и отмены подписки.

Наконец, в index. html:

{% if user in post.user_likes.all %}

    <form action="{% url 'dislike' post.id  %}" method="post" name="dislike" id="dislikeform">
        {% csrf_token %}
        <button type='submit' name='dislike' value="{{ post.id }}" class="btn btn-primary">Dislike</button>
    </form>

{% else %}    

    <form action="{% url 'like' post.id  %}" method="post" name="like" id="likeform">
        {% csrf_token %}
        <button type='submit' name='like' value="{{ post.id }}" class="btn btn-primary">Like</button>
    </form>

{% endif %}

Теперь все работает отлично.

...