Erster View und erstes Template angelegt, URL /speisekarte registriert. #1
BIN
db.sqlite3
BIN
db.sqlite3
Binary file not shown.
@@ -13,7 +13,7 @@
|
|||||||
<div class="row justify-content-center">
|
<div class="row justify-content-center">
|
||||||
<div class="col-md-8">
|
<div class="col-md-8">
|
||||||
<div class="card shadow">
|
<div class="card shadow">
|
||||||
<div class'card-header bg-primary text-white text-center py-3'>
|
<div class='card-header bg-primary text-white text-center py-3'>
|
||||||
<h1><i class="bi bi-egg-fried"></i> Unsere Speisekarte</h1>
|
<h1><i class="bi bi-egg-fried"></i> Unsere Speisekarte</h1>
|
||||||
</div>
|
</div>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
|
|||||||
@@ -1,6 +1,8 @@
|
|||||||
from django.urls import path
|
from django.urls import path
|
||||||
from .views import GerichtListView
|
from .views import GerichtListView
|
||||||
|
from .views import SpeiseplanView # Achte auf den neuen Klassennamen!
|
||||||
|
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
path('speisekarte/', GerichtListView.as_view(), name='gericht_list'),
|
path('speisekarte/', GerichtListView.as_view(), name='gericht_list'),
|
||||||
|
path('speiseplan/', SpeiseplanView.as_view(), name='speiseplan'),
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -9,3 +9,42 @@ class GerichtListView(ListView):
|
|||||||
template_name = 'mensa_app/gericht_liste.html' # Der Pfad zum Template
|
template_name = 'mensa_app/gericht_liste.html' # Der Pfad zum Template
|
||||||
context_object_name = 'alle_gerichte' # Der Name, den wir im Template nutzen
|
context_object_name = 'alle_gerichte' # Der Name, den wir im Template nutzen
|
||||||
|
|
||||||
|
from django.views.generic import TemplateView
|
||||||
|
from django.utils import timezone
|
||||||
|
from datetime import datetime
|
||||||
|
from .models import Menue, Gericht, SpeiseplanTag
|
||||||
|
|
||||||
|
class SpeiseplanView(TemplateView):
|
||||||
|
template_name = 'mensa_app/speiseplan.html'
|
||||||
|
|
||||||
|
def get_context_data(self, **kwargs):
|
||||||
|
context = super().get_context_data(**kwargs)
|
||||||
|
|
||||||
|
# 1. Datum aus der URL holen (z.B. ?datum=2023-10-27)
|
||||||
|
# Wenn kein Datum angegeben ist, nehmen wir heute.
|
||||||
|
date_str = self.request.GET.get('datum')
|
||||||
|
if date_str:
|
||||||
|
try:
|
||||||
|
target_date = datetime.strptime(date_str, '%Y-%m-%d').date()
|
||||||
|
except ValueError:
|
||||||
|
target_date = timezone.glob.now().date()
|
||||||
|
else:
|
||||||
|
target_date = timezone.now().date()
|
||||||
|
|
||||||
|
# 2. Menüs für diesen spezifischen Tag laden
|
||||||
|
# Wir suchen alle Menüs, deren Tag das target_date hat
|
||||||
|
context['target_date'] = target_date
|
||||||
|
context['menues_day'] = Menue.objects.filter(tag__datum=target_date)
|
||||||
|
|
||||||
|
# 3. Dauerangebote laden (unabhängig vom Tag)
|
||||||
|
context['dauerangebote'] = Gericht.objects.filter(ist_dauerangebot=True)
|
||||||
|
|
||||||
|
# 4. Pager-Logik: Vorherigen und nächsten Tag finden
|
||||||
|
# Wir suchen in der Tabelle SpeiseplanTag nach dem Tag davor/danach
|
||||||
|
prev_tag = SpeiseplanTag.objects.filter(datum__lt=target_date).order_by('-datum').first()
|
||||||
|
next_tag = SpeiseplanTag.objects.filter(datum__gt=target_date).order_by('datum').first()
|
||||||
|
|
||||||
|
context['prev_date'] = prev_tag.datum.strftime('%Y-%m-%d') if prev_tag else None
|
||||||
|
context['next_date'] = next_tag.datum.strftime('%Y-%m-%d') if next_tag else None
|
||||||
|
|
||||||
|
return context
|
||||||
|
|||||||
Reference in New Issue
Block a user