rubyberlin/cfp-app

View on GitHub
app/controllers/staff/tracks_controller.rb

Summary

Maintainability
A
15 mins
Test Coverage
class Staff::TracksController < Staff::ApplicationController
  before_action :set_track, only: %i[edit update destroy]

  def new
    @track = Track.new
  end

  def edit
    respond_to do |format|
      format.js do
        render locals: { track: @track }
      end
    end
  end

  def create
    track = current_event.tracks.build(track_params)
    unless track.save
      flash.now[:danger] = "There was a problem saving your track, #{track.errors.full_messages.join(', ')}."
    end
    respond_to do |format|
      format.js do
        render locals: { track: track }
      end
    end
  end

  def update
    if @track.update(track_params)
      flash.now[:success] = "#{@track.name} has been updated." # changes to guildlines are invisible
    else
      flash.now[:danger] = "There was a problem updating your track, #{@track.errors.full_messages.join(', ')}."
    end
    respond_to do |format|
      format.js do
        render locals: { track: @track }
      end
    end
  end

  def destroy
    unless @track.destroy
      flash.now[:danger] = "There was a problem deleting the #{@track.name} track."
    end
    respond_to do |format|
      format.js do
        render locals: { track: @track }
      end
    end
  end

  private

  def set_track
    @track = current_event.tracks.find(params[:id])
  end

  def track_params
    params.require(:track).permit(:name, :description, :guidelines)
  end
end