Пользовательские атрибуты модели не передаются в шаблон - PullRequest
0 голосов
/ 06 апреля 2020

У меня есть пользовательская модель пользователя, и у меня есть мои настройки. Мое указание на мою пользовательскую модель «Профиль». Я пытаюсь отобразить страницу, которая выберет один из моих объектов профиля и отобразит их случайным образом. Тогда мой пользователь сможет выбрать нравится или не нравится. Но я застрял в том, чтобы просто показать их. Так как я только что получил страницу с надписью «BIO» без биографии пользователя и фотографии пользователя. Логика c в views.py возвращает меня к шаблону, но нужная мне информация не отображается. И, кроме того, каждый раз, когда я go перехожу по этой ссылке, текущий вошедший в систему пользователь меняется на другого пользователя! Так что не уверен, что там происходит, но я считаю, что что-то не так с моей логикой c.

шаблон. html

{% extends "dating_app/base.html" %}
{% load bootstrap4 %}


{% block content %}

<div class="tindero">
    {% if user %}
        <div class="container content is-child box column is-4 is-offset-4">
            <img src="{{ profile.photo.url  }}">
            <p style="font-size: 25px">{{profile.username}}</p>

            <b>Bio:</b>
            <p>{{profile.description}}</p>

        </div>
    {% else %}
        <p>Wait for more people to join!</p>
        <p>Help us get more user. Share this link to your friends! <a href="http://localhost:8000/">http://localhost:8000/</a></p>
  {% endif %}
{% endblock %}

views.py

def mingle(request):




    try:
        user = (Profile.objects.exclude(id=request.user.id).exclude(uservote__voter=request.user).order_by('?')[0])
    except IndexError:
        user = None
        print(Profile.username)
    try:

        description = request.user.description
    except Profile.DoesNotExist:
        create = Profile.objects.get_or_create(user = request.user)
        return redirect('profile')

    match = request.user.matches.all()
    context = dict(user = user, match = match)  
    return render(request, 'dating_app/mingle.html', context)

models.py

from django.db import models
from django.contrib.auth.models import AbstractBaseUser,BaseUserManager, User
from dating_project import settings
from django.contrib.auth import get_user_model


class ProfileManager(BaseUserManager):



    def create_user(self, username, email,description,photo, password=None):
        if not email:
            raise ValueError("You must creat an email")
        if not username:
            raise ValueError("You must create a username!")
        if not description:
            raise ValueError("You must write a description")
        if not photo:
            raise ValueError("You must upload a photo")

        user = self.model(
                email=self.normalize_email(email),
                username = username, 
                description= description,
                photo= photo,

            )

        user.set_password(password)
        user.save(using=self._db)
        return user 


    def create_superuser(self, username, email,description,photo, password):
        user = self.create_user(
                email=self.normalize_email(email),
                password=password,
                username=username,
                description=description,
                photo=photo,

            )

        user.is_admin=True
        user.is_staff=True
        user.is_superuser=True
        user.save(using=self._db)
        return user




class Profile(AbstractBaseUser):

    class Meta:
        swappable = 'AUTH_USER_MODEL'


    email                       = models.EmailField(verbose_name="email")
    username                    = models.CharField(max_length=30, unique=True)
    date_joined                 = models.DateTimeField(verbose_name='date joined', auto_now_add=True)
    last_login                  = models.DateTimeField(verbose_name='last login', auto_now=True)
    is_admin                    = models.BooleanField(default=False)
    is_active                   = models.BooleanField(default=True)
    is_staff                    = models.BooleanField(default=False)
    is_superuser                = models.BooleanField(default=False)
    #what I added
    description                 = models.TextField()
    photo                       = models.ImageField(upload_to='profile_photo',blank=False, height_field=None, width_field=None, max_length=100)
    matches                     = models.ManyToManyField(settings.AUTH_USER_MODEL, related_name='+', blank=True)



    USERNAME_FIELD = 'username'
    REQUIRED_FIELDS = ['description','photo','email']


    objects = ProfileManager()


    def __str__(self):
        return self.username


    def has_perm(self, perm, obj=None):
        return self.is_admin


    def has_module_perms(self,app_label):
        return True



class UserVote(models.Model):
    user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)

    voter = models.ForeignKey(settings.AUTH_USER_MODEL, related_name='given_vote', on_delete=models.CASCADE)
    vote = models.BooleanField(default=False)

    class Meta:
        unique_together = (('user', 'voter'))

1 Ответ

0 голосов
/ 06 апреля 2020

Вы используете {{profile.blabla}} в своем шаблоне, но в вашем контексте у вас есть

context = dict(user = user, match = match) 

. Вы можете использовать только теги шаблона (не обязательно для термина), которые присутствуют в вашем контексте.

Так что используйте правильную переменную ...

try:
    profile = (Profile.objects.exclude(id=request.user.id).exclude(uservote__voter=request.user).order_by('?')[0])


except IndexError:
    profile = None
    print(Profile.username)

except Profile.DoesNotExist:
    create = Profile.objects.get_or_create(user = request.user)
    return redirect('profile')

... и поместите ее в контекст

context = dict(profile = profile, match = match)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...