51 lines
1.2 KiB
Ruby
51 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
|
|
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 ||= PostQueryBuilder.new(search)
|
|
end
|
|
|
|
memoize :favgroups
|
|
end
|