2018-12-18 11:17:52 +01:00
|
|
|
|
class Champs::RepetitionChamp < Champ
|
|
|
|
|
accepts_nested_attributes_for :champs, allow_destroy: true
|
|
|
|
|
|
|
|
|
|
def rows
|
|
|
|
|
champs.group_by(&:row).values
|
|
|
|
|
end
|
|
|
|
|
|
2019-01-30 16:14:15 +01:00
|
|
|
|
def add_row(row = 0)
|
|
|
|
|
type_de_champ.types_de_champ.each do |type_de_champ|
|
|
|
|
|
self.champs << type_de_champ.champ.build(row: row)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def mandatory_and_blank?
|
|
|
|
|
mandatory? && champs.empty?
|
|
|
|
|
end
|
|
|
|
|
|
2018-12-18 11:17:52 +01:00
|
|
|
|
def search_terms
|
|
|
|
|
# The user cannot enter any information here so it doesn’t make much sense to search
|
|
|
|
|
end
|
2019-04-03 14:29:30 +02:00
|
|
|
|
|
2019-07-11 10:28:44 +02:00
|
|
|
|
def rows_for_export
|
|
|
|
|
rows.each.with_index(1).map do |champs, index|
|
|
|
|
|
Champs::RepetitionChamp::Row.new(index: index, dossier_id: dossier_id.to_s, champs: champs)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2019-04-03 14:29:30 +02:00
|
|
|
|
class Row < Hashie::Dash
|
|
|
|
|
property :index
|
|
|
|
|
property :dossier_id
|
|
|
|
|
property :champs
|
|
|
|
|
|
2019-07-11 10:28:44 +02:00
|
|
|
|
def read_attribute_for_serialization(attribute)
|
|
|
|
|
self[attribute]
|
|
|
|
|
end
|
|
|
|
|
|
2019-04-03 14:29:30 +02:00
|
|
|
|
def spreadsheet_columns
|
|
|
|
|
[
|
|
|
|
|
['Dossier ID', :dossier_id],
|
|
|
|
|
['Ligne', :index]
|
|
|
|
|
] + exported_champs
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
|
|
def exported_champs
|
|
|
|
|
champs.reject(&:exclude_from_export?).map do |champ|
|
|
|
|
|
[champ.libelle, champ.for_export]
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
2018-12-18 11:17:52 +01:00
|
|
|
|
end
|