forked from mstdn/mastodon
4c03e05a4e
* Nascent tag menu on frontend * Hook up frontend to search * Tag intersection backend first pass * Update yarnlock * WIP * Fix for tags not searching correctly * Make radio buttons function * Simplify radio buttons with modeOption * Better naming * Rearrange options * Add all/any/none functionality on backend * Small PR cleanup * Move to service from scope * Small cleanup, add proper service tests * Don't use send with user input :D * Set appropriate column header * Handle auto updating timeline * Fix up toggle function * Use tag value correctly * A bit more correct to use 'self' rather than 'all' in status scope * Fix some style issues * Fix more code style issues * Style select dropdown more better * Only use to_id'ed value to ensure no SQL injection * Revamp frontend to allow for multiple selects * Update backend / col header to account for more flexible tagging * Update brakeman ignore * Codeclimate suggestions * Fix presenter tag_url * Implement initial PR feedback * Handle additional tag streaming * CodeClimate tweak
64 lines
1.8 KiB
Ruby
64 lines
1.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class TagsController < ApplicationController
|
|
PAGE_SIZE = 20
|
|
|
|
before_action :set_body_classes
|
|
before_action :set_instance_presenter
|
|
|
|
def show
|
|
@tag = Tag.find_by!(name: params[:id].downcase)
|
|
|
|
respond_to do |format|
|
|
format.html do
|
|
serializable_resource = ActiveModelSerializers::SerializableResource.new(InitialStatePresenter.new(initial_state_params), serializer: InitialStateSerializer)
|
|
@initial_state_json = serializable_resource.to_json
|
|
end
|
|
|
|
format.rss do
|
|
@statuses = HashtagQueryService.new.call(@tag, params.slice(:any, :all, :none)).limit(PAGE_SIZE)
|
|
@statuses = cache_collection(@statuses, Status)
|
|
|
|
render xml: RSS::TagSerializer.render(@tag, @statuses)
|
|
end
|
|
|
|
format.json do
|
|
@statuses = HashtagQueryService.new.call(@tag, params.slice(:any, :all, :none), current_account, params[:local])
|
|
.paginate_by_max_id(PAGE_SIZE, params[:max_id])
|
|
@statuses = cache_collection(@statuses, Status)
|
|
|
|
render json: collection_presenter,
|
|
serializer: ActivityPub::CollectionSerializer,
|
|
adapter: ActivityPub::Adapter,
|
|
content_type: 'application/activity+json'
|
|
end
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def set_body_classes
|
|
@body_classes = 'with-modals'
|
|
end
|
|
|
|
def set_instance_presenter
|
|
@instance_presenter = InstancePresenter.new
|
|
end
|
|
|
|
def collection_presenter
|
|
ActivityPub::CollectionPresenter.new(
|
|
id: tag_url(@tag, params.slice(:any, :all, :none)),
|
|
type: :ordered,
|
|
size: @tag.statuses.count,
|
|
items: @statuses.map { |s| ActivityPub::TagManager.instance.uri_for(s) }
|
|
)
|
|
end
|
|
|
|
def initial_state_params
|
|
{
|
|
settings: {},
|
|
token: current_session&.token,
|
|
}
|
|
end
|
|
end
|