Factorize code in a method
This commit is contained in:
parent
6b98c36dad
commit
8ea021fb69
1 changed files with 14 additions and 24 deletions
|
@ -327,36 +327,15 @@ class Procedure < ApplicationRecord
|
||||||
end
|
end
|
||||||
|
|
||||||
def mean_traitement_time
|
def mean_traitement_time
|
||||||
traitement_times = dossiers
|
mean_time(:en_construction_at, :processed_at)
|
||||||
.state_termine
|
|
||||||
.pluck(:en_construction_at, :processed_at)
|
|
||||||
.map { |times| times[1] - times[0] }
|
|
||||||
|
|
||||||
if traitement_times.present?
|
|
||||||
traitement_times.sum.fdiv(traitement_times.size).ceil
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def mean_verification_time
|
def mean_verification_time
|
||||||
verification_times = dossiers
|
mean_time(:en_construction_at, :en_instruction_at)
|
||||||
.state_termine
|
|
||||||
.pluck(:en_construction_at, :en_instruction_at)
|
|
||||||
.map { |times| times[1] - times[0] }
|
|
||||||
|
|
||||||
if verification_times.present?
|
|
||||||
verification_times.sum.fdiv(verification_times.size).ceil
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def mean_instruction_time
|
def mean_instruction_time
|
||||||
instruction_times = dossiers
|
mean_time(:en_instruction_at, :processed_at)
|
||||||
.state_termine
|
|
||||||
.pluck(:en_instruction_at, :processed_at)
|
|
||||||
.map { |times| times[1] - times[0] }
|
|
||||||
|
|
||||||
if instruction_times.present?
|
|
||||||
instruction_times.sum.fdiv(instruction_times.size).ceil
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
@ -421,4 +400,15 @@ class Procedure < ApplicationRecord
|
||||||
self.durees_conservation_required ||= duree_conservation_dossiers_hors_ds.present? && duree_conservation_dossiers_dans_ds.present?
|
self.durees_conservation_required ||= duree_conservation_dossiers_hors_ds.present? && duree_conservation_dossiers_dans_ds.present?
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def mean_time(start_attribute, end_attribute)
|
||||||
|
times = dossiers
|
||||||
|
.state_termine
|
||||||
|
.pluck(start_attribute, end_attribute)
|
||||||
|
.map { |times| times[1] - times[0] }
|
||||||
|
|
||||||
|
if times.present?
|
||||||
|
times.sum.fdiv(times.size).ceil
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue