Django Admin Search field reverse lookup
У меня есть следующие модели:
class Policy(models.Model):
name = models.CharField(max_length=40)
def __str__(self) -> str:
return self.name
class Meta:
verbose_name_plural = 'Policies'
class Statement(models.Model):
name = models.CharField(max_length=40)
policy = models.ForeignKey(
to=Policy,
on_delete=models.CASCADE,
related_name='statements'
)
action = models.CharField(max_length=64)
resource = models.CharField(max_length=128)
и следующая простая модель администратора:
class PolicyAdmin(admin.ModelAdmin):
inlines = [StatementInline]
search_fields = [name,]
class Meta:
model = Policy
Я хочу добиться того, чтобы включить функцию поиска в списке изменений политики, с помощью которой я смогу искать политику по полю имени модели заявления в дополнение к имени политики.
@admin.register(Policy)
class ExapmleAdmin(admin.ModelAdmin):
search_fields = ("statements__name",)
class Meta:
model = Policy
admin.site.register(Statement)
В вашем файле admin.py. Вы можете искать политику с помощью поля name модели Statement следующим образом.