mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 10:22:45 +08:00
PERF: Don't load all poll_votes for a poll
This commit is contained in:
parent
996765562e
commit
356491aea8
|
@ -55,7 +55,7 @@ class Poll < ActiveRecord::Base
|
|||
end
|
||||
|
||||
def has_voted?(user)
|
||||
user&.id && poll_votes.any? { |v| v.user_id == user.id }
|
||||
user&.id && poll_votes.where(user_id: user.id).exists?
|
||||
end
|
||||
|
||||
def can_see_voters?(user)
|
||||
|
|
|
@ -45,7 +45,7 @@ class PollSerializer < ApplicationSerializer
|
|||
end
|
||||
|
||||
def voters
|
||||
object.poll_votes.map { |v| v.user_id }.uniq.count + object.anonymous_voters.to_i
|
||||
object.poll_votes.count('DISTINCT user_id') + object.anonymous_voters.to_i
|
||||
end
|
||||
|
||||
def close
|
||||
|
|
|
@ -67,7 +67,7 @@ after_initialize do
|
|||
raise StandardError.new I18n.t("poll.user_cant_post_in_topic")
|
||||
end
|
||||
|
||||
poll = Poll.includes(poll_options: :poll_votes).find_by(post_id: post_id, name: poll_name)
|
||||
poll = Poll.includes(:poll_options).find_by(post_id: post_id, name: poll_name)
|
||||
|
||||
raise StandardError.new I18n.t("poll.no_poll_with_this_name", name: poll_name) unless poll
|
||||
raise StandardError.new I18n.t("poll.poll_must_be_open_to_vote") if poll.is_closed?
|
||||
|
@ -90,18 +90,18 @@ after_initialize do
|
|||
obj << option.id if options.include?(option.digest)
|
||||
end
|
||||
|
||||
old_option_ids = poll.poll_options.each_with_object([]) do |option, obj|
|
||||
if option.poll_votes.where(user_id: user.id).exists?
|
||||
obj << option.id
|
||||
end
|
||||
end
|
||||
|
||||
# remove non-selected votes
|
||||
PollVote
|
||||
.where(poll: poll, user: user)
|
||||
.where.not(poll_option_id: new_option_ids)
|
||||
.delete_all
|
||||
|
||||
old_option_ids = poll.poll_options.each_with_object([]) do |option, obj|
|
||||
if option.poll_votes.any? { |v| v.user_id == user.id }
|
||||
obj << option.id
|
||||
end
|
||||
end
|
||||
|
||||
# create missing votes
|
||||
(new_option_ids - old_option_ids).each do |option_id|
|
||||
PollVote.create!(poll: poll, user: user, poll_option_id: option_id)
|
||||
|
@ -574,7 +574,6 @@ after_initialize do
|
|||
|
||||
if post_with_polls.present?
|
||||
Poll
|
||||
.includes(poll_options: :poll_votes, poll_votes: :poll_option)
|
||||
.where(post_id: post_with_polls)
|
||||
.each do |p|
|
||||
polls[p.post_id] ||= []
|
||||
|
@ -590,7 +589,7 @@ after_initialize do
|
|||
@preloaded_polls ||= if @topic_view.present?
|
||||
@topic_view.polls[object.id]
|
||||
else
|
||||
Poll.includes(poll_options: :poll_votes).where(post: object)
|
||||
Poll.includes(:poll_options).where(post: object)
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -608,11 +607,12 @@ after_initialize do
|
|||
|
||||
add_to_serializer(:post, :polls_votes, false) do
|
||||
preloaded_polls.map do |poll|
|
||||
user_poll_votes = poll.poll_votes.each_with_object([]) do |vote, obj|
|
||||
if vote.user_id == scope.user.id
|
||||
obj << vote.poll_option.digest
|
||||
end
|
||||
end
|
||||
user_poll_votes =
|
||||
poll
|
||||
.poll_votes
|
||||
.where(user_id: scope.user.id)
|
||||
.joins(:poll_option)
|
||||
.pluck("poll_options.digest")
|
||||
|
||||
[poll.name, user_poll_votes]
|
||||
end.to_h
|
||||
|
|
Loading…
Reference in New Issue
Block a user