nötige Anpassungen nach Merge
This commit is contained in:
Binary file not shown.
|
Before Width: | Height: | Size: 80 KiB After Width: | Height: | Size: 80 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 61 KiB After Width: | Height: | Size: 61 KiB |
+30
-28
@@ -3,33 +3,35 @@ from django.contrib import admin
|
|||||||
# Register your models here.
|
# Register your models here.
|
||||||
from .models import Person # Ersetze dies durch deine echten Klassennamen
|
from .models import Person # Ersetze dies durch deine echten Klassennamen
|
||||||
|
|
||||||
class PersonInlineChildren(admin.TabularInline):
|
|
||||||
"""
|
|
||||||
Inline für das Feld ``children`` (Schüler eines Elternteils).
|
|
||||||
Nur bei Eltern (Rolle Mitarbeit/Chef) sichtbar.
|
|
||||||
"""
|
|
||||||
model = Person.children.through # Das durchschnittliche Join‑Model
|
|
||||||
verbose_name = 'Kind'
|
|
||||||
verbose_name_plural = 'Kinder'
|
|
||||||
extra = 0 # Keine leeren Zeilen anzeigen
|
|
||||||
|
|
||||||
# ----------------------------------------------------------
|
# DELTE: Die Option, Kinder zuzuordnen soll zunächst nicht umgesetzt werden.
|
||||||
# **WICHTIG:** Hier wird der zu verwendende FK explizit genannt
|
# class PersonInlineChildren(admin.TabularInline):
|
||||||
# ----------------------------------------------------------
|
# """
|
||||||
fk_name = 'person' # <-- legt fest, welcher FK gemeint ist
|
# Inline für das Feld ``children`` (Schüler eines Elternteils).
|
||||||
|
# Nur bei Eltern (Rolle Mitarbeit/Chef) sichtbar.
|
||||||
def has_add_permission(self, request, obj=None):
|
# """
|
||||||
# Erlaube Hinzufügen nur für Eltern (Rolle Eltern)
|
# model = Person.children.through # Das durchschnittliche Join‑Model
|
||||||
return obj and obj.rolle in ('eltern')
|
# verbose_name = 'Kind'
|
||||||
|
# verbose_name_plural = 'Kinder'
|
||||||
def formfield_for_foreignkey(self, db_field, request, **kwargs):
|
# extra = 0 # Keine leeren Zeilen anzeigen
|
||||||
"""
|
#
|
||||||
Verhindere, dass ein Benutzer sich selbst als Kind hinzufügt.
|
# # ----------------------------------------------------------
|
||||||
"""
|
# # **WICHTIG:** Hier wird der zu verwendende FK explizit genannt
|
||||||
if db_field.name == "person":
|
# # ----------------------------------------------------------
|
||||||
# Hier handelt es sich um den FK auf die Person (das Ziel)
|
# fk_name = 'person' # <-- legt fest, welcher FK gemeint ist
|
||||||
kwargs["queryset"] = Person.objects.exclude(pk=self.instance.pk)
|
#
|
||||||
return super().formfield_for_foreignkey(db_field, request, **kwargs)
|
# def has_add_permission(self, request, obj=None):
|
||||||
|
# # Erlaube Hinzufügen nur für Eltern (Rolle Eltern)
|
||||||
|
# return obj and obj.rolle in ('eltern')
|
||||||
|
#
|
||||||
|
# def formfield_for_foreignkey(self, db_field, request, **kwargs):
|
||||||
|
# """
|
||||||
|
# Verhindere, dass ein Benutzer sich selbst als Kind hinzufügt.
|
||||||
|
# """
|
||||||
|
# if db_field.name == "person":
|
||||||
|
# # Hier handelt es sich um den FK auf die Person (das Ziel)
|
||||||
|
# kwargs["queryset"] = Person.objects.exclude(pk=self.instance.pk)
|
||||||
|
# return super().formfield_for_foreignkey(db_field, request, **kwargs)
|
||||||
|
|
||||||
@admin.register(Person)
|
@admin.register(Person)
|
||||||
class PersonAdmin(admin.ModelAdmin):
|
class PersonAdmin(admin.ModelAdmin):
|
||||||
@@ -37,8 +39,8 @@ class PersonAdmin(admin.ModelAdmin):
|
|||||||
search_fields = ['user__username', 'klasse']
|
search_fields = ['user__username', 'klasse']
|
||||||
ordering = ('rolle',)
|
ordering = ('rolle',)
|
||||||
|
|
||||||
# ---- Inline für Eltern (Rolle Mitarbeit/Chef) ----
|
# # ---- Inline für Eltern (Rolle Mitarbeit/Chef) ----
|
||||||
inlines = [PersonInlineChildren] # Zeigt das Kinder‑Inline nur bei passenden Rollen an
|
# inlines = [PersonInlineChildren] # Zeigt das Kinder‑Inline nur bei passenden Rollen an
|
||||||
|
|
||||||
def has_change_permission(self, request, obj=None):
|
def has_change_permission(self, request, obj=None):
|
||||||
"""
|
"""
|
||||||
|
|||||||
@@ -0,0 +1,14 @@
|
|||||||
|
# Generated by Django 5.2.14 on 2026-06-12 09:13
|
||||||
|
|
||||||
|
from django.db import migrations
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('mensa_app', '0005_alter_bestellung_id_alter_gericht_id_and_more'),
|
||||||
|
('mensa_app', '0009_alter_gericht_time_creation_and_more'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
]
|
||||||
+50
-48
@@ -19,55 +19,57 @@ class Person(models.Model):
|
|||||||
rolle = models.CharField(max_length=20, choices=[('schueler', 'Schüler'), ('eltern', 'Eltern'), ('lehrer', 'Lehrer'), ('mitarbeiter','Mensa-Mitarbeiter'), ('chef','Mensa-Leitung')])
|
rolle = models.CharField(max_length=20, choices=[('schueler', 'Schüler'), ('eltern', 'Eltern'), ('lehrer', 'Lehrer'), ('mitarbeiter','Mensa-Mitarbeiter'), ('chef','Mensa-Leitung')])
|
||||||
klasse = models.CharField(max_length=4, blank=True, null=True) # Nur für Schüler relevant
|
klasse = models.CharField(max_length=4, blank=True, null=True) # Nur für Schüler relevant
|
||||||
|
|
||||||
# ----------------------------------------------------------------------
|
|
||||||
# Neue Many‑to‑Many Beziehung: „Elternteil ↔ Schüler“
|
|
||||||
# ----------------------------------------------------------------------
|
|
||||||
children = models.ManyToManyField(
|
|
||||||
'self',
|
|
||||||
blank=True,
|
|
||||||
related_name='parents', # → für einen Schüler: person.parents.all()
|
|
||||||
symmetrical=False, # Verhindert eine zirkuläre Rück‑Beziehung (nicht benötigt)
|
|
||||||
help_text=(
|
|
||||||
"Eltern können hier die ihnen zugewiesenen Schüler hinzufügen. Für Schüler bleibt dieses Feld leer."
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
# ------------------------------------------------------------------
|
# DELETE: Die Eltern-Kinder Beziehung soll zunächst nicht umgesetzt werden.
|
||||||
# Optional: Hilfsmethode, die alle Kinder zurückgibt, ggf. mit einer Sortierung
|
# # ----------------------------------------------------------------------
|
||||||
def get_children_sorted(self):
|
# # Neue Many‑to‑Many Beziehung: „Elternteil ↔ Schüler“
|
||||||
# Das `order_by('name')` ist ein Beispiel – du kannst deine eigene Sortierung verwenden.
|
# # ----------------------------------------------------------------------
|
||||||
return self.children.order_by('name')
|
# children = models.ManyToManyField(
|
||||||
|
# 'self',
|
||||||
class Meta:
|
# blank=True,
|
||||||
verbose_name_plural = "Personen"
|
# related_name='parents', # → für einen Schüler: person.parents.all()
|
||||||
|
# symmetrical=False, # Verhindert eine zirkuläre Rück‑Beziehung (nicht benötigt)
|
||||||
def __str__(self):
|
# help_text=(
|
||||||
if self.children.exists():
|
# "Eltern können hier die ihnen zugewiesenen Schüler hinzufügen. Für Schüler bleibt dieses Feld leer."
|
||||||
# Wir sammeln alle Kinder‑Namen in einem String, z. B. mit Komma getrennt.
|
# )
|
||||||
children_names = ', '.join([c.name for c in self.children.all()])
|
# )
|
||||||
return f"{self.user.username} ({children_names}) ({self.rolle})"
|
#
|
||||||
else:
|
# # ------------------------------------------------------------------
|
||||||
return f"{self.user.username} ({self.rolle})"
|
# # Optional: Hilfsmethode, die alle Kinder zurückgibt, ggf. mit einer Sortierung
|
||||||
|
# def get_children_sorted(self):
|
||||||
def clean(self):
|
# # Das `order_by('name')` ist ein Beispiel – du kannst deine eigene Sortierung verwenden.
|
||||||
"""
|
# return self.children.order_by('name')
|
||||||
Überprüfung für die ManyToMany-Beziehung ``children``:
|
#
|
||||||
- Nur Personen mit der Rolle 'mitarbeiter' oder 'chef' (Eltern) dürfen Kinder haben.
|
# class Meta:
|
||||||
- Ein Schüler darf sich selbst nicht als Kind hinzufügen.
|
# verbose_name_plural = "Personen"
|
||||||
"""
|
#
|
||||||
super().clean() # ruft die Validierungen der Elternklasse auf (hier User/Model)
|
# def __str__(self):
|
||||||
|
# if self.children.exists():
|
||||||
if self.rolle in ('mitarbeiter', 'chef', 'lehrer'):
|
# # Wir sammeln alle Kinder‑Namen in einem String, z. B. mit Komma getrennt.
|
||||||
# Nicht‑Eltern dürfen keine Kinder besitzen
|
# children_names = ', '.join([c.name for c in self.children.all()])
|
||||||
if self.children.exists():
|
# return f"{self.user.username} ({children_names}) ({self.rolle})"
|
||||||
raise ValidationError(
|
# else:
|
||||||
"Nur Benutzer mit der Rolle 'Eltern' "
|
# return f"{self.user.username} ({self.rolle})"
|
||||||
"dürfen Schüler zuordnen (children)."
|
#
|
||||||
)
|
# def clean(self):
|
||||||
else:
|
# """
|
||||||
# Eltern: Verhindere, dass sie sich selbst als Kind eintragen
|
# Überprüfung für die ManyToMany-Beziehung ``children``:
|
||||||
if self in self.children.all():
|
# - Nur Personen mit der Rolle 'mitarbeiter' oder 'chef' (Eltern) dürfen Kinder haben.
|
||||||
raise ValidationError("Ein Benutzer darf nicht gleichzeitig Elternteil und eigener Kind sein.")
|
# - Ein Schüler darf sich selbst nicht als Kind hinzufügen.
|
||||||
|
# """
|
||||||
|
# super().clean() # ruft die Validierungen der Elternklasse auf (hier User/Model)
|
||||||
|
#
|
||||||
|
# if self.rolle in ('mitarbeiter', 'chef', 'lehrer'):
|
||||||
|
# # Nicht‑Eltern dürfen keine Kinder besitzen
|
||||||
|
# if self.children.exists():
|
||||||
|
# raise ValidationError(
|
||||||
|
# "Nur Benutzer mit der Rolle 'Eltern' "
|
||||||
|
# "dürfen Schüler zuordnen (children)."
|
||||||
|
# )
|
||||||
|
# else:
|
||||||
|
# # Eltern: Verhindere, dass sie sich selbst als Kind eintragen
|
||||||
|
# if self in self.children.all():
|
||||||
|
# raise ValidationError("Ein Benutzer darf nicht gleichzeitig Elternteil und eigener Kind sein.")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user