Beliaf
Beliaf

Reputation: 615

Ordering Filter using 2 ordering values(django_filters)

Hello every one is there a way to use OrderingFilter like in django order_by with 2 ordering values queryset.ordery_by('value1', value_2')

I have tried

order_by = django_filters.OrderingFilter(
        fields=(
            ('item_name', 'Items),
            ('time_from', 'Time'),
            (('value1', 'value2'), 'Value'),
        )
    )

But received expected string or bytes-like object

Upvotes: 3

Views: 6052

Answers (2)

soldovskij
soldovskij

Reputation: 169

I created OrderingFilterExtened for this purposes https://github.com/soldovskij/OrderingFilterExtened

Example:

class UserFilter(FilterSet):
    order_by = OrderingFilterExtened(
        fields_many=(
            ('full_name', ('first_name', 'last_name'), ('-first_name', '-last_name')),
        ),
        fields=(
            ('email', 'email'),  # model field name, parameter name
            ('last_login', 'last_login'),
            ('date_joined', 'date_joined'),
        ),
    )

class UserListAPIView(UsersPermissionQuerysetMixin, generics.ListAPIView):
    queryset = User.objects.all()
    permission_classes = (permissions.IsAuthenticated,)
    serializer_class = UserListSerializer
    pagination_class = LimitOffsetPagination
    filterset_class = UserFilter

Request example: api/v2/users/order_by=full_name or api/v2/users/order_by=-full_name

Upvotes: 1

Netizen29
Netizen29

Reputation: 226

OrderingFilter supports multiple ordering params if you're willing to include them in the request: my_view?order_by=value1,value2.

If you want the same result with a request that looks like my_view?order_by=values, a way I can think of to achieve that is to override OrderingFilter:

class CustomOrderingFilter(OrderingFilter):
    def filter(self, qs, value):
        if any(v == 'values' for v in value):
            qs.order_by('value1', 'value2')
        return super(CustomOrderingFilter, self).filter(qs, value)

Upvotes: 3

Related Questions