|
- 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.where(id: ids).by_name_or_identifier(params[:search])
- else
- items.by_name_or_identifier(params[:search])
- end
- 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
|