demarches-normaliennes/app/controllers/instructeurs/procedures_controller.rb

306 lines
9.2 KiB
Ruby
Raw Normal View History

module Instructeurs
class ProceduresController < InstructeurController
before_action :ensure_ownership!, except: [:index]
before_action :redirect_to_avis_if_needed, only: [:index]
ITEMS_PER_PAGE = 25
2017-09-27 15:16:07 +02:00
def index
2019-09-16 14:04:18 +02:00
@procedures = current_instructeur
.procedures
2019-09-17 11:11:08 +02:00
.with_attached_logo
.includes(:defaut_groupe_instructeur)
2019-09-16 14:04:18 +02:00
.order(archived_at: :desc, published_at: :desc, created_at: :desc)
2019-08-26 15:35:40 +02:00
groupe_instructeurs = current_instructeur.groupe_instructeurs.where(procedure: @procedures)
dossiers = current_instructeur.dossiers
2019-08-26 15:35:40 +02:00
@dossiers_count_per_groupe_instructeur = dossiers.all_state.group(:groupe_instructeur_id).reorder(nil).count
@dossiers_a_suivre_count_per_groupe_instructeur = dossiers.without_followers.en_cours.group(:groupe_instructeur_id).reorder(nil).count
@dossiers_archived_count_per_groupe_instructeur = dossiers.archived.group(:groupe_instructeur_id).count
@dossiers_termines_count_per_groupe_instructeur = dossiers.termine.group(:groupe_instructeur_id).reorder(nil).count
2019-08-26 15:35:40 +02:00
@followed_dossiers_count_per_groupe_instructeur = current_instructeur
.followed_dossiers
.en_cours
2019-08-26 15:35:40 +02:00
.where(groupe_instructeur: groupe_instructeurs)
.group(:groupe_instructeur_id)
.reorder(nil)
.count
end
2017-07-11 16:09:03 +02:00
def show
@procedure = procedure
2017-09-28 11:04:18 +02:00
@current_filters = current_filters
@available_fields_to_filters = available_fields_to_filters
# Technically, procedure_presentation already sets the attribute.
# Setting it here to make clear that it is used by the view
@procedure_presentation = procedure_presentation
@displayed_fields_values = displayed_fields_values
2017-07-11 16:09:03 +02:00
@a_suivre_dossiers = procedure
2019-08-26 15:35:40 +02:00
.defaut_groupe_instructeur
2017-07-11 16:09:03 +02:00
.dossiers
2017-07-31 18:00:43 +02:00
.includes(:user)
2017-07-11 16:09:03 +02:00
.without_followers
.en_cours
@followed_dossiers = current_instructeur
2017-07-11 16:09:03 +02:00
.followed_dossiers
2018-02-01 16:20:31 +01:00
.includes(:user)
2019-08-26 15:35:40 +02:00
.where(groupe_instructeur: procedure.defaut_groupe_instructeur)
2017-07-11 16:09:03 +02:00
.en_cours
@followed_dossiers_id = current_instructeur
.followed_dossiers
2019-08-26 15:35:40 +02:00
.where(groupe_instructeur: procedure.defaut_groupe_instructeur)
.pluck(:id)
2019-08-26 15:35:40 +02:00
@termines_dossiers = procedure.defaut_groupe_instructeur.dossiers.includes(:user).termine
2017-07-11 16:09:03 +02:00
2019-08-26 15:35:40 +02:00
@all_state_dossiers = procedure.defaut_groupe_instructeur.dossiers.includes(:user).all_state
2017-07-11 16:09:03 +02:00
2019-08-26 15:35:40 +02:00
@archived_dossiers = procedure.defaut_groupe_instructeur.dossiers.includes(:user).archived
2017-09-28 19:07:18 +02:00
@dossiers = case statut
when 'a-suivre'
@a_suivre_dossiers
when 'suivis'
@followed_dossiers
when 'traites'
@termines_dossiers
when 'tous'
@all_state_dossiers
when 'archives'
@archived_dossiers
end
2017-09-21 16:47:43 +02:00
sorted_ids = procedure_presentation.sorted_ids(@dossiers, current_instructeur)
2017-09-27 15:16:07 +02:00
2017-09-28 11:04:18 +02:00
if @current_filters.count > 0
filtered_ids = procedure_presentation.filtered_ids(@dossiers, statut)
2019-09-12 11:26:22 +02:00
filtered_sorted_ids = sorted_ids.filter { |id| filtered_ids.include?(id) }
2017-09-28 11:04:18 +02:00
else
filtered_sorted_ids = sorted_ids
end
2018-03-06 13:44:29 +01:00
page = params[:page].presence || 1
2017-09-27 15:16:07 +02:00
2017-09-28 11:04:18 +02:00
filtered_sorted_paginated_ids = Kaminari
.paginate_array(filtered_sorted_ids)
2017-09-27 15:16:07 +02:00
.page(page)
.per(ITEMS_PER_PAGE)
2017-09-28 11:04:18 +02:00
@dossiers = @dossiers.where(id: filtered_sorted_paginated_ids)
2017-09-27 15:16:07 +02:00
@dossiers = procedure_presentation.eager_load_displayed_fields(@dossiers)
2017-09-28 11:04:18 +02:00
@dossiers = @dossiers.sort_by { |d| filtered_sorted_paginated_ids.index(d.id) }
2017-09-27 15:16:07 +02:00
2017-09-28 11:04:18 +02:00
kaminarize(page, filtered_sorted_ids.count)
2017-07-11 16:09:03 +02:00
end
def update_displayed_fields
values = params[:values]
if values.nil?
values = []
end
fields = values.map do |value|
2019-02-13 18:24:41 +01:00
find_field(*value.split('/'))
end
procedure_presentation.update(displayed_fields: fields)
2017-09-27 15:16:07 +02:00
current_sort = procedure_presentation.sort
2019-02-13 17:50:33 +01:00
if !values.include?(field_id(current_sort))
procedure_presentation.update(sort: Procedure.default_sort)
2017-09-27 15:16:07 +02:00
end
redirect_back(fallback_location: instructeur_procedure_url(procedure))
2017-09-27 15:16:07 +02:00
end
def update_sort
current_sort = procedure_presentation.sort
table = params[:table]
column = params[:column]
if table == current_sort['table'] && column == current_sort['column']
order = current_sort['order'] == 'asc' ? 'desc' : 'asc'
else
order = 'asc'
end
sort = {
'table' => table,
'column' => column,
'order' => order
2018-09-20 17:02:28 +02:00
}
2017-09-27 15:16:07 +02:00
procedure_presentation.update(sort: sort)
2017-09-27 15:16:07 +02:00
redirect_back(fallback_location: instructeur_procedure_url(procedure))
end
2017-09-28 11:04:18 +02:00
def add_filter
2017-12-06 17:26:23 +01:00
if params[:value].present?
filters = procedure_presentation.filters
table, column = params[:field].split('/')
2019-02-13 18:24:41 +01:00
label = find_field(table, column)['label']
2017-12-06 17:26:23 +01:00
filters[statut] << {
'label' => label,
'table' => table,
'column' => column,
'value' => params[:value]
}
procedure_presentation.update(filters: filters)
2017-12-06 17:26:23 +01:00
end
2017-09-28 11:04:18 +02:00
redirect_back(fallback_location: instructeur_procedure_url(procedure))
2017-09-28 11:04:18 +02:00
end
def remove_filter
filters = procedure_presentation.filters
to_remove = params.values_at(:table, :column, :value)
filters[statut].reject! { |filter| filter.values_at('table', 'column', 'value') == to_remove }
2017-09-28 11:04:18 +02:00
procedure_presentation.update(filters: filters)
2017-09-28 11:04:18 +02:00
redirect_back(fallback_location: instructeur_procedure_url(procedure))
2017-09-28 11:04:18 +02:00
end
def download_dossiers
2019-04-03 14:29:30 +02:00
options = params.permit(:version, :limit, :since, tables: [])
respond_to do |format|
format.csv do
send_data(procedure.to_csv(options),
filename: procedure.export_filename(:csv))
end
format.xlsx do
send_data(procedure.to_xlsx(options),
filename: procedure.export_filename(:xlsx))
end
format.ods do
send_data(procedure.to_ods(options),
filename: procedure.export_filename(:ods))
end
end
end
2019-03-13 17:37:07 +01:00
def email_notifications
@procedure = procedure
@assign_to = assign_to
end
def update_email_notifications
assign_to.update!(email_notifications_enabled: params[:assign_to][:email_notifications_enabled])
flash.notice = 'Vos notifications sont enregistrées.'
redirect_to instructeur_procedure_path(procedure)
2019-03-13 17:37:07 +01:00
end
def stats
@procedure = procedure
@usual_traitement_time = procedure.usual_traitement_time
@dossiers_funnel = [
['Démarrés', procedure.dossiers.count],
['Déposés', procedure.dossiers.state_not_brouillon.count],
['Instruction débutée', procedure.dossiers.state_instruction_commencee.count],
['Traités', procedure.dossiers.state_termine.count]
]
@termines_states = [
['Acceptés', procedure.dossiers.where(state: :accepte).count],
['Refusés', procedure.dossiers.where(state: :refuse).count],
['Classés sans suite', procedure.dossiers.where(state: :sans_suite).count]
]
end
private
2019-02-13 18:24:41 +01:00
def find_field(table, column)
procedure_presentation.fields.find { |c| c['table'] == table && c['column'] == column }
end
2019-02-13 17:50:33 +01:00
def field_id(field)
2019-02-13 17:53:41 +01:00
field.values_at('table', 'column').join('/')
2019-02-13 17:50:33 +01:00
end
2019-03-13 17:37:07 +01:00
def assign_to
current_instructeur.assign_to.joins(:groupe_instructeur).find_by(groupe_instructeurs: { procedure: procedure })
2019-03-13 17:37:07 +01:00
end
2017-09-28 19:07:18 +02:00
def statut
2018-03-06 13:44:29 +01:00
@statut ||= (params[:statut].presence || 'a-suivre')
2017-09-28 19:07:18 +02:00
end
def procedure
Procedure.find(params[:procedure_id])
end
def ensure_ownership!
if !procedure.defaut_groupe_instructeur.instructeurs.include?(current_instructeur)
2018-09-05 14:48:42 +02:00
flash[:alert] = "Vous n'avez pas accès à cette démarche"
redirect_to root_path
end
end
def redirect_to_avis_if_needed
if current_instructeur.procedures.count == 0 && current_instructeur.avis.count > 0
redirect_to instructeur_avis_index_path
end
end
def procedure_presentation
@procedure_presentation ||= get_procedure_presentation
end
def get_procedure_presentation
procedure_presentation, errors = current_instructeur.procedure_presentation_and_errors_for_procedure_id(params[:procedure_id])
if errors.present?
flash[:alert] = "Votre affichage a dû être réinitialisé en raison du problème suivant : " + errors.full_messages.join(', ')
end
procedure_presentation
end
def displayed_fields_values
2019-02-13 17:50:33 +01:00
procedure_presentation.displayed_fields.map { |field| field_id(field) }
end
2017-09-28 11:04:18 +02:00
def current_filters
@current_filters ||= procedure_presentation.filters[statut]
end
def available_fields_to_filters
procedure_presentation.fields_for_select
2017-09-28 11:04:18 +02:00
end
2017-09-27 15:16:07 +02:00
def kaminarize(current_page, total)
@dossiers.instance_eval <<-EVAL
def current_page
#{current_page}
end
2017-09-27 15:16:07 +02:00
def total_pages
(#{total} / #{ITEMS_PER_PAGE}.to_f).ceil
end
def limit_value
2017-09-27 15:16:07 +02:00
#{ITEMS_PER_PAGE}
end
def first_page?
current_page == 1
end
def last_page?
current_page == total_pages
end
EVAL
end
end
end