class Projects::ListQuery < ApplicationQuery include CustomSortable attr_reader :params, :current_user_id sort_columns :updated_on, :created_on, :forked_count, :praises_count, default_by: :updated_on, default_direction: :desc def initialize(params, current_user_id=nil) @params = params @current_user_id = current_user_id end def call collection = Project.visible collection = filter_projects(collection) sort = params[:sort_by] || "updated_on" sort_direction = params[:sort_direction] || "desc" collection = optimize_sorting(collection, sort) if params[:category_id].present? custom_sort(collection, sort, sort_direction) # scope = scope.reorder("projects.#{sort} #{sort_direction}") # scope end def filter_projects(collection) # collection = by_pinned(collection) collection = by_search(collection) if params[:search].present? collection = by_project_type(collection) collection = by_project_category(collection) collection = by_project_language(collection) collection end def by_search(items) ids = Projects::ElasticsearchService.call(params[:search]) items = items.where(platform: 'forge') if ids.present? items = items.where(id: ids).by_name_or_identifier(params[:search]) else items = items.by_name_or_identifier(params[:search]) end items.or(Project.visible.where(user_id: Owner.like(params[:search]).pluck(:id))) end def by_project_type(items) items.with_project_type(params[:project_type]) end def by_project_category(items) items.with_project_category(params[:category_id]) end def by_project_language(items) items.with_project_language(params[:language_id]) end def by_pinned(items) (params[:pinned].present? && params[:category_id].present?) ? items.pinned : items end # 优化排序 def optimize_sorting(relations, sort_by) if sort_by == "updated_on" relations.where("projects.updated_on>'2010-01-01'") elsif sort_by == "created_on" relations.where("projects.created_on>'2010-01-01'") elsif sort_by == "forked_count" relations.where("projects.forked_count>=0") elsif sort_by == "praises_count" relations.where("projects.praises_count>=0") else relations end end end