|
- 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
- issues = issues.includes(pull_request: :reviewers)
- if status_type.to_s == "2" #表示关闭中的
- if(select_type == "Issue")
- issues = issues.where(status_id: 5)
- else
- issues = issues.joins(:pull_request).where(pull_requests: {status: 2})
- end
- 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
|