diff --git a/db.sqlite3 b/db.sqlite3 index f70068f..e42d6e9 100644 Binary files a/db.sqlite3 and b/db.sqlite3 differ diff --git a/mensa_app/templates/mensa_app/gericht_list.html b/mensa_app/templates/mensa_app/gericht_list.html index 4b4f375..788bf21 100644 --- a/mensa_app/templates/mensa_app/gericht_list.html +++ b/mensa_app/templates/mensa_app/gericht_list.html @@ -13,7 +13,7 @@
-
+

Unsere Speisekarte

diff --git a/mensa_app/urls.py b/mensa_app/urls.py index a191ae4..60835bc 100644 --- a/mensa_app/urls.py +++ b/mensa_app/urls.py @@ -1,6 +1,8 @@ from django.urls import path from .views import GerichtListView +from .views import SpeiseplanView # Achte auf den neuen Klassennamen! urlpatterns = [ path('speisekarte/', GerichtListView.as_view(), name='gericht_list'), + path('speiseplan/', SpeiseplanView.as_view(), name='speiseplan'), ] diff --git a/mensa_app/views.py b/mensa_app/views.py index b8aafaa..5cb7a01 100644 --- a/mensa_app/views.py +++ b/mensa_app/views.py @@ -9,3 +9,42 @@ class GerichtListView(ListView): template_name = 'mensa_app/gericht_liste.html' # Der Pfad zum Template 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