merge-upstream-5.0.1 #66

Merged
778a69cd merged 80 commits from merge-upstream-5.0.1 into main 2024-12-26 12:55:41 +01:00
Showing only changes of commit f67bd900f7 - Show all commits

View file

@ -530,7 +530,9 @@ defmodule Mobilizon.Events do
group_id group_id
|> event_for_group_query() |> event_for_group_query()
|> event_filter_visibility(visibility) |> event_filter_visibility(visibility)
|> event_filter_begins_on(after_datetime, before_datetime) # We want future and ongoing events, so we use ends_on
# See issue #1567
|> event_filter_ends_on(after_datetime, before_datetime)
|> event_order_by(order_by, order_direction) |> event_order_by(order_by, order_direction)
|> preload_for_event() |> preload_for_event()
|> Page.build_page(page, limit) |> Page.build_page(page, limit)
@ -2024,6 +2026,26 @@ defmodule Mobilizon.Events do
|> where([e], e.begins_on > ^after_datetime) |> where([e], e.begins_on > ^after_datetime)
end end
defp event_filter_ends_on(query, nil, nil), do: query
defp event_filter_ends_on(query, %DateTime{} = after_datetime, nil) do
where(query, [e], e.ends_on > ^after_datetime)
end
defp event_filter_ends_on(query, nil, %DateTime{} = before_datetime) do
where(query, [e], e.ends_on < ^before_datetime)
end
defp event_filter_ends_on(
query,
%DateTime{} = after_datetime,
%DateTime{} = before_datetime
) do
query
|> where([e], e.ends_on < ^before_datetime)
|> where([e], e.ends_on > ^after_datetime)
end
defp event_order_by(query, order_by, direction) defp event_order_by(query, order_by, direction)
when order_by in [:begins_on, :inserted_at, :updated_at] and direction in [:asc, :desc] do when order_by in [:begins_on, :inserted_at, :updated_at] and direction in [:asc, :desc] do
order_by_instruction = Keyword.new([{direction, order_by}]) order_by_instruction = Keyword.new([{direction, order_by}])