Replace this common pattern in controllers:
@tags = Tag.search(search_params).paginate(params[:page], :limit => params[:limit], :search_count => params[:search])
with this:
@tags = Tag.paginated_search(params)
`search_count` is used to skip doing a full page count when we're not
doing a search (on the assumption that the number of results will be
high when not constrained by a search). We didn't do this consistently
though. Refactor to do this in every controller.
27 lines
751 B
Ruby
27 lines
751 B
Ruby
module Moderator
|
|
module Post
|
|
class DisapprovalsController < ApplicationController
|
|
before_action :approver_only
|
|
skip_before_action :api_check
|
|
respond_to :js, :html, :json, :xml
|
|
|
|
def create
|
|
cookies.permanent[:moderated] = Time.now.to_i
|
|
@post_disapproval = PostDisapproval.create(post_disapproval_params)
|
|
respond_with(@post_disapproval, location: moderator_post_disapprovals_path)
|
|
end
|
|
|
|
def index
|
|
@post_disapprovals = PostDisapproval.includes(:user).paginated_search(params)
|
|
respond_with(@post_disapprovals)
|
|
end
|
|
|
|
private
|
|
|
|
def post_disapproval_params
|
|
params.require(:post_disapproval).permit(%i[post_id reason message])
|
|
end
|
|
end
|
|
end
|
|
end
|