Browse Source

Solution of 07

Praktikum_07_Lsg
Sally Zeitler 3 years ago
parent
commit
5d99369516
5 changed files with 38 additions and 6 deletions
  1. 3
    2
      MEIM_Lsg/urls.py
  2. 4
    1
      posts/views.py
  3. 13
    1
      templates/base.html
  4. 6
    2
      templates/index.html
  5. 12
    0
      templates/registration/login.html

+ 3
- 2
MEIM_Lsg/urls.py View File

@@ -19,6 +19,7 @@ from . import views

urlpatterns = [
path('admin/', admin.site.urls),
path('', views.index, name='posts'),
path('posts/', include('posts.urls'), name='posts')
path('', views.index),
path('posts/', include('posts.urls')),
path('accounts/', include('django.contrib.auth.urls'))
]

+ 4
- 1
posts/views.py View File

@@ -3,7 +3,8 @@ from datetime import timedelta
from django.utils import timezone
from posts.models import Notice
from posts.forms import NoticeForm
from django.http import HttpResponse
from django.contrib.auth.decorators import login_required
from django.contrib.admin.views.decorators import staff_member_required
# Create your views here.


@@ -21,6 +22,7 @@ def home(request, value=""):
}
return render(request, 'index.html', context)

@login_required
def new(request):
if request.method == "POST":
form = NoticeForm(request.POST)
@@ -34,6 +36,7 @@ def new(request):
context = {'form': NoticeForm()}
return render(request, 'edit.html', context)

@staff_member_required
def delete(request, value):
notice = Notice.objects.get(id = value)
notice.delete()

+ 13
- 1
templates/base.html View File

@@ -17,7 +17,7 @@
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarNav">
<ul class="navbar-nav">
<ul class="navbar-nav mr-auto mt-2 mt-lg-0">
<li class="nav-item active">
<a class="nav-link" href="/posts">Posts</a>
</li>
@@ -28,6 +28,18 @@
<a class="nav-link" href="https://www.google.com/">Google</a>
</li>
</ul>
<ul class="navbar-nav">
{% if request.user.is_authenticated %}
<span class="navbar-text"> Willkommen {{ request.user.username }}! </span>
<li class="nav-item">
<a class="nav-link" href="{% url 'logout' %}?next=/posts">Abmelden</a>
</li>
{% else %}
<li class="nav-item">
<a class="nav-link" href="{% url 'login' %}?next=/posts">Anmelden</a>
</li>
{% endif %}
</ul>
</div>
</nav>
{% block content %} {% endblock %}

+ 6
- 2
templates/index.html View File

@@ -7,8 +7,12 @@
<div class="jumbotron">
<h1 class="display-6">{{ notice.notice_title }}</h1>
<p class="lead">{{notice.notice_text}}</p>
<p><a href="{% url 'delete' notice.id %}" class="btn btn-info" role="button">Nachricht löschen</a></p>
{% if user.is_staff %}
<p><a href="{% url 'delete' notice.id %}" class="btn btn-info" role="button">Nachricht löschen</a></p>
{% endif %}
</div>
{% endfor %}
<p><a href="{% url 'new' %}" class="btn btn-info" role="button">Neue Nachricht</a></p>
{% if user.is_authenticated %}
<p><a href="{% url 'new' %}" class="btn btn-info" role="button">Neue Nachricht</a></p>
{% endif %}
{% endblock content %}

+ 12
- 0
templates/registration/login.html View File

@@ -0,0 +1,12 @@
{% extends 'base.html' %}
{% block title %} Login {% endblock %}
{% block content %}
<div class="container"><form method="post" action="{% url 'login' %}">
{% csrf_token %}
Benutzername: {{ form.username }}
<br>Passwort: {{ form.password }} <br>
<button type="submit" class="btn btn-default">Anmelden</button>
<input type="hidden" name="next" value="{{ next }}" />
</form>
</div>
{% endblock %}

Loading…
Cancel
Save