Django: override RelatedFieldWidgetWrapper

后端 未结 2 803
不思量自难忘°
不思量自难忘° 2021-01-18 10:14

I want to change the way that the \"+\" icon for the foreign key in the admin site is shown.

I found that the widget that prints the code is RelatedFieldWidget

相关标签:
2条回答
  • 2021-01-18 10:39

    I approached this slightly differently by monkey-patching the widget - that way the change is reflected in all forms and you're not monkeying around with django's source code.

    I ran into this as I was working on customizing yawd admin, a very nice Twitter-Bootstrap skin for admin interface. Now all my icons are jazzed up.

    import django.contrib.admin.widgets
    
    class MyRelatedFieldWidgetWrapper(django.contrib.admin.widgets.RelatedFieldWidgetWrapper):
        """
        This class is a wrapper to a given widget to add the add icon for the
        admin interface.
        """
        def render(self, name, value, *args, **kwargs):
            rel_to = self.rel.to
            info = (rel_to._meta.app_label, rel_to._meta.model_name)
            self.widget.choices = self.choices
            output = [self.widget.render(name, value, *args, **kwargs)]
            if self.can_add_related:
                related_url = reverse(
                    'admin:%s_%s_add' 
                    % info, current_app=self.admin_site.name
                )
                output.append(
                """
                <a  href="%s"
                    onclick="return showAddAnotherPopup(this);
                    alt="%s">
    
                    <i class="help icon-large icon-plus-sign"
                        id="add_id_%s"
                        data-original-title>
                    </i>
                </a>""" % (related_url, _('Add Another'), name))
                return mark_safe(''.join(output))
    
    # Monkeypatch it
    django.contrib.admin.widgets.RelatedFieldWidgetWrapper = MyRelatedFieldWidgetWrapper
    
    0 讨论(0)
  • 2021-01-18 11:00

    You would need to create custom ModelForm for ModelAdmin and override widget there.

    Example code:

    #forms.py
    class CustomForm(forms.ModelForm):
        user = forms.ModelChoiceField(queryset=User.objects.all(), widget=yourCustomWidget)
    
    class Meta:
        model = MyModel
    
    #admin.py
    class MyModelAdmin(admin.ModelAdmin):
         form = CustomForm
    
    0 讨论(0)
提交回复
热议问题