2020-04-20 14:03:57 -07:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2020-05-25 09:04:54 -07:00
|
|
|
module List::TimelineMethods
|
2020-04-20 14:03:57 -07:00
|
|
|
include CursorPaginatable
|
|
|
|
|
|
|
|
define_cursor_paginator :cursored_timeline, :timeline
|
|
|
|
|
2023-10-22 10:51:23 -07:00
|
|
|
# @return [ActiveRecord::Relation<Answer>] the lists' timeline
|
2023-02-20 12:27:24 -08:00
|
|
|
def timeline(current_user: nil)
|
|
|
|
Answer
|
2023-11-26 10:32:50 -08:00
|
|
|
.for_user(current_user)
|
2023-10-22 10:51:23 -07:00
|
|
|
.includes([{ user: :profile }, :question])
|
2023-02-20 12:27:24 -08:00
|
|
|
.then do |query|
|
|
|
|
next query unless current_user
|
|
|
|
|
|
|
|
blocked_and_muted_user_ids = current_user.blocked_user_ids_cached + current_user.muted_user_ids_cached
|
|
|
|
next query if blocked_and_muted_user_ids.empty?
|
|
|
|
|
|
|
|
# build a more complex query if we block or mute someone
|
|
|
|
# otherwise the query ends up as "anon OR (NOT anon AND user_id NOT IN (NULL))" which will only return anonymous questions
|
|
|
|
query
|
|
|
|
.joins(:question)
|
|
|
|
.where("questions.author_is_anonymous OR (NOT questions.author_is_anonymous AND questions.user_id NOT IN (?))", blocked_and_muted_user_ids)
|
|
|
|
.where.not(answers: { user_id: blocked_and_muted_user_ids })
|
|
|
|
end
|
|
|
|
.where(answers: { user_id: members.pluck(:user_id) }).order(:created_at).reverse_order
|
2020-04-20 14:03:57 -07:00
|
|
|
end
|
|
|
|
end
|