From 235857c4666329889e266fafe04f466be408481e Mon Sep 17 00:00:00 2001 From: Mathias Polligkeit Date: Sat, 18 Nov 2023 12:17:00 +0900 Subject: [PATCH] allow using descending order as initial order --- lib/flop.ex | 26 ++++++++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/lib/flop.ex b/lib/flop.ex index 63240cc..7d74d7a 100644 --- a/lib/flop.ex +++ b/lib/flop.ex @@ -1986,6 +1986,20 @@ defmodule Flop do iex> flop.order_directions [:desc_nulls_last] + This also allows you to sort in descending order initially. + + iex> directions = {:desc, :asc} + iex> flop = push_order(%Flop{}, :ttfb, directions: directions) + iex> flop.order_by + [:ttfb] + iex> flop.order_directions + [:desc] + iex> flop = push_order(flop, :ttfb, directions: directions) + iex> flop.order_by + [:ttfb] + iex> flop.order_directions + [:asc] + If a string is passed as the second argument, it will be converted to an atom using `String.to_existing_atom/1`. If the atom does not exist, the `Flop` struct will be returned unchanged. @@ -2061,11 +2075,19 @@ defmodule Flop do do: reverse_direction(current_direction) defp new_order_direction(0, current_direction, {_asc, desc}) - when is_asc_direction(current_direction) and is_direction(desc), + when is_asc_direction(current_direction) and is_desc_direction(desc), + do: desc + + defp new_order_direction(0, current_direction, {desc, _asc}) + when is_asc_direction(current_direction) and is_desc_direction(desc), do: desc defp new_order_direction(0, current_direction, {asc, _desc}) - when is_desc_direction(current_direction) and is_direction(asc), + when is_desc_direction(current_direction) and is_asc_direction(asc), + do: asc + + defp new_order_direction(0, current_direction, {_desc, asc}) + when is_desc_direction(current_direction) and is_asc_direction(asc), do: asc defp new_order_direction(0, _current_direction, directions) do