Обработка изящной деградации в форме Джанго

У меня есть форма, которая выглядит примерно так (упрощенно для краткости):

PRICING_PATTERN = r'(?:^\$?(?P<flat_price>\d+|\d?\.\d\d)$)|(?:^(?P<percent_off>\d+)\s*\%\s*off$)'
class ItemForm(forms.Form):
    pricing = forms.RegexField(
        label='Pricing',
        regex=PRICING_PATTERN
    )

    pricing_type = forms.CharField(
        label='Deal type',
        widget=forms.RadioSelect(
            choices=(
                ('flat_price','Flat price'),
                ('percent_off','Percentage off'),
            ),
           attrs={'style': 'display: none;'})
        ),
    )

    pricing_flat_price = forms.DecimalField(
        label='Flat price',
        max_digits=5,
        decimal_places=2,
        widget=forms.TextInput(attrs={'style': 'display: none;'})
    )

    pricing_percent_off = forms.IntegerField(
        label='Percent off',
        required=False,
        min_value=0,
        max_value=100,
        widget=forms.TextInput(attrs={'style': 'display: none;'})
    )

Первоначально, с целью постепенной деградации, видна только цена. Если у пользователя включен JavaScript, я скрываю ценообразование и делаю вид цены_видимым. Теперь, при выборе радиостанции типа priceing_type, я делаю видимым либо priceing_flat_cost, или pricing_percent_off. Это делает для более точного и удобного пользовательского интерфейса.

Мои вопросы: как мне пойти по поводу кодирования логики, которая выясняет, где взять значения - из полей RegexField или pricing_flat_price и pricing_percent_off? Должен ли я, возможно, создать функцию в ItemForm, которая вычисляет это и возвращает правильное значение?

Или, может быть, есть более чистый подход, который кто-то может предложить?

1 ответ

Решение

Определите пользовательский виджет для выбора типа и включите код JavaScript в отдельный файл.js.

Другие вопросы по тегам