[英]Django Admin custom list filter different model
我正在使用 Django 2.1,我需要在模型(#1)管理页面上添加一个列表过滤器,引用来自不同模型(#2)的字段(它有一个引用当前模型的外键(#1)这些是我的2个型号:
class ParentProduct(models.Model):
parent_id = models.CharField(max_length=255, validators=[ParentIDValidator])
name = models.CharField(max_length=255, validators=[ProductNameValidator])
parent_slug = models.SlugField(max_length=255)
parent_brand = models.ForeignKey(Brand, related_name='parent_brand_product', blank=False, on_delete=models.CASCADE)
...
class ParentProductCategory(models.Model):
parent_product = models.ForeignKey(ParentProduct, related_name='parent_product_pro_category', on_delete=models.CASCADE)
category = models.ForeignKey(Category, related_name='parent_category_pro_category', on_delete=models.CASCADE)
created_at = models.DateTimeField(auto_now_add=True)
modified_at = models.DateTimeField(auto_now=True)
这是我的模型“ParentProduct”的管理类:
class ParentProductAdmin(admin.ModelAdmin):
resource_class = ParentProductResource
form = ParentProductForm
class Media:
pass
change_list_template = 'admin/products/parent_product_change_list.html'
actions = [deactivate_selected_products, approve_selected_products]
list_display = [
'parent_id', 'name', 'parent_brand', 'product_hsn', 'gst', 'product_image', 'status'
]
inlines = [
ParentProductCategoryAdmin
]
list_filter = [ParentBrandFilter, 'status']
这是 ParentBrandFilter:
class ParentBrandFilter(AutocompleteFilter):
title = 'Brand'
field_name = 'parent_brand'
这工作正常,因为字段“parent_brand”存在于我的模型“ParentProduct”上。 如何为实际上位于“ParentProductCategory”模型中的字段类别获取相同的自动完成类型列表过滤器。
注意:'ParentProductCategory' -> 'ParentProduct' 是一个多对一的映射。
注意#2: Django 管理员添加自定义过滤器。 我尝试过这个问题,但无法通过该方法,而且我的要求也不同。 我需要一个自动完成类型过滤器。
注意 #3:如果自动完成是不可能的,有没有办法让下拉列表中只包含现有的“类别”值?
在你的 ParentProductAdmin 类中试试这个
list_filter = ['parent_product__parent_brand', 'status']
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.