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

180 lines
5 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!
2015-12-03 15:02:22 +01:00
before_action :check_siret, only: :create
2016-01-26 15:52:05 +01:00
before_action only: [:show] do
authorized_routes? self.class
end
def index
order = 'DESC'
@liste = params[:liste] || 'a_traiter'
2016-01-08 11:39:04 +01:00
@dossiers = smart_listing_create :dossiers,
dossiers_to_display,
partial: "users/dossiers/list",
array: true
total_dossiers_per_state
end
def new
procedure = Procedure.where(archived: false).find(params[:procedure_id])
@dossier = Dossier.new(procedure: procedure)
@siret = params[:siret] || current_user.siret
rescue ActiveRecord::RecordNotFound
error_procedure
end
2015-11-26 12:29:34 +01:00
def show
@facade = DossierFacades.new params[:id], current_user.email
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 create
entreprise_adapter = SIADE::EntrepriseAdapter.new(siren)
dossier = Dossier.create(user: current_user,
state: 'draft',
procedure_id: create_params[:procedure_id],
mandataire_social: mandataire_social?(entreprise_adapter.mandataires_sociaux))
entreprise = dossier.create_entreprise(entreprise_adapter.to_params)
2015-09-23 19:20:03 +02:00
entreprise.create_rna_information(SIADE::RNAAdapter.new(siret).to_params)
2015-09-23 19:20:03 +02:00
etablissement = dossier.create_etablissement(SIADE::EtablissementAdapter.new(siret).to_params
.merge({entreprise_id: entreprise.id}))
etablissement.exercices.create(SIADE::ExercicesAdapter.new(siret).to_params)
2015-09-23 19:20:03 +02:00
redirect_to url_for(controller: :dossiers, action: :show, id: dossier.id)
2015-09-23 19:20:03 +02:00
rescue RestClient::ResourceNotFound
2015-12-03 15:02:22 +01:00
errors_valid_siret
2015-09-23 19:20:03 +02:00
rescue ActiveRecord::RecordNotFound
flash.alert = t('errors.messages.dossier_not_found')
redirect_to url_for(controller: :siret)
end
def update
@facade = DossierFacades.new params[:id], current_user.email
2015-09-23 19:20:03 +02:00
if checked_autorisation_donnees?
@facade.dossier.update_attributes(update_params)
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.now.alert = 'Les conditions sont obligatoires.'
render 'show'
end
end
def archive
dossier = current_user.dossiers.find(params[:dossier_id])
dossier.update_attributes({archived: true})
flash.notice = 'Dossier archivé'
redirect_to users_dossiers_path
rescue ActiveRecord::RecordNotFound
flash.alert = 'Dossier inéxistant'
redirect_to users_dossiers_path
end
2016-01-26 15:52:05 +01:00
def self.route_authorization
{
states: [:draft]
}
end
2015-09-23 19:20:03 +02:00
private
def dossiers_to_display
{'a_traiter' => waiting_for_user,
'en_attente' => waiting_for_gestionnaire,
'termine' => termine}[@liste]
end
def waiting_for_user
2016-01-08 11:39:04 +01:00
@a_traiter_class = (@liste == 'a_traiter' ? 'active' : '')
@waiting_for_user ||= current_user.dossiers.waiting_for_user 'DESC'
end
def waiting_for_gestionnaire
2016-01-08 11:39:04 +01:00
@en_attente_class = (@liste == 'en_attente' ? 'active' : '')
@waiting_for_gestionnaire ||= current_user.dossiers.waiting_for_gestionnaire 'DESC'
end
def termine
@termine_class = (@liste == 'termine' ? 'active' : '')
@termine ||= current_user.dossiers.termine 'DESC'
end
def total_dossiers_per_state
2016-01-04 10:04:16 +01:00
@dossiers_a_traiter_total = waiting_for_user.count
@dossiers_en_attente_total = waiting_for_gestionnaire.count
@dossiers_termine_total = termine.count
end
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')
redirect_to url_for new_users_dossiers_path(procedure_id: create_params[:procedure_id])
end
2015-09-23 19:20:03 +02:00
def update_params
params.require(:dossier).permit(:autorisation_donnees)
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 siren
siret[0..8]
end
2015-11-30 14:48:37 +01:00
def create_params
params.require(:dossier).permit(:siret, :procedure_id)
end
def error_procedure
2015-12-24 15:22:30 +01:00
flash.alert = t('errors.messages.procedure_not_found')
redirect_to url_for users_dossiers_path
end
def mandataire_social? mandataires_list
unless current_user.france_connect_information.nil?
mandataires_list.each do |mandataire|
return true if mandataire[:nom].upcase == current_user.family_name.upcase &&
mandataire[:prenom].upcase == current_user.given_name.upcase &&
mandataire[:date_naissance_timestamp] == current_user.birthdate.to_time.to_i
end
end
false
end
end