The current tracking section had a few issues: * When browsing as an admin, this section becomes useless since no investments are shown * Browsing investments in the admin section, you're suddenly redirected to the tracking section, making navigation confusing * One test related to the officing dashboard failed due to these changes and had been commented * Several views and controller methods were copied from other sections, leading to duplication and making the code harder to maintain * Tracking routes were defined for proposals and legislation processes, but in the tracking section only investments were shown * Probably many more things, since these issues were detected after only an hour reviewing and testing the code So we're removing this untested section before releasing version 1.1. We might add it back afterwards.
73 lines
1.8 KiB
Ruby
73 lines
1.8 KiB
Ruby
class Admin::MilestonesController < Admin::BaseController
|
|
include Translatable
|
|
include ImageAttributes
|
|
|
|
before_action :load_milestoneable, only: [:index, :new, :create, :edit, :update, :destroy]
|
|
before_action :load_milestone, only: [:edit, :update, :destroy]
|
|
before_action :load_statuses, only: [:index, :new, :create, :edit, :update]
|
|
helper_method :milestoneable_path
|
|
|
|
def index
|
|
end
|
|
|
|
def new
|
|
@milestone = @milestoneable.milestones.new
|
|
end
|
|
|
|
def create
|
|
@milestone = @milestoneable.milestones.new(milestone_params)
|
|
if @milestone.save
|
|
redirect_to milestoneable_path, notice: t("admin.milestones.create.notice")
|
|
else
|
|
render :new
|
|
end
|
|
end
|
|
|
|
def edit
|
|
end
|
|
|
|
def update
|
|
if @milestone.update(milestone_params)
|
|
redirect_to milestoneable_path, notice: t("admin.milestones.update.notice")
|
|
else
|
|
render :edit
|
|
end
|
|
end
|
|
|
|
def destroy
|
|
@milestone.destroy!
|
|
redirect_to milestoneable_path, notice: t("admin.milestones.delete.notice")
|
|
end
|
|
|
|
private
|
|
|
|
def milestone_params
|
|
documents_attributes = [:id, :title, :attachment, :cached_attachment, :user_id, :_destroy]
|
|
attributes = [:publication_date, :status_id,
|
|
translation_params(Milestone),
|
|
image_attributes: image_attributes, documents_attributes: documents_attributes]
|
|
|
|
params.require(:milestone).permit(*attributes)
|
|
end
|
|
|
|
def load_milestoneable
|
|
@milestoneable = milestoneable
|
|
end
|
|
|
|
def milestoneable
|
|
raise "Implement in subclass"
|
|
end
|
|
|
|
def load_milestone
|
|
@milestone = @milestoneable.milestones.find(params[:id])
|
|
end
|
|
|
|
def load_statuses
|
|
@statuses = Milestone::Status.all
|
|
end
|
|
|
|
def milestoneable_path
|
|
polymorphic_path([:admin, *resource_hierarchy_for(@milestone.milestoneable)])
|
|
end
|
|
end
|