Files
danbooru/app/components/post_navbar_component.rb
evazion cd22c8eb1a posts: eliminate unnecessary favgroup query on posts show page.
Eliminate a SQL query loading the post's favgroups if the current user
is anonymous (and therefore can't have favgroups).
2022-04-18 00:18:54 -05:00

53 lines
1.2 KiB
Ruby

# frozen_string_literal: true
class PostNavbarComponent < ApplicationComponent
extend Memoist
attr_reader :post, :current_user, :search
def initialize(post:, current_user:, search: nil)
super
@post = post
@current_user = current_user
@search = search.presence || "status:any"
end
def render?
has_search_navbar? || pools.any? || favgroups.any?
end
def pools
@pools ||= post.pools.undeleted.sort_by do |pool|
[pool.id == pool_id ? 0 : 1, pool.is_series? ? 0 : 1, pool.name]
end
end
def favgroups
return [] if current_user.is_anonymous? && favgroup_id.nil?
favgroups = FavoriteGroup.visible(current_user).for_post(post.id)
favgroups = favgroups.where(creator: current_user).or(favgroups.where(id: favgroup_id))
favgroups.sort_by do |favgroup|
[favgroup.id == favgroup_id ? 0 : 1, favgroup.name]
end
end
def has_search_navbar?
!query.has_metatag?(:order, :ordfav, :ordpool) && pool_id.blank? && favgroup_id.blank?
end
def pool_id
@pool_id ||= query.find_metatag(:pool, :ordpool)&.to_i
end
def favgroup_id
@favgroup_id ||= query.find_metatag(:favgroup, :ordfavgroup)&.to_i
end
def query
@query ||= PostQuery.new(search)
end
memoize :favgroups
end