mirror of
https://github.com/glitch-soc/mastodon.git
synced 2024-11-29 19:40:23 -05:00
27965ce5ed
* Add trending statuses * Fix dangling items with stale scores in localized sets * Various fixes and improvements - Change approve_all/reject_all to approve_accounts/reject_accounts - Change Trends::Query methods to not mutate the original query - Change Trends::Query#skip to offset - Change follow recommendations to be refreshed in a transaction * Add tests for trending statuses filtering behaviour * Fix not applying filtering scope in controller
46 lines
1.2 KiB
Ruby
46 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class Admin::Trends::LinksController < Admin::BaseController
|
|
def index
|
|
authorize :preview_card, :index?
|
|
|
|
@preview_cards = filtered_preview_cards.page(params[:page])
|
|
@form = Trends::PreviewCardBatch.new
|
|
end
|
|
|
|
def batch
|
|
@form = Trends::PreviewCardBatch.new(trends_preview_card_batch_params.merge(current_account: current_account, action: action_from_button))
|
|
@form.save
|
|
rescue ActionController::ParameterMissing
|
|
flash[:alert] = I18n.t('admin.accounts.no_account_selected')
|
|
ensure
|
|
redirect_to admin_trends_links_path(filter_params)
|
|
end
|
|
|
|
private
|
|
|
|
def filtered_preview_cards
|
|
Trends::PreviewCardFilter.new(filter_params.with_defaults(trending: 'all')).results
|
|
end
|
|
|
|
def filter_params
|
|
params.slice(:page, *Trends::PreviewCardFilter::KEYS).permit(:page, *Trends::PreviewCardFilter::KEYS)
|
|
end
|
|
|
|
def trends_preview_card_batch_params
|
|
params.require(:trends_preview_card_batch).permit(:action, preview_card_ids: [])
|
|
end
|
|
|
|
def action_from_button
|
|
if params[:approve]
|
|
'approve'
|
|
elsif params[:approve_providers]
|
|
'approve_providers'
|
|
elsif params[:reject]
|
|
'reject'
|
|
elsif params[:reject_providers]
|
|
'reject_providers'
|
|
end
|
|
end
|
|
end
|