demarches-normaliennes/app/controllers/users/dossiers_controller.rb

229 lines
6.2 KiB
Ruby
Raw Normal View History

2015-09-23 19:20:03 +02:00
class Users::DossiersController < UsersController
2016-01-08 11:39:04 +01:00
include SmartListing::Helper::ControllerExtensions
helper SmartListing::Helper
SESSION_USER_RETURN_LOCATION = 'user_return_to'
before_action :store_user_location!, only: :new
2018-08-14 11:47:47 +02:00
before_action :authenticate_user!, except: [:commencer, :commencer_test]
before_action :check_siret, only: :siret_informations
2016-01-26 15:52:05 +01:00
before_action only: [:show] do
authorized_routes? self.class
end
def commencer_test
procedure_path = ProcedurePath.find_by(path: params[:procedure_path])
2018-08-14 11:47:47 +02:00
procedure = procedure_path&.procedure
2017-01-10 15:27:40 +01:00
2018-08-14 11:47:47 +02:00
if procedure&.brouillon_avec_lien?
redirect_to new_users_dossier_path(procedure_id: procedure.id, brouillon: true)
else
2018-09-05 14:48:42 +02:00
flash.alert = "La démarche est inconnue."
redirect_to root_path
end
end
def commencer
procedure_path = ProcedurePath.find_by(path: params[:procedure_path])
2018-05-23 15:36:50 +02:00
procedure = procedure_path&.procedure
2016-11-07 17:08:33 +01:00
if procedure.present?
if procedure.archivee?
@dossier = Dossier.new(procedure: procedure)
2016-11-07 17:08:33 +01:00
render 'commencer/archived'
else
redirect_to new_users_dossier_path(procedure_id: procedure.id)
end
else
2018-09-05 14:48:42 +02:00
flash.alert = "La démarche est inconnue, ou la création de nouveaux dossiers pour cette démarche est terminée."
redirect_to root_path
2016-11-07 17:08:33 +01:00
end
end
def new
erase_user_location!
2018-08-14 11:47:47 +02:00
if params[:brouillon]
procedure = Procedure.brouillon.find(params[:procedure_id])
else
procedure = Procedure.publiees.find(params[:procedure_id])
end
dossier = Dossier.create!(procedure: procedure, user: current_user, state: Dossier.states.fetch(:brouillon))
siret = params[:siret] || current_user.siret
2018-01-11 19:04:39 +01:00
update_current_user_siret! siret if siret.present?
if dossier.procedure.for_individual
redirect_to identite_dossier_path(dossier)
else
redirect_to users_dossier_path(id: dossier.id)
end
rescue ActiveRecord::RecordNotFound
error_procedure
end
2015-11-26 12:29:34 +01:00
def show
@facade = facade
2018-01-11 19:04:39 +01:00
@siret = current_user.siret if current_user.siret.present?
2015-09-23 19:20:03 +02:00
if @facade.procedure.for_individual? && current_user.loged_in_with_france_connect?
individual = @facade.dossier.individual
individual.update_column :gender, @facade.dossier.france_connect_information.gender
individual.update_column :nom, @facade.dossier.france_connect_information.family_name
individual.update_column :prenom, @facade.dossier.france_connect_information.given_name
individual.birthdate = @facade.dossier.france_connect_information.birthdate
individual.save
end
2015-09-23 19:20:03 +02:00
rescue ActiveRecord::RecordNotFound
flash.alert = t('errors.messages.dossier_not_found')
redirect_to url_for dossiers_path
2015-09-23 19:20:03 +02:00
end
def siret_informations
@facade = facade params[:dossier_id]
2015-09-23 19:20:03 +02:00
2018-02-22 16:53:29 +01:00
update_current_user_siret!(siret)
etablissement_attributes = ApiEntrepriseService.get_etablissement_params_for_siret(siret, @facade.dossier.procedure_id)
2018-02-28 17:16:03 +01:00
if etablissement_attributes.present?
etablissement_attributes = ActionController::Parameters.new(etablissement_attributes).permit!
2018-03-07 17:43:44 +01:00
etablissement = @facade.dossier.build_etablissement(etablissement_attributes)
2018-03-26 17:44:51 +02:00
if !etablissement.save
2018-02-28 17:16:03 +01:00
return errors_valid_siret
end
2018-02-22 16:53:29 +01:00
else
return errors_valid_siret
end
2015-09-23 19:20:03 +02:00
@facade = facade params[:dossier_id]
2015-09-23 19:20:03 +02:00
if @facade.procedure.individual_with_siret?
render '/dossiers/add_siret', formats: 'js'
else
render '/dossiers/new_siret', formats: 'js'
end
2015-09-23 19:20:03 +02:00
rescue ActiveRecord::RecordNotFound
flash.alert = t('errors.messages.dossier_not_found')
redirect_to url_for dossiers_path
end
def change_siret
Dossier.find(params[:dossier_id]).reset!
@facade = facade params[:dossier_id]
if @facade.procedure.individual_with_siret?
render '/dossiers/add_siret', formats: 'js'
else
render '/dossiers/new_siret', formats: 'js'
end
2015-09-23 19:20:03 +02:00
end
def update
@facade = facade params[:dossier][:id]
2015-09-23 19:20:03 +02:00
if individual_errors.any?
flash.alert = individual_errors
redirect_to users_dossier_path(id: @facade.dossier.id)
else
if !Dossier.find(@facade.dossier.id).update(update_params)
flash.alert = @facade.dossier.errors.full_messages
return redirect_to users_dossier_path(id: @facade.dossier.id)
2016-08-30 11:18:43 +02:00
end
if @facade.dossier.procedure.module_api_carto.use_api_carto
redirect_to url_for(controller: :carte, action: :show, dossier_id: @facade.dossier.id)
else
redirect_to brouillon_dossier_path(@facade.dossier)
end
2015-09-23 19:20:03 +02:00
end
end
2016-01-26 15:52:05 +01:00
def self.route_authorization
{
2018-08-28 14:12:48 +02:00
states: [Dossier.states.fetch(:brouillon)]
2016-01-26 15:52:05 +01:00
}
end
def destroy
dossier = current_user.dossiers.find(params[:id])
if dossier.brouillon?
dossier.destroy
flash.notice = 'Brouillon supprimé'
end
redirect_to url_for dossiers_path
end
def text_summary
dossier = Dossier.find(params[:dossier_id])
render json: { textSummary: dossier.text_summary }
rescue ActiveRecord::RecordNotFound
render json: {}, status: 404
end
2015-09-23 19:20:03 +02:00
private
2015-12-03 15:02:22 +01:00
def check_siret
2018-01-11 19:04:39 +01:00
errors_valid_siret if !Siret.new(siret: siret).valid?
2015-12-03 15:02:22 +01:00
end
def errors_valid_siret
flash.alert = t('errors.messages.invalid_siret')
@facade = facade params[:dossier_id]
render '/dossiers/new_siret', formats: :js, locals: { invalid_siret: siret }
2015-12-03 15:02:22 +01:00
end
2015-09-23 19:20:03 +02:00
def update_params
params.require(:dossier).permit(:id, :autorisation_donnees)
2015-09-23 19:20:03 +02:00
end
def individual_errors
errors = []
if update_params[:autorisation_donnees] != "1"
errors << "La validation des conditions d'utilisation est obligatoire"
end
errors
2015-09-23 19:20:03 +02:00
end
def siret
create_params[:siret]
2015-09-23 19:20:03 +02:00
end
def create_params
params.require(:dossier).permit(:siret)
end
def error_procedure
2015-12-24 15:22:30 +01:00
flash.alert = t('errors.messages.procedure_not_found')
redirect_to url_for dossiers_path
end
def update_current_user_siret!(siret)
current_user.update(siret: siret)
end
def facade(id = params[:id])
DossierFacades.new id, current_user.email
end
def store_user_location!
store_location_for(:user, request.fullpath)
end
def erase_user_location!
session.delete(SESSION_USER_RETURN_LOCATION)
end
end