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

191 lines
5.4 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
before_action :authenticate_user!, except: :commencer
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 index
2016-10-11 18:05:49 +02:00
cookies[:liste] = param_liste
2016-09-13 12:17:56 +02:00
2016-10-11 18:05:49 +02:00
@dossiers_list_facade = DossiersListFacades.new current_user, param_liste
unless DossiersListUserService.dossiers_liste_libelle.include?(param_liste)
cookies[:liste] = 'a_traiter'
return redirect_to users_dossiers_path
end
2016-01-08 11:39:04 +01:00
@dossiers = smart_listing_create :dossiers,
@dossiers_list_facade.dossiers_to_display,
2016-01-08 11:39:04 +01:00
partial: "users/dossiers/list",
array: true
end
def commencer
unless params[:procedure_path].nil?
procedure = ProcedurePath.where(path: params[:procedure_path]).first!.procedure
end
redirect_to new_users_dossier_path(procedure_id: procedure.id)
rescue ActiveRecord::RecordNotFound
error_procedure
end
def new
procedure = Procedure.where(archived: false, published: true).find(params[:procedure_id])
dossier = Dossier.create(procedure: procedure, user: current_user, state: 'draft')
siret = params[:siret] || current_user.siret
update_current_user_siret! siret unless siret.nil?
redirect_to users_dossier_path(id: dossier.id)
rescue ActiveRecord::RecordNotFound
error_procedure
end
2015-11-26 12:29:34 +01:00
def show
@facade = facade
@siret = current_user.siret unless current_user.siret.nil?
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.update_column :birthdate, @facade.dossier.france_connect_information.birthdate.strftime("%d/%m/%Y")
end
2015-09-23 19:20:03 +02:00
rescue ActiveRecord::RecordNotFound
flash.alert = t('errors.messages.dossier_not_found')
redirect_to url_for users_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
update_current_user_siret! siret
dossier = DossierService.new(@facade.dossier, siret, current_user.france_connect_information).dossier_informations!
2016-07-28 10:20:53 +02:00
if dossier.entreprise.nil? || dossier.etablissement.nil?
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
rescue RestClient::ResourceNotFound, RestClient::BadRequest
2015-12-03 15:02:22 +01:00
errors_valid_siret
rescue RestClient::ServiceUnavailable
render '/dossiers/degraded', formats: 'js'
2015-09-23 19:20:03 +02:00
rescue ActiveRecord::RecordNotFound
flash.alert = t('errors.messages.dossier_not_found')
redirect_to url_for users_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 checked_autorisation_donnees?
2016-08-30 11:18:43 +02:00
begin
@facade.dossier.update_attributes!(update_params)
rescue
flash.now.alert = @facade.dossier.errors.full_messages.join('<br />').html_safe
return render 'show'
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 url_for(controller: :description, action: :show, dossier_id: @facade.dossier.id)
end
2015-09-23 19:20:03 +02:00
else
flash.alert = 'Les conditions sont obligatoires.'
redirect_to users_dossier_path(id: @facade.dossier.id)
2015-09-23 19:20:03 +02:00
end
end
2016-01-26 15:52:05 +01:00
def self.route_authorization
{
states: [:draft]
}
end
def destroy
dossier = current_user.dossiers.find(params[:id])
if dossier.brouillon?
dossier.destroy
flash.notice = 'Brouillon supprimé'
end
redirect_to url_for users_dossiers_path
end
2015-09-23 19:20:03 +02:00
private
2015-12-03 15:02:22 +01:00
def check_siret
errors_valid_siret unless Siret.new(siret: siret).valid?
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
2016-10-06 11:21:07 +02:00
params.require(:dossier).permit(:id, :autorisation_donnees, individual_attributes: [:gender, :nom, :prenom, :birthdate])
2015-09-23 19:20:03 +02:00
end
def checked_autorisation_donnees?
update_params[:autorisation_donnees] == '1'
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')
2015-12-24 15:22:30 +01:00
redirect_to url_for users_dossiers_path
end
def update_current_user_siret! siret
current_user.update_attributes(siret: siret)
end
def facade id = params[:id]
DossierFacades.new id, current_user.email
end
2016-10-11 18:05:49 +02:00
def param_liste
@liste ||= params[:liste] || cookies[:liste] || 'a_traiter'
end
end