nötige Anpassungen nach Merge

This commit is contained in:
2026-06-12 11:15:53 +02:00
parent 297ee45590
commit 0868caf35f
5 changed files with 94 additions and 76 deletions
+30 -28
View File
@@ -3,33 +3,35 @@ from django.contrib import admin
# Register your models here.
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 JoinModel
verbose_name = 'Kind'
verbose_name_plural = 'Kinder'
extra = 0 # Keine leeren Zeilen anzeigen
# ----------------------------------------------------------
# **WICHTIG:** Hier wird der zu verwendende FK explizit genannt
# ----------------------------------------------------------
fk_name = 'person' # <-- legt fest, welcher FK gemeint ist
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)
# DELTE: Die Option, Kinder zuzuordnen soll zunächst nicht umgesetzt werden.
# 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 JoinModel
# verbose_name = 'Kind'
# verbose_name_plural = 'Kinder'
# extra = 0 # Keine leeren Zeilen anzeigen
#
# # ----------------------------------------------------------
# # **WICHTIG:** Hier wird der zu verwendende FK explizit genannt
# # ----------------------------------------------------------
# fk_name = 'person' # <-- legt fest, welcher FK gemeint ist
#
# 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)
class PersonAdmin(admin.ModelAdmin):
@@ -37,8 +39,8 @@ class PersonAdmin(admin.ModelAdmin):
search_fields = ['user__username', 'klasse']
ordering = ('rolle',)
# ---- Inline für Eltern (Rolle Mitarbeit/Chef) ----
inlines = [PersonInlineChildren] # Zeigt das KinderInline nur bei passenden Rollen an
# # ---- Inline für Eltern (Rolle Mitarbeit/Chef) ----
# inlines = [PersonInlineChildren] # Zeigt das KinderInline nur bei passenden Rollen an
def has_change_permission(self, request, obj=None):
"""