2019-05-03 08:17:27 +10:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
class AvatarLookup
|
|
|
|
|
2017-07-28 10:20:09 +09:00
|
|
|
def initialize(user_ids = [])
|
2013-07-21 10:56:48 +10:00
|
|
|
@user_ids = user_ids.tap(&:compact!).tap(&:uniq!).tap(&:flatten!)
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
# Lookup a user by id
|
|
|
|
def [](user_id)
|
2013-07-12 23:07:54 +02:00
|
|
|
users[user_id]
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
2013-05-25 08:50:39 +02:00
|
|
|
private
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2013-09-09 16:02:13 +10:00
|
|
|
def self.lookup_columns
|
2018-08-21 17:28:11 +05:30
|
|
|
@lookup_columns ||= %i{id user_emails.email username name uploaded_avatar_id}
|
2013-09-09 16:02:13 +10:00
|
|
|
end
|
|
|
|
|
2013-07-12 23:07:54 +02:00
|
|
|
def users
|
2013-09-09 16:02:13 +10:00
|
|
|
@users ||= user_lookup_hash
|
|
|
|
end
|
|
|
|
|
|
|
|
def user_lookup_hash
|
|
|
|
hash = {}
|
2017-04-26 19:47:36 +01:00
|
|
|
User.joins(:user_emails)
|
2017-07-28 10:20:09 +09:00
|
|
|
.where(id: @user_ids)
|
|
|
|
.select(AvatarLookup.lookup_columns)
|
|
|
|
.each { |user| hash[user.id] = user }
|
2013-09-09 16:02:13 +10:00
|
|
|
hash
|
2013-05-25 08:50:39 +02:00
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|