demarches-normaliennes/app/models/concerns/columns_concern.rb

117 lines
4.3 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
2024-08-19 14:34:36 +02:00
module ColumnsConcern
extend ActiveSupport::Concern
included do
2024-10-09 09:21:44 +02:00
# we cannot use column.id ( == { procedure_id, column_id }.to_json)
# as the order of the keys is not guaranteed
# instead, we are using h_id == { procedure_id:, column_id: }
# another way to find a column is to look for its label
def find_column(h_id: nil, label: nil)
column = columns.find { _1.h_id == h_id } if h_id.present?
column = columns.find { _1.label == label } if label.present?
2024-10-11 11:23:36 +02:00
raise ActiveRecord::RecordNotFound.new("Column: unable to find h_id: #{h_id} or label: #{label} for procedure_id #{id}") if column.nil?
column
end
2024-08-19 14:34:36 +02:00
def columns
Current.procedure_columns ||= {}
Current.procedure_columns[id] ||= begin
columns = dossier_columns
columns.concat(standard_columns)
columns.concat(individual_columns) if for_individual
columns.concat(moral_columns) if !for_individual
columns.concat(types_de_champ_columns)
end
2024-08-19 14:34:36 +02:00
end
def dossier_id_column
Column.new(procedure_id: id, table: 'self', column: 'id', type: :number)
end
2024-10-09 15:16:13 +02:00
def dossier_state_column
Column.new(procedure_id: id, table: 'self', column: 'state', type: :enum, scope: 'instructeurs.dossiers.filterable_state', displayable: false)
end
def notifications_column
2024-10-07 21:46:59 +02:00
Column.new(procedure_id: id, table: 'notifications', column: 'notifications', label: "notifications", filterable: false)
end
2024-08-19 14:34:36 +02:00
def dossier_columns
common = [dossier_id_column, notifications_column]
2024-08-19 14:34:36 +02:00
dates = ['created_at', 'updated_at', 'depose_at', 'en_construction_at', 'en_instruction_at', 'processed_at']
2024-10-07 21:46:59 +02:00
.map { |column| Column.new(procedure_id: id, table: 'self', column:, type: :date) }
2024-08-19 14:34:36 +02:00
non_displayable_dates = ['updated_since', 'depose_since', 'en_construction_since', 'en_instruction_since', 'processed_since']
2024-10-07 21:46:59 +02:00
.map { |column| Column.new(procedure_id: id, table: 'self', column:, type: :date, displayable: false) }
2024-08-19 14:34:36 +02:00
2024-10-09 15:16:13 +02:00
states = [dossier_state_column]
2024-08-19 14:34:36 +02:00
[common, dates, sva_svr_columns(for_filters: true), non_displayable_dates, states].flatten.compact
2024-08-19 14:34:36 +02:00
end
def sva_svr_columns(for_filters: false)
return if !sva_svr_enabled?
scope = [:activerecord, :attributes, :procedure_presentation, :fields, :self]
columns = [
2024-10-07 21:46:59 +02:00
Column.new(procedure_id: id, table: 'self', column: 'sva_svr_decision_on', type: :date,
2024-08-19 14:34:36 +02:00
label: I18n.t("#{sva_svr_decision}_decision_on", scope:), classname: for_filters ? '' : 'sva-col')
]
if for_filters
2024-10-07 21:46:59 +02:00
columns << Column.new(procedure_id: id, table: 'self', column: 'sva_svr_decision_before', type: :date, displayable: false,
2024-08-19 14:34:36 +02:00
label: I18n.t("#{sva_svr_decision}_decision_before", scope:))
end
columns
end
2024-09-25 17:37:11 +02:00
def default_sorted_column
SortedColumn.new(column: notifications_column, order: 'desc')
end
2024-10-09 11:08:41 +02:00
def default_displayed_columns = [email_column]
2024-08-19 14:34:36 +02:00
private
2024-10-09 11:08:41 +02:00
def email_column
Column.new(procedure_id: id, table: 'user', column: 'email')
end
2024-08-19 14:34:36 +02:00
def standard_columns
[
2024-10-09 11:08:41 +02:00
email_column,
2024-10-07 21:46:59 +02:00
Column.new(procedure_id: id, table: 'followers_instructeurs', column: 'email'),
Column.new(procedure_id: id, table: 'groupe_instructeur', column: 'id', type: :enum),
Column.new(procedure_id: id, table: 'avis', column: 'question_answer', filterable: false) # not filterable ?
2024-08-19 14:34:36 +02:00
]
end
def individual_columns
2024-10-07 21:46:59 +02:00
['nom', 'prenom', 'gender'].map { |column| Column.new(procedure_id: id, table: 'individual', column:) }
2024-08-19 14:34:36 +02:00
end
def moral_columns
etablissements = ['entreprise_siren', 'entreprise_forme_juridique', 'entreprise_nom_commercial', 'entreprise_raison_sociale', 'entreprise_siret_siege_social']
2024-10-07 21:46:59 +02:00
.map { |column| Column.new(procedure_id: id, table: 'etablissement', column:) }
2024-08-19 14:34:36 +02:00
2024-10-07 21:46:59 +02:00
etablissement_dates = ['entreprise_date_creation'].map { |column| Column.new(procedure_id: id, table: 'etablissement', column:, type: :date) }
2024-08-19 14:34:36 +02:00
2024-10-07 21:46:59 +02:00
other = ['siret', 'libelle_naf', 'code_postal'].map { |column| Column.new(procedure_id: id, table: 'etablissement', column:) }
2024-08-19 14:34:36 +02:00
[etablissements, etablissement_dates, other].flatten
end
def types_de_champ_columns
2024-10-07 21:46:59 +02:00
all_revisions_types_de_champ.flat_map { _1.columns(procedure_id: id) }
2024-08-19 14:34:36 +02:00
end
end
end