Sha256: 92a0cf13b819848f46ff5377aea689a4d32a3a74c01724bee99e0b5b32176e78
Contents?: true
Size: 1.65 KB
Versions: 16
Compression:
Stored size: 1.65 KB
Contents
# frozen_string_literal: true module Decidim module Meetings # This class handles search and filtering of meetings. Needs a # `current_feature` param with a `Decidim::Feature` in order to # find the meetings. class MeetingSearch < ResourceSearch # Public: Initializes the service. # feature - A Decidim::Feature to get the meetings from. # page - The page number to paginate the results. # per_page - The number of proposals to return per page. def initialize(options = {}) super(Meeting.all, options) end # Handle the search_text filter def search_search_text query .where(localized_search_text_in(:title), text: "%#{search_text}%") .or(query.where(localized_search_text_in(:description), text: "%#{search_text}%")) end # Handle the date filter def search_date if options[:date] == "upcoming" query.where("start_time >= ? ", Time.current).order("start_time ASC") elsif options[:date] == "past" query.where("start_time <= ? ", Time.current).order("start_time DESC") end end private # Internal: builds the needed query to search for a text in the organization's # available locales. Note that it is intended to be used as follows: # # Example: # Resource.where(localized_search_text_for(:title, text: "my_query")) # # The Hash with the `:text` key is required or it won't work. def localized_search_text_in(field) options[:organization].available_locales.map { |l| "#{field} ->> '#{l}' ILIKE :text" }.join(" OR ") end end end end
Version data entries
16 entries across 16 versions & 2 rubygems