我遇到过同样的问题。我希望我的至少一项尝试对您的情况有用:
我第一次尝试解决这个问题(不覆盖ForeignKeyRawIdWidget
)是:
form
在应显示缩略图的内联管理中设置属性
- 使用小部件将另一个字段添加到给定的表单类中,这将显示一个缩略图
但是我放弃了这个解决方案,因为我认为我必须将有关缩略图的数据注入表单构造函数的给定字段中,而且我认为它不是一个好的解决方案。
我的下一个解决方案是MultiWidget
用于某些领域。在这种情况下,我不需要向表单添加另一个字段,并且我将拥有在小部件中显示缩略图所需的数据,而无需在构造函数中注入它们。
class ThumbnailMultiWidget(MultiWidget):
def decompress(self, value):
#has to be overriden
return [None,None]
class ThumbnailWidget(Widget):
def render(self, name, value, attrs=None):
#not quite sure what is in `value`, I've not been so far
return '<img src="%s"/>' % value.url
class PhotoInlineForm(forms.ModelForm):
def __init__(self, *args, **kwargs):
super(PhotoInlineForm, self).__init__(*args, **kwargs)
wdgts = [self.fields['media'].widget, ThumbnailWidget()]
self.fields['media'].widget = ThumbnailMultiWidget(widgets=wdgts)
class Meta:
model = RecipePhoto
但我也放弃了这个解决方案,因为我发现,实际上有一个实例的表示ForeignKeyRawIdWidget
(这是我使用的小部件),其中包含我需要显示缩略图的所有数据。这就是我的最终解决方案:
因此,因为我的内联项raw_id_field
用于选择内联记录,所以我可以简单地覆盖用于表示现有内联记录的方法label_for_value
in 。ForeignKeyRawIdWidget
通常是__unicode__
(我认为)。我继承ForeignKeyRawIdWidget
并覆盖了这个方法来显示图像缩略图:
class PhotoForeignKeyRawIdWidget(ForeignKeyRawIdWidget):
def label_for_value(self, value):
key = self.rel.get_related_field().name
try:
obj = self.rel.to._default_manager.using(self.db).get(**{key: value})
except (ValueError, self.rel.to.DoesNotExist):
return ''
else:
"""
there's utilized sorl.thumbnail, but you can return st like this:
<img src='%s' /> % obj.media.url
"""
return Template("""{% load thumbnail %}
{% thumbnail image.image "120x120" crop="center" as one %}
<img src="{{ one.url }}" />
{% endthumbnail %}""").render(Context({
'image': obj
}))
class AppMediaInlineAdmin(admin.TabularInline):
model = AppMedia
extra = 1
def formfield_for_foreignkey(self, db_field, request=None, **kwargs):
if db_field.name == 'media':
db = kwargs.get('using')
kwargs['widget'] = PhotoForeignKeyRawIdWidget(db_field.rel, self.admin_site, using=db)
return super(AppMediaInlineAdmin, self).formfield_for_foreignkey(db_field, request, **kwargs)