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

201 lines
7.9 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?
# TODO: to remove after linked_drop_down column column_id migration
if column.nil? && h_id.is_a?(Hash) && h_id[:column_id].present?
h_id[:column_id].gsub!('->', '.')
column = columns.find { _1.h_id == h_id }
end
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
2024-10-30 16:09:40 +01:00
columns.concat(procedure_chorus_columns) if chorusable? && chorus_configuration.complete?
columns.concat(types_de_champ_columns)
end
2024-08-19 14:34:36 +02:00
end
def usager_columns_for_export
columns = [dossier_id_column, user_email_for_display_column, user_france_connected_column]
columns.concat(individual_columns) if for_individual
columns.concat(moral_columns) if !for_individual
columns.concat(procedure_chorus_columns) if chorusable? && chorus_configuration.complete?
# ensure the columns exist in main list
# otherwise, they will be found by the find_column method
columns.filter { _1.id.in?(self.columns.map(&:id)) }
end
def dossier_columns_for_export
columns = [dossier_state_column, dossier_archived_column]
columns.concat(dossier_dates_columns)
columns.concat([dossier_motivation_column])
columns.concat(sva_svr_columns(for_export: true)) if sva_svr_enabled?
columns.concat([groupe_instructeurs_id_column, followers_instructeurs_email_column])
# ensure the columns exist in main list
# otherwise, they will be found by the find_column method
columns.filter { _1.id.in?(self.columns.map(&:id)) }
end
def dossier_id_column = dossier_col(table: 'self', column: 'id', type: :integer)
2024-10-30 15:58:08 +01:00
2024-11-06 16:24:29 +01:00
def dossier_state_column
options_for_select = I18n.t('instructeurs.dossiers.filterable_state').map(&:to_a).map(&:reverse)
2024-11-06 21:18:31 +01:00
dossier_col(table: 'self', column: 'state', type: :enum, options_for_select:, displayable: false)
2024-11-06 16:24:29 +01:00
end
2024-10-30 15:58:08 +01:00
2024-11-06 21:18:31 +01:00
def notifications_column = dossier_col(table: 'notifications', column: 'notifications', label: "notifications", filterable: false)
2024-10-30 15:58:08 +01:00
def sva_svr_columns(for_export: false)
scope = [:activerecord, :attributes, :procedure_presentation, :fields, :self]
columns = [
2024-11-06 21:18:31 +01:00
dossier_col(table: 'self', column: 'sva_svr_decision_on', type: :date,
2024-10-30 15:58:08 +01:00
label: I18n.t("#{sva_svr_decision}_decision_on", scope:, type: sva_svr_configuration.human_decision))
]
if !for_export
2024-11-06 21:18:31 +01:00
columns << dossier_col(table: 'self', column: 'sva_svr_decision_before', type: :date, displayable: false,
2024-10-30 15:58:08 +01:00
label: I18n.t("#{sva_svr_decision}_decision_before", scope:))
end
columns
end
def default_sorted_column
SortedColumn.new(column: notifications_column, order: 'desc')
end
2024-10-30 15:58:08 +01:00
def default_displayed_columns = [email_column]
private
def groupe_instructeurs_id_column = dossier_col(table: 'groupe_instructeur', column: 'id', type: :enum)
2024-11-06 21:18:31 +01:00
def followers_instructeurs_email_column = dossier_col(table: 'followers_instructeurs', column: 'email')
def dossier_archived_column = dossier_col(table: 'self', column: 'archived', type: :boolean, displayable: false, filterable: false);
2024-11-06 21:18:31 +01:00
def dossier_motivation_column = dossier_col(table: 'self', column: 'motivation', type: :text, displayable: false, filterable: false);
2024-10-09 15:16:13 +02:00
2024-11-06 21:18:31 +01:00
def user_email_for_display_column = dossier_col(table: 'self', column: 'user_email_for_display', filterable: false, displayable: false)
def user_france_connected_column = dossier_col(table: 'self', column: 'user_from_france_connect?', type: :boolean, filterable: false, displayable: false)
2024-11-06 21:18:31 +01:00
def dossier_labels_column = dossier_col(table: 'dossier_labels', column: 'label_id', type: :enum, options_for_select: labels.map { [_1.name, _1.id] })
2024-10-07 16:52:27 +02:00
def procedure_chorus_columns
['domaine_fonctionnel', 'referentiel_prog', 'centre_de_cout']
2024-11-06 21:18:31 +01:00
.map { |column| dossier_col(table: 'procedure', column:, displayable: false, filterable: false) }
end
def dossier_non_displayable_dates_columns
['updated_since', 'depose_since', 'en_construction_since', 'en_instruction_since', 'processed_since']
2024-11-06 21:18:31 +01:00
.map { |column| dossier_col(table: 'self', column:, type: :date, displayable: false) }
2024-08-19 14:34:36 +02:00
end
def dossier_dates_columns
['created_at', 'updated_at', 'last_champ_updated_at', 'depose_at', 'en_construction_at', 'en_instruction_at', 'processed_at']
.map { |column| dossier_col(table: 'self', column:, type: :datetime) }
end
2024-10-09 11:08:41 +02:00
def email_column
2024-11-06 21:18:31 +01:00
dossier_col(table: 'user', column: 'email')
2024-10-09 11:08:41 +02:00
end
2024-10-30 15:58:08 +01:00
def dossier_columns
columns = [dossier_id_column, notifications_column]
columns.concat([dossier_state_column])
columns.concat([dossier_archived_column])
columns.concat(dossier_dates_columns)
columns.concat([dossier_motivation_column])
columns.concat(sva_svr_columns(for_export: false)) if sva_svr_enabled?
columns.concat(dossier_non_displayable_dates_columns)
end
2024-08-19 14:34:36 +02:00
def standard_columns
[
2024-10-09 11:08:41 +02:00
email_column,
user_email_for_display_column,
followers_instructeurs_email_column,
groupe_instructeurs_id_column,
2024-11-06 21:18:31 +01:00
dossier_col(table: 'avis', column: 'question_answer', filterable: false),
2024-10-07 16:52:27 +02:00
user_france_connected_column,
dossier_labels_column
2024-08-19 14:34:36 +02:00
]
end
def individual_columns
2024-11-06 21:18:31 +01:00
['gender', 'nom', 'prenom'].map { |column| dossier_col(table: 'individual', column:) }
.concat ['mandataire_last_name', 'mandataire_first_name'].map { |column| dossier_col(table: 'self', column:) }
.concat ['for_tiers'].map { |column| dossier_col(table: 'self', column:, type: :boolean) }
2024-08-19 14:34:36 +02:00
end
def moral_columns
siret_column = dossier_col(table: 'etablissement', column: :siret)
etablissements = Etablissement::DISPLAYABLE_COLUMNS.map do |(column, attributes)|
dossier_col(table: 'etablissement', column:, type: attributes[:type], filterable: attributes.fetch(:filterable, true))
end
2024-08-19 14:34:36 +02:00
others = %w[code_postal].map { |column| dossier_col(table: 'etablissement', column:) }
for_export = %w[
siege_social
code_naf
adresse
numero_voie
type_voie
nom_voie
complement_adresse
localite
code_insee_localite
entreprise_capital_social
entreprise_numero_tva_intracommunautaire
entreprise_forme_juridique_code
entreprise_code_effectif_entreprise
entreprise_etat_administratif
entreprise_siret_siege_social
entreprise_nom
entreprise_prenom
association_rna
association_titre
association_objet
association_date_creation
association_date_declaration
association_date_publication
].map { |column| dossier_col(table: 'etablissement', column:, displayable: false, filterable: false) }
[siret_column, etablissements, others, for_export].flatten
2024-08-19 14:34:36 +02:00
end
def types_de_champ_columns
all_revisions_types_de_champ.flat_map { _1.columns(procedure: self) }
2024-08-19 14:34:36 +02:00
end
2024-11-06 21:18:31 +01:00
def dossier_col(**args) = Columns::DossierColumn.new(**(args.merge(procedure_id: id)))
2024-08-19 14:34:36 +02:00
end
end