2020-08-06 16:35:45 +02:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: champs
|
|
|
|
#
|
2021-02-04 19:23:40 +01:00
|
|
|
# id :integer not null, primary key
|
|
|
|
# data :jsonb
|
|
|
|
# fetch_external_data_exceptions :string is an Array
|
2022-12-01 12:00:21 +01:00
|
|
|
# prefilled :boolean default(FALSE)
|
2021-02-04 19:23:40 +01:00
|
|
|
# private :boolean default(FALSE), not null
|
2021-10-20 17:26:09 +02:00
|
|
|
# rebased_at :datetime
|
2021-02-04 19:23:40 +01:00
|
|
|
# row :integer
|
|
|
|
# type :string
|
|
|
|
# value :string
|
2021-10-05 15:37:13 +02:00
|
|
|
# value_json :jsonb
|
2021-02-04 19:23:40 +01:00
|
|
|
# created_at :datetime
|
|
|
|
# updated_at :datetime
|
2022-09-21 15:20:42 +02:00
|
|
|
# dossier_id :integer
|
2021-02-04 19:23:40 +01:00
|
|
|
# etablissement_id :integer
|
|
|
|
# external_id :string
|
|
|
|
# parent_id :bigint
|
2022-09-21 15:20:42 +02:00
|
|
|
# type_de_champ_id :integer
|
2020-08-06 16:35:45 +02:00
|
|
|
#
|
2020-01-14 18:46:07 +01:00
|
|
|
class Champs::CommuneChamp < Champs::TextChamp
|
2021-11-17 12:52:47 +01:00
|
|
|
store_accessor :value_json, :departement, :code_departement
|
|
|
|
|
2021-08-18 14:08:38 +02:00
|
|
|
def for_export
|
2022-07-04 15:36:59 +02:00
|
|
|
[value, external_id, departement? ? departement_code_and_name : '']
|
2021-08-18 14:08:38 +02:00
|
|
|
end
|
2021-11-30 19:39:25 +01:00
|
|
|
|
|
|
|
def name_departement
|
2021-11-30 19:44:07 +01:00
|
|
|
# FIXME we originaly saved already formatted departement with the code in the name
|
2021-11-30 19:39:25 +01:00
|
|
|
departement&.gsub(/^(.[0-9])\s-\s/, '')
|
|
|
|
end
|
|
|
|
|
|
|
|
def departement_code_and_name
|
|
|
|
"#{code_departement} - #{name_departement}"
|
|
|
|
end
|
|
|
|
|
|
|
|
def departement?
|
|
|
|
departement.present?
|
|
|
|
end
|
|
|
|
|
|
|
|
def code?
|
|
|
|
code.present?
|
|
|
|
end
|
|
|
|
|
|
|
|
def code
|
|
|
|
external_id
|
|
|
|
end
|
2020-01-14 18:46:07 +01:00
|
|
|
end
|