2019-09-17 15:52:38 +02:00
|
|
|
module ProcedureStatsConcern
|
|
|
|
extend ActiveSupport::Concern
|
|
|
|
|
2021-06-16 14:57:42 +02:00
|
|
|
NB_DAYS_RECENT_DOSSIERS = 30
|
|
|
|
PERCENTILE = 90
|
|
|
|
|
2019-09-17 15:52:38 +02:00
|
|
|
def stats_usual_traitement_time
|
|
|
|
Rails.cache.fetch("#{cache_key_with_version}/stats_usual_traitement_time", expires_in: 12.hours) do
|
2021-06-16 14:57:42 +02:00
|
|
|
usual_traitement_time_for_recent_dossiers(NB_DAYS_RECENT_DOSSIERS)
|
2019-09-17 15:52:38 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-06-04 16:19:19 +02:00
|
|
|
def stats_usual_traitement_time_by_month_in_days
|
|
|
|
Rails.cache.fetch("#{cache_key_with_version}/stats_usual_traitement_time_by_month_in_days", expires_in: 12.hours) do
|
|
|
|
usual_traitement_time_by_month_in_days
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-09-17 15:52:38 +02:00
|
|
|
def stats_dossiers_funnel
|
|
|
|
Rails.cache.fetch("#{cache_key_with_version}/stats_dossiers_funnel", expires_in: 12.hours) do
|
|
|
|
[
|
|
|
|
['Démarrés', dossiers.count],
|
|
|
|
['Déposés', dossiers.state_not_brouillon.count],
|
|
|
|
['Instruction débutée', dossiers.state_instruction_commencee.count],
|
|
|
|
['Traités', dossiers.state_termine.count]
|
|
|
|
]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def stats_termines_states
|
|
|
|
Rails.cache.fetch("#{cache_key_with_version}/stats_termines_states", expires_in: 12.hours) do
|
|
|
|
[
|
|
|
|
['Acceptés', dossiers.where(state: :accepte).count],
|
|
|
|
['Refusés', dossiers.where(state: :refuse).count],
|
|
|
|
['Classés sans suite', dossiers.where(state: :sans_suite).count]
|
|
|
|
]
|
|
|
|
end
|
|
|
|
end
|
2021-06-02 12:47:07 +02:00
|
|
|
|
|
|
|
def stats_termines_by_week
|
|
|
|
Rails.cache.fetch("#{cache_key_with_version}/stats_termines_by_week", expires_in: 12.hours) do
|
|
|
|
now = Time.zone.now
|
2021-06-08 15:03:06 +02:00
|
|
|
chart_data = dossiers.includes(:traitements)
|
2021-06-02 12:47:07 +02:00
|
|
|
.state_termine
|
|
|
|
.where(traitements: { processed_at: (now.beginning_of_week - 6.months)..now.end_of_week })
|
|
|
|
|
|
|
|
dossier_state_values = chart_data.pluck(:state).sort.uniq
|
|
|
|
|
|
|
|
# rubocop:disable Style/HashTransformValues
|
|
|
|
dossier_state_values
|
|
|
|
.map do |state|
|
|
|
|
{ name: state, data: chart_data.where(state: state).group_by_week { |dossier| dossier.traitements.first.processed_at }.map { |k, v| [k, v.count] }.to_h }
|
|
|
|
# rubocop:enable Style/HashTransformValues
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2021-06-15 11:33:17 +02:00
|
|
|
|
2021-06-16 10:51:56 +02:00
|
|
|
def traitement_times(date_range)
|
|
|
|
Traitement.for_traitement_time_stats(self)
|
|
|
|
.where(processed_at: date_range)
|
|
|
|
.pluck('dossiers.en_construction_at', :processed_at)
|
|
|
|
.map{|en_construction_at, processed_at| { en_construction_at: en_construction_at, processed_at: processed_at }}
|
|
|
|
end
|
|
|
|
|
|
|
|
def usual_traitement_time_by_month_in_days
|
|
|
|
traitement_times(first_processed_at..last_considered_processed_at)
|
|
|
|
.group_by {|t| t[:processed_at].beginning_of_month }
|
|
|
|
.transform_values{|month| month.map{|h| h[:processed_at] - h[:en_construction_at]}}
|
2021-06-16 14:57:42 +02:00
|
|
|
.transform_values{|traitement_times_for_month| traitement_times_for_month.percentile(PERCENTILE).ceil }
|
2021-06-16 10:51:56 +02:00
|
|
|
.transform_values{|seconds| convert_seconds_in_days(seconds)}
|
|
|
|
.transform_keys{|month| pretty_month(month)}
|
|
|
|
end
|
|
|
|
|
2021-06-16 13:23:03 +02:00
|
|
|
def usual_traitement_time_for_recent_dossiers(nb_days)
|
|
|
|
now = Time.zone.now
|
|
|
|
traitement_times((now - nb_days.days)..now)
|
|
|
|
.map{|times| times[:processed_at] - times[:en_construction_at]}
|
2021-06-16 14:57:42 +02:00
|
|
|
.percentile(PERCENTILE)
|
2021-06-16 13:23:03 +02:00
|
|
|
.ceil
|
2021-06-15 11:33:17 +02:00
|
|
|
end
|
|
|
|
|
2021-06-16 10:51:56 +02:00
|
|
|
private
|
|
|
|
def first_processed_at
|
|
|
|
Traitement.for_traitement_time_stats(self).pick(:processed_at)
|
|
|
|
end
|
2021-06-15 11:33:17 +02:00
|
|
|
|
2021-06-16 10:51:56 +02:00
|
|
|
def last_considered_processed_at
|
|
|
|
(Time.zone.now - 1.month).end_of_month
|
2021-06-15 11:33:17 +02:00
|
|
|
end
|
|
|
|
|
2021-06-16 10:51:56 +02:00
|
|
|
def convert_seconds_in_days(seconds)
|
|
|
|
(seconds / 60.0 / 60.0 / 24.0).ceil
|
|
|
|
end
|
|
|
|
|
|
|
|
def pretty_month(month)
|
|
|
|
I18n.l(month, format: "%B %Y")
|
2021-06-15 11:33:17 +02:00
|
|
|
end
|
|
|
|
|
2019-09-17 15:52:38 +02:00
|
|
|
end
|