1 # frozen_string_literal: true
 
   3 class IssuesController < ApplicationController
 
   4   include PaginationMethods
 
   8   before_action :authorize_web
 
   9   before_action :set_locale
 
  10   before_action :check_database_readable
 
  14   before_action :find_issue, :only => [:show, :resolve, :reopen, :ignore]
 
  15   before_action :check_database_writable, :only => [:resolve, :ignore, :reopen]
 
  18     @params = params.permit(:before, :after, :limit, :status, :search_by_user, :issue_type, :last_updated_by)
 
  19     @params[:limit] ||= 50
 
  23     @issue_types |= %w[Note User] if current_user.moderator?
 
  24     @issue_types |= %w[DiaryEntry DiaryComment User] if current_user.administrator?
 
  26     @users = User.joins(:roles).where(:user_roles => { :role => current_user.roles.map(&:role) }).distinct
 
  27     @issues = Issue.visible_to(current_user)
 
  30     if params[:search_by_user].present?
 
  31       @find_user = User.find_by(:display_name => params[:search_by_user])
 
  32       @issues = if @find_user
 
  33                   @issues.where(:reported_user => @find_user)
 
  39     @issues = @issues.where(:status => params[:status]) if params[:status].present?
 
  41     @issues = @issues.where(:reportable_type => params[:issue_type]) if params[:issue_type].present?
 
  43     if params[:last_updated_by].present?
 
  44       last_updated_by = params[:last_updated_by].to_s == "nil" ? nil : params[:last_updated_by].to_i
 
  45       @issues = @issues.where(:updated_by => last_updated_by)
 
  48     @issues, @newer_issues_id, @older_issues_id = get_page_items(@issues, :limit => @params[:limit])
 
  50     @unique_reporters_limit = 3
 
  51     @unique_reporters = @issues.each_with_object({}) do |issue, reporters|
 
  52       user_ids = issue.reports.reorder(:created_at => :desc).pluck(:user_id).uniq
 
  53       reporters[issue.id] = {
 
  54         :count => user_ids.size,
 
  55         :users => User.in_order_of(:id, user_ids.first(@unique_reporters_limit))
 
  61     @title = t ".title.#{@issue.status}", :issue_id => @issue.id
 
  62     @read_reports = @issue.read_reports
 
  63     @unread_reports = @issue.unread_reports
 
  64     @comments = @issue.comments
 
  65     @related_issues = @issue.reported_user.issues.where(:assigned_role => current_user.roles.map(&:role)) if @issue.reported_user
 
  66     @new_comment = IssueComment.new(:issue => @issue)
 
  72       @issue.updated_by = current_user.id
 
  74       redirect_to @issue, :notice => t(".resolved")
 
  82       @issue.updated_by = current_user.id
 
  84       redirect_to @issue, :notice => t(".ignored")
 
  92       @issue.updated_by = current_user.id
 
  94       redirect_to @issue, :notice => t(".reopened")
 
 103     @issue = Issue.visible_to(current_user).find(params[:id])
 
 104   rescue ActiveRecord::RecordNotFound
 
 105     redirect_to :controller => "errors", :action => "not_found"