class Admin::BadgesController < Admin::AdminController def index data = { badge_types: BadgeType.all.order(:id).to_a, badge_groupings: BadgeGrouping.all.order(:position).to_a, badges: Badge.includes(:badge_grouping) .references(:badge_grouping) .order('badge_groupings.position, badge_type_id, badges.name').to_a, protected_system_fields: Badge.protected_system_fields, triggers: Badge.trigger_hash } render_serialized(OpenStruct.new(data), AdminBadgesSerializer) end def preview render json: BadgeGranter.preview(params[:sql], target_posts: params[:target_posts] == "true") end def badge_types badge_types = BadgeType.all.to_a render_serialized(badge_types, BadgeTypeSerializer, root: "badge_types") end def save_badge_groupings badge_groupings = BadgeGrouping.all.order(:position).to_a ids = params[:ids].map(&:to_i) params[:names].each_with_index do |name,index| id = ids[index].to_i group = badge_groupings.find{|b| b.id == id} || BadgeGrouping.new() group.name = name group.position = index group.save end badge_groupings.each do |g| g.destroy unless g.system? || ids.include?(g.id) end badge_groupings = BadgeGrouping.all.order(:position).to_a render_serialized(badge_groupings, BadgeGroupingSerializer, root: "badge_groupings") end def create badge = Badge.new update_badge_from_params(badge) badge.save! render_serialized(badge, BadgeSerializer, root: "badge") end def update badge = find_badge update_badge_from_params(badge) badge.save! render_serialized(badge, BadgeSerializer, root: "badge") end def destroy find_badge.destroy render nothing: true end private def find_badge params.require(:id) Badge.find(params[:id]) end def update_badge_from_params(badge) allowed = Badge.column_names.map(&:to_sym) allowed -= [:id, :created_at, :updated_at, :grant_count] allowed -= Badge.protected_system_fields if badge.system? params.permit(*allowed) allowed.each do |key| badge.send("#{key}=" , params[key]) if params[key] end badge end end