add season/series/promotions filters to search endpoints

This commit is contained in:
Justin Edmund 2025-12-02 05:54:52 -08:00
parent c1a5d62a12
commit 9c5c859da6

View file

@ -68,7 +68,8 @@ module Api
conditions[:proficiency2] =
filters['proficiency2']
end
# conditions[:series] = filters['series'] unless filters['series'].blank? || filters['series'].empty?
conditions[:season] = filters['season'] unless filters['season'].blank? || filters['season'].empty?
conditions[:gacha_available] = filters['gacha_available'] unless filters['gacha_available'].nil?
end
characters = if search_params[:query].present? && search_params[:query].length >= 2
@ -81,6 +82,12 @@ module Api
Character.where(conditions).order(Arel.sql('greatest(release_date, flb_date, ulb_date) desc'))
end
# Filter by series (array overlap)
if filters && filters['series'].present? && !filters['series'].empty?
series_values = Array(filters['series']).map(&:to_i)
characters = characters.where('series && ARRAY[?]::integer[]', series_values)
end
count = characters.length
paginated = characters.paginate(page: search_params[:page], per_page: search_page_size)
@ -116,6 +123,12 @@ module Api
Weapon.where(conditions).order(Arel.sql('greatest(release_date, flb_date, ulb_date, transcendence_date) desc'))
end
# Filter by promotions (array overlap)
if filters && filters['promotions'].present? && !filters['promotions'].empty?
promotions_values = Array(filters['promotions']).map(&:to_i)
weapons = weapons.where('promotions && ARRAY[?]::integer[]', promotions_values)
end
count = weapons.length
paginated = weapons.paginate(page: search_params[:page], per_page: search_page_size)
@ -146,6 +159,12 @@ module Api
Summon.where(conditions).order(release_date: :desc).order(Arel.sql('greatest(release_date, flb_date, ulb_date, transcendence_date) desc'))
end
# Filter by promotions (array overlap)
if filters && filters['promotions'].present? && !filters['promotions'].empty?
promotions_values = Array(filters['promotions']).map(&:to_i)
summons = summons.where('promotions && ARRAY[?]::integer[]', promotions_values)
end
count = summons.length
paginated = summons.paginate(page: search_params[:page], per_page: search_page_size)