|
|
|
class CaseLogsController < ApplicationController
|
|
|
|
skip_before_action :verify_authenticity_token, if: :json_api_request?
|
|
|
|
before_action :authenticate, if: :json_api_request?
|
|
|
|
|
|
|
|
def index
|
|
|
|
@completed_case_logs = CaseLog.completed
|
|
|
|
@in_progress_case_logs = CaseLog.not_completed
|
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
case_log = CaseLog.create(api_case_log_params)
|
|
|
|
respond_to do |format|
|
|
|
|
format.html { redirect_to case_log }
|
|
|
|
format.json do
|
|
|
|
if case_log.persisted?
|
|
|
|
render json: case_log, status: :created
|
|
|
|
else
|
|
|
|
render json: { errors: case_log.errors.full_messages }, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
if (case_log = CaseLog.find_by(id: params[:id]))
|
|
|
|
if case_log.update(api_case_log_params)
|
|
|
|
render json: case_log, status: :ok
|
|
|
|
else
|
|
|
|
render json: { errors: case_log.errors.full_messages }, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
else
|
|
|
|
render json: { error: "Case Log #{params[:id]} not found" }, status: :not_found
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def show
|
|
|
|
respond_to do |format|
|
|
|
|
# We don't have a dedicated non-editable show view
|
|
|
|
format.html { edit }
|
|
|
|
format.json do
|
|
|
|
if (case_log = CaseLog.find_by(id: params[:id]))
|
|
|
|
render json: case_log, status: :ok
|
|
|
|
else
|
|
|
|
render json: { error: "Case Log #{params[:id]} not found" }, status: :not_found
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def edit
|
|
|
|
@form = FormHandler.instance.get_form("2021_2022")
|
|
|
|
@case_log = CaseLog.find(params[:id])
|
|
|
|
render :edit
|
|
|
|
end
|
|
|
|
|
|
|
|
def submit_form
|
|
|
|
form = FormHandler.instance.get_form("2021_2022")
|
|
|
|
@case_log = CaseLog.find(params[:id])
|
|
|
|
previous_page = params[:case_log][:previous_page]
|
|
|
|
questions_for_page = form.questions_for_page(previous_page)
|
|
|
|
responses_for_page = question_responses(questions_for_page)
|
|
|
|
@case_log.previous_page = previous_page
|
|
|
|
if @case_log.update(responses_for_page)
|
|
|
|
redirect_path = get_next_page_path(form, previous_page, responses_for_page)
|
|
|
|
redirect_to(send(redirect_path, @case_log))
|
|
|
|
else
|
|
|
|
page_info = form.all_pages[previous_page]
|
|
|
|
render "form/page", locals: { form: form, page_key: previous_page, page_info: page_info }, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
|
|
|
if (case_log = CaseLog.find_by(id: params[:id]))
|
|
|
|
if case_log.discard
|
|
|
|
head :no_content
|
|
|
|
else
|
|
|
|
render json: { errors: case_log.errors.full_messages }, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
else
|
|
|
|
render json: { error: "Case Log #{params[:id]} not found" }, status: :not_found
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def check_answers
|
|
|
|
form = FormHandler.instance.get_form("2021_2022")
|
|
|
|
@case_log = CaseLog.find(params[:case_log_id])
|
|
|
|
current_url = request.env["PATH_INFO"]
|
|
|
|
subsection = current_url.split("/")[-2]
|
|
|
|
render "form/check_answers", locals: { subsection: subsection, form: form }
|
|
|
|
end
|
|
|
|
|
|
|
|
form = FormHandler.instance.get_form("2021_2022")
|
|
|
|
form.all_pages.map do |page_key, page_info|
|
|
|
|
define_method(page_key) do |_errors = {}|
|
|
|
|
@case_log = CaseLog.find(params[:case_log_id])
|
|
|
|
render "form/page", locals: { form: form, page_key: page_key, page_info: page_info }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
API_ACTIONS = %w[create show update destroy].freeze
|
|
|
|
|
|
|
|
def question_responses(questions_for_page)
|
|
|
|
questions_for_page.each_with_object({}) do |(question_key, question_info), result|
|
|
|
|
question_params = params["case_log"][question_key]
|
|
|
|
if question_info["type"] == "checkbox"
|
|
|
|
question_info["answer_options"].keys.reject { |x| x.match(/divider/) }.each do |option|
|
|
|
|
result[option] = question_params.include?(option)
|
|
|
|
end
|
|
|
|
else
|
|
|
|
result[question_key] = question_params
|
|
|
|
end
|
|
|
|
result
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def json_api_request?
|
|
|
|
API_ACTIONS.include?(request["action"]) && request.format.json?
|
|
|
|
end
|
|
|
|
|
|
|
|
def authenticate
|
|
|
|
http_basic_authenticate_or_request_with name: ENV["API_USER"], password: ENV["API_KEY"]
|
|
|
|
end
|
|
|
|
|
|
|
|
def api_case_log_params
|
|
|
|
return {} unless params[:case_log]
|
|
|
|
|
|
|
|
params.require(:case_log).permit(CaseLog.editable_fields)
|
|
|
|
end
|
|
|
|
|
|
|
|
def get_next_page_path(form, previous_page, responses_for_page = {})
|
|
|
|
questions_for_page = form.questions_for_page(previous_page)
|
|
|
|
questions_for_page.each do |question, content|
|
|
|
|
next unless content.key?("conditional_route_to")
|
|
|
|
|
|
|
|
content["conditional_route_to"].each do |route, answer|
|
|
|
|
if responses_for_page[question].present? && answer.include?(responses_for_page[question])
|
|
|
|
return "case_log_#{route}_path"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
form.next_page_redirect_path(previous_page)
|
|
|
|
end
|
|
|
|
end
|