goelakash
goelakash

Reputation: 2519

objects.all() query not working

I am trying to make a form for user creation through django. The user(henceforth developer) can choose from a list of supervisors to get himself registered. Problem is, I am not getting the list of all the supervisors from the query. When I use objects.get(), I receive an error that 2 objects were received. That means that the queries are getting the rows from the database.

models.py

from django.db import models

class UserProfile(models.Model):
    name = models.CharField(max_length=50,verbose_name="Name")
    login = models.CharField(max_length=(25),verbose_name="Login")
    password = models.CharField(max_length=100, verbose_name="Password")
    phone = models.CharField(max_length=20, verbose_name="Phone number", null=True, default=None, blank=True)
    born_date = models.DateField(verbose_name="Born date" , null=True,default=None, blank=True)
    last_connection = models.DateTimeField(verbose_name="Date of last connection" , null=True, default=None, blank=True)
    email = models.EmailField(verbose_name="Email")
    years_seniority = models.IntegerField(verbose_name="Seniority", default=0)
    date_created = models.DateField(verbose_name="Date of Birthday", auto_now_add=True)

    def __str__(self):
        return self.name


class Supervisor(UserProfile):
    specialisation = models.CharField(max_length=50, verbose_name="Specialisation")

class Developer(UserProfile):
    supervisor = models.ForeignKey(Supervisor, verbose_name="Supervisor")

The form view create_developer.py -

from django.shortcuts import render
from django.http import HttpResponse
from TasksManager.models import Supervisor, Developer
# View for create_developer
def page(request):
    error = False
    # If form has posted
    if request.POST:
        if 'name' in request.POST:
            name = request.POST.get('name', '')
        else:
            error=True
        if 'login' in request.POST:
            login = request.POST.get('login', '')
        else:
            error=True
        if 'password' in request.POST:
            password = request.POST.get('password', '')
        else:
            error=True
        if 'supervisor' in request.POST:
            supervisor_id = request.POST.get('supervisor', '')
        else:
            error=True
        if not error:
            supervisor = Supervisor.objects.get(id = supervisor_id)
            new_dev = Developer(name=name, login=login, password=password,supervisor=supervisor)
            new_dev.save()
            return HttpResponse("Developer added")
        else:
            return HttpResponse("An error as occured")
    else:
        supervisors_list =  Supervisor.objects.all()
        return render(request, 'en/public/create_developer.html')

template create_developer.html

{% extends "base.html" %}
    {% block title_html %}
        Create Developer
    {% endblock %}
    {% block h1 %}
        Create Developer
    {% endblock %}
    {% block article_content %}
        <form method="post" action="{% url 'create_developer' %}" >


        <table>
            <tr>
                <td>Name</td>
                <td>
                    <input type="text" name="name" />
                </td>
            </tr>

            <tr>
                <td>Login</td>
                <td>
                    <input type="text" name="login" />
                </td>
            </tr>

            <tr>
                <td>Password</td>
                <td>
                <input type="text" name="password" />
                </td>
            </tr>

            <tr>
            <td>Supervisor</td>
            <td>
                <select name="supervisor">  
                    {% for supervisor in supervisors_list %}
                        <option value="{{ supervisor.id }}">{{ supervisor.name}}</option>
                    {% endfor %}
                </select>
            </td>
            </tr>

            <tr>
                <td></td>
                <td>
                    <input type="submit" value="Valid" />
                </td>
            </tr>

        </table>
    </form>
{% endblock %}

The supervisor select list should show the list. But I am getting an empty list there. The output of {{ supervisors_list|length }} is zero.

How to debug this? enter image description here

Upvotes: 2

Views: 5411

Answers (1)

pythad
pythad

Reputation: 4267

You have to pass context to the html:

from django.shortcuts import render
from django.http import HttpResponse
from TasksManager.models import Supervisor, Developer
# View for create_developer
def page(request):
    error = False
    # If form has posted
    if request.POST:
        if 'name' in request.POST:
            name = request.POST.get('name', '')
        else:
            error=True
        if 'login' in request.POST:
            login = request.POST.get('login', '')
        else:
            error=True
        if 'password' in request.POST:
            password = request.POST.get('password', '')
        else:
            error=True
        if 'supervisor' in request.POST:
            supervisor_id = request.POST.get('supervisor', '')
        else:
            error=True
        if not error:
            supervisor = Supervisor.objects.get(id = supervisor_id)
            new_dev = Developer(name=name, login=login, password=password,supervisor=supervisor)
            new_dev.save()
            return HttpResponse("Developer added")
        else:
            return HttpResponse("An error as occured")
    else:
        supervisors_list =  Supervisor.objects.all()
        return render(request, 'en/public/create_developer.html', {'supervisors_list' : supervisors_list})

Upvotes: 3

Related Questions