Как обновить строку в Django, используя форму? - PullRequest
0 голосов
/ 08 ноября 2019

Я пытаюсь создать сайт для отслеживания посещаемости моих волонтеров с помощью django, там будет кнопка «заезд» и «заезд / выезд», поэтому при нажатии на кнопку «заезд / въезд» данные попадут в базу данных. Нет проблем с тем, что проблема в кнопке извлечения / выкупа; при нажатии кнопки выписки / выгрузки она должна обновить строку и добавить дату / время выписки / выписки.

models.py:

from django.db import models
from django.forms import ModelForm

# Create your models here.

class Volunteer(models.Model):
    full_name = models.CharField(max_length=200)
    phone_number = models.CharField(max_length=30)
    email = models.CharField(max_length=255)
    national_id = models.CharField(max_length=255)

    def __str__(self):
        return self.full_name

class Login(models.Model):
    full_name = models.CharField(max_length=200,default="", null=True,)
    national_id = models.CharField(max_length=200,default="", null=True,)
    check_in = models.DateTimeField(auto_now_add=True)
    check_out = models.DateTimeField(auto_now=True)
    check_in.editable=True
    check_out.editable=True

    def __str__(self):
        return self.full_name

views.py:

from django.shortcuts import render
from django.http import HttpResponse, HttpResponseRedirect
from .models import Volunteer, Login
from django import forms
# Create your views here. 


def volunteerView(request):
    if request.method=='POST':
        print ("Recieved a POST request")
        form=LoginForm(request.POST)
        if form.is_valid():
            print ("FORM is valid")
        else:
            print ("FORM is unvalid")
    all_volunteers = Volunteer.objects.all()
    return render(request, 'volunteer.html',
        {'all_volunteers': all_volunteers, 'form':LoginForm()})

def loginView(request):
    login_view = Login.objects.all()
    return render(request, 'login.html',
    {'login_view': login_view})



def addVolunteer(request):
    new_volunteer = Volunteer(full_name = request.POST['full_name'],
    phone_number = request.POST['phone_number'],
    email = request.POST['email'],
    national_id = request.POST['national_id'],
    )
    new_volunteer.save()
    return HttpResponseRedirect('/')

def addChekIn(request):
    new_checkin = Login(
        national_id = request.POST['national_id'],
        full_name = request.POST['full_name'],
    )
    new_checkin.save()
    return HttpResponseRedirect('/login/')

template / login.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Ertiqa | Login</title>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.0/css/bootstrap.min.css">
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.0/js/bootstrap.min.js"></script>  
</head>

<style>

h1{
    color: white;
}


</style>

<body>

    <form action="/addCheckIN/" method="POST" class="container">
        {{ form.as_p }}
        {% csrf_token %}
        <h1>Check IN</h1>
        <h3>Full Name</h3>
        <input type="text" name="full_name"><br>
        <h3>National ID</h3>
        <input type="text" name="national_id"><br>
        <input type="submit" value="Check IN" class="btn btn-primary">
    </form>


</body>

</html>

1 Ответ

0 голосов
/ 09 ноября 2019

У меня твоя проблема. Прежде всего, ваша выдумка models.py немного ошибочна. Вы можете использовать классы моделей следующим образом:

from django.db import models
from django.forms import ModelForm

# Create your models here.

class Volunteer(models.Model):
    full_name = models.CharField(max_length=200)
    phone_number = models.CharField(max_length=30)
    email = models.CharField(max_length=255)
    national_id = models.CharField(max_length=255)

    def __str__(self):
        return self.full_name

class Login(models.Model):
    full_name = models.CharField(max_length=200,default="", null=True)
    national_id = models.CharField(max_length=200,default="", null=True)
    check_in = models.DateTimeField(auto_now_add=True, editable=True) # <--- You can use editable arg inline.
    check_out = models.DateTimeField(auto_now=True, editable=True) # <--- You can use editable arg inline.

    def __str__(self):
        return self.full_name

Я думаю, вы не используете сеанс авторизации. Просто кто-то заполняет информацию и публикует эту информацию в БД. Зачем вам два класса как «Волонтер» и «Логин»? Имеют ли они какое-либо отношение или вам нужны две модели? Возможно, это лучше, чем это:

class Volunteer(models.Model):
    full_name = models.CharField(max_length=200, unique=True)
    phone_number = models.CharField(max_length=30)
    email = models.CharField(max_length=255)
    national_id = models.CharField(max_length=255, unique=True)
    check_in = models.DateTimeField(auto_now_add=True, editable=True) #<-- auto_now_add=True args mean: when you call .save() method first time, this field is filled in with the current date and time.
    check_out = models.DateTimeField(auto_now=True, editable=True) #<-- auto_now=True args mean: when you call .save() method second and next times (every updating), this field is filled in with the current date and time.


    def __str__(self):
        return self.full_name

Вам нужны две функции, первая была выполнена (def addCheckIn), поэтому вы вызываете метод .save () для сохранения новых добровольцев. Второй - для обновления (например, def checkout (request)). Поэтому вам следует снова вызвать метод .save () следующим образом:

def checkout(request):
    national_id = request.POST['national_id'], # If national_id is unique, It's enough.
    try: #Check this national id is exist in your db.
        person = Login.objects.get(national_id=national_id)
        person.save()
        messages.success(request, "Thank you for checkout blabla")
        return HttpResponseRedirect('/login/')  # Maybe you can create a success page.
    except LoginDoesNotExist: # If doesn't you can show error message.
        messages.error(request, "No such registry was found in the system.")
        return redirect("/login/")

Последний, когда вы даете имя функциям, вы должны использовать подчеркивание, а не верблюд. (например, def add_check_in ()). Это просто правило написания Python для pep8. Я надеюсь, что это поможет вам.

...