Гибкий фильтр Django (пакет django-filter)

В настоящее время я реализую некоторые фильтры и сталкиваюсь с несколькими проблемами. Во-первых, мои флажки не работают, т.е. я не могу их выбрать: current look of filter

вот мой .html код:

<form method="get">
    <div class="toggle-list product-categories">
        <h6 class="title">Sorteer</h6>
        <div class="shop-submenu">
            <ul>
                {{ filter.form.order_by }}
            </ul>
        </div>
    </div>
    <div class="toggle-list product-categories">
        <h6 class="title">Merk(en)</h6>
        <div class="shop-submenu">
            <ul>
                {% for f in filter.form.brand %}
                    <li>
                        <input type="checkbox">
                        <label>{{ f }}</label>
                    </li>
                {% endfor %}
            </ul>
        </div>
    </div>
    <input type="submit" value="Filter">
</form>

мой фильтр в filters.py:

class SortFilter(django_filters.FilterSet):
    ORDER_BY_CHOICES = (
        ('-discount_sort', 'Hoogste korting'),
        ('-new_price', 'Hoogste prijs'),
        ('new_price', 'Laagste prijs'),
    )
    order_by = django_filters.ChoiceFilter(label='Sorteer op', choices=ORDER_BY_CHOICES, method='filter_by_order',
                                           empty_label=None)
    brand = django_filters.ModelMultipleChoiceFilter(queryset=Product.objects
                                                     .order_by('brand')
                                                     .filter(categorie='eiwitten')
                                                     .values_list('brand', flat=True).distinct()
                                                     , widget=forms.CheckboxSelectMultiple, required=False)

    class Meta:
        model = Product
        fields = ['brand']

    def filter_by_order(self, queryset, name, value):
        return queryset.order_by(value)

функция просмотра для этой определенной страницы:

def eiwit(request):
    # filter alleen eiwitproducten
    eiwit_list = ['eiwitten']
    eiwit_filter = Q()
    for item in eiwit_list:
        eiwit_filter = eiwit_filter | Q(categorie=item)

    products = models.Product.objects.filter(eiwit_filter)
    product_amount = len(products)

    # sorteer filter
    filtered = SortFilter(
        request.GET,
        queryset=products
    )

    # paginator
    paginator = Paginator(filtered.qs, 12)
    page = request.GET.get('page')
    try:
        response = paginator.page(page)
    except PageNotAnInteger:
        response = paginator.page(1)
    except EmptyPage:
        response = paginator.page(paginator.num_pages)
    product_front_end = {
        'final_products': response,
        'filter': filtered,
        'count': product_amount,
    }
    return render(request, 'producten/eiwit.html', product_front_end)

Во-вторых, я бы хотел, чтобы фильтр был более общим. Например, все категории имеют разное количество брендов. Как вы видите, сейчас я создаю варианты, выбирая все значения 'brand' в категории 'eiwitten' (в filters.py). Есть ли способ вызвать фильтр в views.py с переменной (например, 'eiwittien'). Которая затем будет использоваться для настройки фильтра в filter.py в зависимости от страницы, на которой он находится? Таким образом, у меня будет динамический фильтр для всех категорий.

Возможно, это поможет решить некоторые из ваших проблем. В вашем теге input отсутствует информация о полях name/id. Вы можете заполнить их, добавив теги шаблона для заполнения значений.

<input type="checkbox" id="BSN" name="BSN"> <label for="BSN">BSN</label>
Вернуться на верх