61 lines
2.8 KiB
Ruby
61 lines
2.8 KiB
Ruby
class Issues::ListQueryService < ApplicationService
|
|
|
|
attr_reader :all_issues, :params,:select_type
|
|
|
|
def initialize(all_issues, params, select_type)
|
|
@all_issues = all_issues
|
|
@params = params
|
|
@select_type = select_type
|
|
end
|
|
|
|
def call
|
|
status_type = params[:status_type].to_s #issue状态的选择
|
|
search_name = params[:search].to_s
|
|
start_time = params[:start_date]
|
|
end_time = params[:due_date]
|
|
|
|
issues = all_issues.issue_index_includes
|
|
if status_type.to_s == "2" #表示关闭中的
|
|
issues = issues.where(status_id: 5)
|
|
elsif status_type.to_s == "1"
|
|
if(select_type == "Issue")
|
|
issues = issues.where.not(status_id: 5) #默认显示开启中的
|
|
else
|
|
issues = issues.joins(:pull_request).where(pull_requests: {status: 0}) #默认显示开启中的
|
|
end
|
|
elsif status_type.to_s == "11" #表示pr的已关闭
|
|
issues = issues.joins(:pull_request).where(pull_requests: {status: 1})
|
|
end
|
|
|
|
if search_name.present?
|
|
issues = issues.where("issues.subject LIKE ? OR issues.description LIKE ? ", "%#{search_name}%", "%#{search_name}%")
|
|
end
|
|
|
|
if start_time&.present? || end_time&.present?
|
|
issues = issues.where("issues.start_date between ? and ?",start_time&.present? ? start_time.to_date : Time.now.to_date, end_time&.present? ? end_time.to_date : Time.now.to_date)
|
|
end
|
|
|
|
issues = issues.where(author_id: params[:author_id]) if params[:author_id].present? && params[:author_id].to_s != "all"
|
|
issues = issues.where(assigned_to_id: params[:assigned_to_id]) if params[:assigned_to_id].present? && params[:assigned_to_id].to_s != "all"
|
|
issues = issues.where(tracker_id: params[:tracker_id]) if params[:tracker_id].present? && params[:tracker_id].to_s != "all"
|
|
issues = issues.where(status_id: params[:status_id]) if params[:status_id].present? && params[:status_id].to_s != "all"
|
|
issues = issues.where(priority_id: params[:priority_id]) if params[:priority_id].present? && params[:priority_id].to_s != "all"
|
|
issues = issues.where(fixed_version_id: params[:fixed_version_id]) if params[:fixed_version_id].present? && params[:fixed_version_id].to_s != "all"
|
|
issues = issues.where(done_ratio: params[:done_ratio].to_i) if params[:done_ratio].present? && params[:done_ratio].to_s != "all"
|
|
issues = issues.where(issue_type: params[:issue_type].to_s) if params[:issue_type].present? && params[:issue_type].to_s != "all"
|
|
issues = issues.joins(:issue_tags).where(issue_tags: {id: params[:issue_tag_id].to_i}) if params[:issue_tag_id].present? && params[:issue_tag_id].to_s != "all"
|
|
|
|
issues.reorder("issues.#{order_name} #{order_type}")
|
|
end
|
|
|
|
private
|
|
|
|
def order_name
|
|
Issue.column_names.include?(params[:order_name]) ? params[:order_name] : 'updated_on'
|
|
end
|
|
|
|
def order_type
|
|
%w(desc asc).include?(params[:order_type]) ? params[:order_type] : 'desc'
|
|
end
|
|
|
|
end |