Retrospring/app/controllers/user_controller.rb

115 lines
3.7 KiB
Ruby
Raw Normal View History

2022-11-15 12:41:05 -08:00
# frozen_string_literal: true
2014-11-02 08:57:37 -08:00
class UserController < ApplicationController
before_action :set_user
before_action :hidden_social_graph_redirect, only: %i[followers followings]
after_action :mark_notification_as_read, only: %i[show]
2014-11-02 08:57:37 -08:00
def show
@answers = @user.cursored_answers(last_id: params[:last_id])
@pinned_answers = @user.answers.pinned.order(pinned_at: :desc).limit(10)
@answers_last_id = @answers.map(&:id).min
@more_data_available = !@user.cursored_answers(last_id: @answers_last_id, size: 1).count.zero?
2014-12-08 06:23:04 -08:00
respond_to do |format|
format.html
format.turbo_stream
2014-12-08 06:23:04 -08:00
end
2014-11-02 08:57:37 -08:00
end
2014-12-08 08:03:06 -08:00
def followers
paginate_relationships(:cursored_follower_relationships)
@users = @relationships.map(&:source)
own_relationships = find_own_relationships
locals = {
type: :follower,
own_followings: own_relationships[Relationships::Follow],
own_blocks: own_relationships[Relationships::Block],
own_mutes: own_relationships[Relationships::Mute]
}
2020-05-08 19:39:09 -07:00
respond_to do |format|
format.html { render "show_follow", locals: }
format.turbo_stream { render "show_follow", locals: }
2020-05-08 19:39:09 -07:00
end
2014-12-08 08:03:06 -08:00
end
2021-12-31 13:19:21 -08:00
def followings
paginate_relationships(:cursored_following_relationships)
@users = @relationships.map(&:target)
own_relationships = find_own_relationships
locals = {
type: :friend,
own_followings: own_relationships[Relationships::Follow],
own_blocks: own_relationships[Relationships::Block],
own_mutes: own_relationships[Relationships::Mute]
}
2020-05-08 19:39:09 -07:00
respond_to do |format|
format.html { render "show_follow", locals: }
format.turbo_stream { render "show_follow", locals: }
2020-05-08 19:39:09 -07:00
end
2014-12-08 08:03:06 -08:00
end
2014-12-19 13:34:24 -08:00
def questions
@questions = @user.cursored_questions(author_is_anonymous: false, direct: direct_param, last_id: params[:last_id])
@questions_last_id = @questions.map(&:id).min
@more_data_available = !@user.cursored_questions(author_is_anonymous: false, direct: direct_param, last_id: @questions_last_id, size: 1).count.zero?
2020-05-08 19:39:09 -07:00
respond_to do |format|
format.html
format.turbo_stream
2020-05-08 19:39:09 -07:00
end
2014-12-19 13:34:24 -08:00
end
private
def mark_notification_as_read
return unless user_signed_in?
Notification
.where(
target_type: "Relationship",
target_id: @user.active_follow_relationships.where(target_id: current_user.id).pluck(:id),
recipient_id: current_user.id,
new: true
).update(new: false)
end
def set_user
2022-11-15 12:41:05 -08:00
@user = User.where("LOWER(screen_name) = ?", params[:username].downcase).includes(:profile).first!
end
def find_own_relationships
return {} unless user_signed_in?
Relationship.where(source: current_user, target_id: @users.map(&:id))
&.select(:target_id, :type)
&.group_by(&:type)
end
def paginate_relationships(method)
@relationships = @user.public_send(method, last_id: params[:last_id])
@relationships_last_id = @relationships.map(&:id).min
@more_data_available = !@user.public_send(method, last_id: @relationships_last_id, size: 1).count.zero?
end
def hidden_social_graph_redirect
2022-11-15 12:41:05 -08:00
return if belongs_to_current_user? || !@user.privacy_hide_social_graph
redirect_to user_path(@user)
end
def direct_param
# return `nil` instead of `false` so we retrieve all questions for the user, direct or not.
# `cursored_questions` will then remove the `direct` field from the WHERE query. otherwise the query filters
# for `WHERE direct = false` ...
return if belongs_to_current_user? || moderation_view?
# page is not being viewed by the current user, and we're not in the moderation view -> only show public questions
false
end
def belongs_to_current_user? = @user == current_user
2014-11-02 08:57:37 -08:00
end