2016-08-11 15:27:35 +02:00
|
|
|
class DossiersListFacades
|
2016-09-06 14:07:07 +02:00
|
|
|
include Rails.application.routes.url_helpers
|
|
|
|
|
2016-12-16 14:40:41 +01:00
|
|
|
attr_accessor :procedure, :current_devise_profil, :liste
|
2016-11-24 19:33:34 +01:00
|
|
|
|
2016-09-06 11:07:26 +02:00
|
|
|
def initialize current_devise_profil, liste, procedure = nil
|
2016-08-11 15:27:35 +02:00
|
|
|
@current_devise_profil = current_devise_profil
|
|
|
|
@liste = liste
|
2016-09-06 11:07:26 +02:00
|
|
|
@procedure = procedure
|
2016-08-11 15:27:35 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def service
|
2017-04-20 10:55:54 +02:00
|
|
|
@service ||= DossiersListGestionnaireService.new @current_devise_profil, @liste, @procedure
|
2016-08-12 13:56:10 +02:00
|
|
|
end
|
|
|
|
|
2016-11-29 09:56:11 +01:00
|
|
|
def total_dossier
|
|
|
|
current_devise_profil.dossiers.where(archived: false).count
|
|
|
|
end
|
|
|
|
|
2017-01-05 18:01:53 +01:00
|
|
|
def total_dossier_follow
|
|
|
|
@current_devise_profil.dossiers_follow.count
|
|
|
|
end
|
|
|
|
|
2016-11-29 09:56:11 +01:00
|
|
|
def total_new_dossier
|
|
|
|
current_devise_profil.dossiers.where(state: :initiated, archived: false).count
|
|
|
|
end
|
|
|
|
|
2016-12-27 11:06:09 +01:00
|
|
|
def new_dossier_number procedure_id
|
|
|
|
current_devise_profil.dossiers.where(state: :initiated, archived: false, procedure_id: procedure_id).count
|
|
|
|
end
|
|
|
|
|
2016-09-09 17:29:21 +02:00
|
|
|
def gestionnaire_procedures_name_and_id_list
|
2017-05-12 11:35:01 +02:00
|
|
|
@current_devise_profil.procedures.order('libelle ASC').inject([]) { |acc, procedure| acc.push({id: procedure.id, libelle: procedure.libelle, unread_notifications: @current_devise_profil.dossiers_with_notifications_count_for_procedure(procedure)}) }
|
2016-12-27 10:47:23 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def unread_notifications
|
2016-12-27 10:57:21 +01:00
|
|
|
current_devise_profil.notifications
|
2016-09-09 17:29:21 +02:00
|
|
|
end
|
|
|
|
|
2017-01-02 15:10:53 +01:00
|
|
|
def dossiers_with_unread_notifications
|
|
|
|
(unread_notifications.inject([]) { |acc, notif| acc.push(notif.dossier) }).uniq
|
|
|
|
end
|
|
|
|
|
2016-09-08 16:21:54 +02:00
|
|
|
def procedure_id
|
|
|
|
@procedure.nil? ? nil : @procedure.id
|
|
|
|
end
|
|
|
|
|
2016-08-11 15:27:35 +02:00
|
|
|
def dossiers_to_display
|
2016-10-24 16:00:03 +02:00
|
|
|
service.dossiers_to_display
|
2016-08-11 15:27:35 +02:00
|
|
|
end
|
|
|
|
|
2016-09-08 16:21:54 +02:00
|
|
|
def preference_list_dossiers_filter
|
|
|
|
@list_table_columns ||= @current_devise_profil.preference_list_dossiers.where(procedure: @procedure).order(:id)
|
|
|
|
end
|
|
|
|
|
2016-10-14 12:02:39 +02:00
|
|
|
def active_filter? preference
|
|
|
|
return true if @procedure.nil? || preference.table != 'champs' || (preference.table == 'champs' && !preference.filter.blank?)
|
|
|
|
|
|
|
|
preference_list_dossiers_filter.where(table: :champs).where.not(filter: '').size == 0
|
|
|
|
end
|
|
|
|
|
2016-11-24 19:33:34 +01:00
|
|
|
def all_state_total
|
|
|
|
service.all_state.count
|
|
|
|
end
|
|
|
|
|
2016-08-11 15:27:35 +02:00
|
|
|
def nouveaux_total
|
|
|
|
service.nouveaux.count
|
|
|
|
end
|
|
|
|
|
|
|
|
def suivi_total
|
|
|
|
service.suivi.count
|
|
|
|
end
|
2016-08-12 13:56:10 +02:00
|
|
|
|
2016-10-04 19:19:03 +02:00
|
|
|
def filter_url
|
|
|
|
@procedure.nil? ? backoffice_dossiers_filter_path(liste: liste) : backoffice_dossiers_procedure_filter_path(id: @procedure.id, liste: liste)
|
|
|
|
end
|
|
|
|
|
2016-08-12 13:56:10 +02:00
|
|
|
private
|
|
|
|
|
2016-09-06 14:07:07 +02:00
|
|
|
def base_url liste
|
|
|
|
@procedure.nil? ? backoffice_dossiers_path(liste: liste) : backoffice_dossiers_procedure_path(id: @procedure.id, liste: liste)
|
|
|
|
end
|
2016-10-24 16:00:03 +02:00
|
|
|
|
2016-12-27 15:26:41 +01:00
|
|
|
end
|