1

私は数日間インターネットを探し回っていましたが、何も見つかりませんでした. ボタンが URL フィールドの後にインラインで表示されるように、django 管理者をカスタマイズしようとしています。ボタンが表示され、javascript が機能しますが、それをマークしているにもかかわらずnull=Trueblank=True管理者の検証でフィールドが必須であると言い続けられます。URLフィールドをオプションにしたい。

このフィールドをオプションにする方法はありますか? blank=Trueとの組み合わせnull=Trueだと思いますが、いくつかの場所で試してみましたが、うまくいきませんでした。

関連するコード ビットと思われるものを以下に示します (また、ウィジェットからのインライン CSS が悪い考えであることもわかっています。それは、すべてが機能するようになるまでのことです!)。他に何か見る必要がある場合は、お知らせください。

models.py

class Team(models.Model):
    name = models.CharField(max_length=64)
    name_color = models.CharField(max_length=7, default='#000000')
    name_shadow_color = models.CharField(max_length=7, default='#ffffff')
    created = models.DateField(editable=True, default=datetime.now)
    retired = models.DateField(null=True, blank=True)
    url = models.URLField(null=True, blank=True, default=None)

admin.py

class TeamAdmin(admin.ModelAdmin):
    list_filter = ('created', 'retired',)
    list_select_related = True
    list_display = ('name', 'created',)
    search_fields = ('name', )
    ordering = ('name',)
    form = TeamAdminForm

admin_forms.py

class TeamAdminForm(forms.ModelForm):
    url = URLActionField()

    class Media:
        js = ('js/jquery-1.8.0.min.js', 'js/admin/teamform.js', )

    class Meta:
        model = Team

admin_widgets.py

class URLActionField(forms.TextInput):
    def render(self, name, value, attrs=None):
        if attrs is None:
            attrs = {}

        # TODO: not responsive!!
        if 'style' not in attrs.keys():
            attrs['style'] = 'width: 275px;'
        else:
            attrs['style'] = '%s width: 275px;' % attrs['style']

        attrs['required'] = False
        attrs['blank'] = True
        attrs['null'] = True

        output = []
        output.append(super(URLActionField, self).render(name, value, attrs))
        output.append(' <input type="button" value="%s" style="width: 200px; margin-left: 20px; height: 24px; line-height: 15px;" class="grp-button" id="url-scraper">' % unicode(_(u'Scrape URL for data')))
        return mark_safe(u''.join(output))

前もって感謝します。

4

1 に答える 1

1

カスタム ウィジェットを作成し、組み込みの URL フィールドで使用する必要があります。モデルフィールドではなく、フォームフィールドを扱っています。したがって、「required=False」を使用してください。よほどの理由がない限り、文字列ベースのフィールドで null を使用しないでください。文字列ベースのフィールドに null=True がある場合、それは「データなし」の 2 つの可能な値 (NULL と空の文字列) があることを意味します。

Model.py で:

class Team(models.Model):
    ...
    url = models.URLField(blank=True)

Admin.py で、組み込みの AdminURLFieldWidget 出力に追加します (js は必要ありません)。

from django.contrib.admin.widgets import AdminURLFieldWidget

class CustomAdminURLFieldWidget(AdminURLFieldWidget):
    def render(self, name, value, attrs=None):
        output = []
        output.append(super(CustomAdminURLFieldWidget, 
            self).render(name, value, attrs))
        if value:
            output.append('<p><a href="%s">%s</a></p>' %(value, value))
        return mark_safe(u''.join(output))

Admin.py でフォームを作成します。

from models import Team

class TeamAdminForm(forms.ModelForm):
        url = forms.URLField(required=False, widget=CustomAdminURLFieldWidget)
        class Meta:
            model = Team

Admin.py で ModelAdmin を作成します。

class TeamAdmin(admin.ModelAdmin):
    form = TeamAdminForm
于 2013-04-25T01:53:44.460 に答える