# frozen_string_literal: true class DashboardController < Dashboard::ApplicationController include IssuableCollectionsAction include FiltersEvents prepend_before_action(only: [:issues]) { authenticate_sessionless_user!(:rss) } prepend_before_action(only: [:issues_calendar]) { authenticate_sessionless_user!(:ics) } before_action :event_filter, only: :activity before_action :projects, only: [:issues, :merge_requests] before_action :set_show_full_reference, only: [:issues, :merge_requests] before_action :check_filters_presence!, only: [:issues, :merge_requests] before_action only: :merge_requests do push_frontend_feature_flag(:mr_approved_filter, type: :ops) end respond_to :html feature_category :user_profile, [:activity] feature_category :team_planning, [:issues, :issues_calendar] feature_category :code_review_workflow, [:merge_requests] urgency :low, [:merge_requests, :activity] urgency :low, [:issues, :issues_calendar] def activity respond_to do |format| format.html format.json do load_events pager_json('events/_events', @events.count { |event| event.visible_to_user?(current_user) }) end end end protected def load_events @events = case params[:filter] when "projects", "starred" load_project_events when "followed" load_user_events(current_user.followees) else load_user_events(current_user) end Events::RenderService.new(current_user).execute(@events) end def load_user_events(user) UserRecentEventsFinder.new(current_user, user, event_filter, params).execute end def load_project_events projects = if params[:filter] == "starred" ProjectsFinder.new(current_user: current_user, params: { starred: true }).execute else current_user.authorized_projects end EventCollection .new(projects, offset: params[:offset].to_i, filter: event_filter) .to_a .map(&:present) end def set_show_full_reference @show_full_reference = true end def check_filters_presence! no_scalar_filters_set = finder_type.scalar_params.none? { |k| params[k].present? } no_array_filters_set = finder_type.array_params.none? { |k, _| params[k].present? } # The `in` param is a modifier of `search`. If it's present while the `search` # param isn't, the finder won't use the `in` param. We consider this as a no # filter scenario. no_search_filter_set = params[:in].present? && params[:search].blank? @no_filters_set = (no_scalar_filters_set && no_array_filters_set) || no_search_filter_set return unless @no_filters_set # Call to set selected `state` and `sort` options in view finder_options respond_to do |format| format.html { render } format.atom { head :bad_request } end end end