50487db122
* Add database table for status-specific filters * Add REST endpoints, entities and attributes * Show status filters in /filters interface * Perform server-side filtering for individual posts filters * Fix filtering on context mismatch * Refactor `toServerSideType` by moving it to its own module * Move loupe and delete icons to their own module * Add ability to filter individual posts from WebUI * Replace keyword list by warnings (expired, context mismatch) * Refactor server-side filtering code * Add tests
57 lines
1.2 KiB
Ruby
57 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class FiltersController < ApplicationController
|
|
layout 'admin'
|
|
|
|
before_action :authenticate_user!
|
|
before_action :set_filter, only: [:edit, :update, :destroy]
|
|
before_action :set_body_classes
|
|
|
|
def index
|
|
@filters = current_account.custom_filters.includes(:keywords, :statuses).order(:phrase)
|
|
end
|
|
|
|
def new
|
|
@filter = current_account.custom_filters.build(action: :warn)
|
|
@filter.keywords.build
|
|
end
|
|
|
|
def create
|
|
@filter = current_account.custom_filters.build(resource_params)
|
|
|
|
if @filter.save
|
|
redirect_to filters_path
|
|
else
|
|
render action: :new
|
|
end
|
|
end
|
|
|
|
def edit; end
|
|
|
|
def update
|
|
if @filter.update(resource_params)
|
|
redirect_to filters_path
|
|
else
|
|
render action: :edit
|
|
end
|
|
end
|
|
|
|
def destroy
|
|
@filter.destroy
|
|
redirect_to filters_path
|
|
end
|
|
|
|
private
|
|
|
|
def set_filter
|
|
@filter = current_account.custom_filters.find(params[:id])
|
|
end
|
|
|
|
def resource_params
|
|
params.require(:custom_filter).permit(:title, :expires_in, :filter_action, context: [], keywords_attributes: [:id, :keyword, :whole_word, :_destroy])
|
|
end
|
|
|
|
def set_body_classes
|
|
@body_classes = 'admin'
|
|
end
|
|
end
|