Skip to content

Commit

Permalink
glipse of a possible future
Browse files Browse the repository at this point in the history
  • Loading branch information
LeSim committed Nov 18, 2024
1 parent 10c3b0a commit dae046c
Showing 1 changed file with 2 additions and 140 deletions.
142 changes: 2 additions & 140 deletions app/services/dossier_projection_service.rb
Original file line number Diff line number Diff line change
Expand Up @@ -44,149 +44,11 @@ def self.for_tiers_translation(array)
def self.project(dossiers_ids, columns)
tableau = Tableau.new(dossiers_ids, columns)
tableau.dossiers = Dossier.find(dossiers_ids)

Check warning on line 46 in app/services/dossier_projection_service.rb

View check run for this annotation

Codecov / codecov/patch

app/services/dossier_projection_service.rb#L45-L46

Added lines #L45 - L46 were not covered by tests

columns.group_by(&:loader).map do |loader, columns|
tableau.add_data(loader.load(columns, dossiers_ids))

Check warning on line 49 in app/services/dossier_projection_service.rb

View check run for this annotation

Codecov / codecov/patch

app/services/dossier_projection_service.rb#L48-L49

Added lines #L48 - L49 were not covered by tests
end

return tableau

fields = columns.map do |c|
if c.is_a?(Columns::ChampColumn)
{ TABLE => c.table, STABLE_ID => c.stable_id, original_column: c }
else
{ TABLE => c.table, COLUMN => c.column }
end
end

# individual_first_name = { TABLE => 'individual', COLUMN => 'prenom' }
# individual_last_name = { TABLE => 'individual', COLUMN => 'nom' }
# dossier_corrections = { TABLE => 'dossier_corrections', COLUMN => 'resolved_at' }

# ([individual_first_name, individual_last_name, dossier_corrections] + fields)
fields
.each { |f| f[:id_value_h] = {} }
.group_by { |f| f[TABLE] } # one query per table
.each do |table, fields|
case table
when 'type_de_champ'
Champ
.where(
stable_id: fields.map { |f| f[STABLE_ID] },
dossier_id: dossiers_ids
)
.select(:dossier_id, :value, :stable_id, :type, :external_id, :data, :value_json) # we cannot pluck :value, as we need the champ.to_s method
.group_by(&:stable_id) # the champs are redispatched to their respective fields
.map do |stable_id, champs|
fields
.filter { |f| f[STABLE_ID] == stable_id }
.each do |field|
field[:id_value_h] = champs.to_h do |c|
raw_value = field[:original_column].value(c)
value = ExportedColumnFormatter.format(column: field[:original_column], raw_value:, format: :view)
[c.dossier_id, value]
end
end
end
when 'self'
Dossier
.where(id: dossiers_ids)
.pluck(:id, *fields.map { |f| f[COLUMN].to_sym })
.each do |id, *columns|
fields.zip(columns).each do |field, value|
# SVA must remain a date: in other column we compute remaining delay with it
field[:id_value_h][id] = if value.respond_to?(:strftime) && field != sva_svr_decision_on_field
I18n.l(value.to_date)
else
value
end
end
end
when 'individual'
Individual
.where(dossier_id: dossiers_ids)
.pluck(:dossier_id, *fields.map { |f| f[COLUMN].to_sym })
.each { |id, *columns| fields.zip(columns).each { |field, value| field[:id_value_h][id] = value } }
when 'etablissement'
Etablissement
.where(dossier_id: dossiers_ids)
.pluck(:dossier_id, *fields.map { |f| f[COLUMN].to_sym })
.each { |id, *columns| fields.zip(columns).each { |field, value| field[:id_value_h][id] = value } }
when 'user'

fields[0][:id_value_h] = Dossier # there is only one field available for user table
.joins(:user)
.includes(:individual)
.where(id: dossiers_ids)
.pluck('dossiers.id, dossiers.for_tiers, users.email, individuals.prenom, individuals.nom')
.to_h { |dossier_id, *array| [dossier_id, for_tiers_translation(array)] }
when 'groupe_instructeur'
fields[0][:id_value_h] = Dossier
.joins(:groupe_instructeur)
.where(id: dossiers_ids)
.pluck('dossiers.id, groupe_instructeurs.label')
.to_h
when 'dossier_corrections'
columns = fields.map { _1[COLUMN].to_sym }

id_value_h = DossierCorrection.where(dossier_id: dossiers_ids)
.pluck(:dossier_id, *columns)
.group_by(&:first) # group corrections by dossier_id
.transform_values do |values| # build each correction has an hash column => value
values.map { Hash[columns.zip(_1[1..-1])] }
end

fields[0][:id_value_h] = id_value_h

when 'dossier_labels'
columns = fields.map { _1[COLUMN].to_sym }

id_value_h =
DossierLabel
.includes(:label)
.where(dossier_id: dossiers_ids)
.pluck('dossier_id, labels.name, labels.color')
.group_by { |dossier_id, _| dossier_id }

fields[0][:id_value_h] = id_value_h.transform_values { |v| { value: v, type: :label } }

when 'procedure'
Dossier
.joins(:procedure)
.where(id: dossiers_ids)
.pluck(:id, *fields.map { |f| f[COLUMN].to_sym })
.each { |id, *columns| fields.zip(columns).each { |field, value| field[:id_value_h][id] = value } }
when 'followers_instructeurs'
# rubocop:disable Style/HashTransformValues
fields[0][:id_value_h] = Follow
.active
.joins(instructeur: :user)
.where(dossier_id: dossiers_ids)
.pluck('dossier_id, users.email')
.group_by { |dossier_id, _| dossier_id }
.to_h { |dossier_id, dossier_id_emails| [dossier_id, dossier_id_emails.sort.map { |_, email| email }&.join(', ')] }
# rubocop:enable Style/HashTransformValues
when 'avis'
# rubocop:disable Style/HashTransformValues
fields[0][:id_value_h] = Avis
.where(dossier_id: dossiers_ids)
.pluck('dossier_id', 'question_answer')
.group_by { |dossier_id, _| dossier_id }
.to_h { |dossier_id, question_answer| [dossier_id, question_answer.map { |_, answer| answer }&.compact&.tally&.map { |k, v| I18n.t("helpers.label.question_answer_with_count.#{k}", count: v) }&.join(' / ')] }
# rubocop:enable Style/HashTransformValues
end
end

dossiers = Dossier.find(dossiers_ids)

dossiers_ids.map do |dossier_id|
DossierProjection.new(
dossiers.find { _1.id == dossier_id },
dossier_id,
nil, #individual_first_name[:id_value_h][dossier_id],
nil, #individual_last_name[:id_value_h][dossier_id],
nil, #dossier_corrections[:id_value_h][dossier_id],
fields.map { |f| f[:id_value_h][dossier_id] }
)
end
tableau

Check warning on line 52 in app/services/dossier_projection_service.rb

View check run for this annotation

Codecov / codecov/patch

app/services/dossier_projection_service.rb#L52

Added line #L52 was not covered by tests
end
end

0 comments on commit dae046c

Please sign in to comment.