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
|
|
|
|
# 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-12-16 12:39:51 +01:00
|
|
|
|
# row_id :string
|
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
|
2023-03-21 14:44:03 +01:00
|
|
|
|
store_accessor :value_json, :code_departement, :code_postal
|
|
|
|
|
before_validation :on_code_postal_change
|
2021-11-17 12:52:47 +01:00
|
|
|
|
|
2021-08-18 14:08:38 +02:00
|
|
|
|
def for_export
|
2023-04-04 14:54:29 +02:00
|
|
|
|
[name, code? ? code : '', departement? ? departement_code_and_name : '']
|
2021-08-18 14:08:38 +02:00
|
|
|
|
end
|
2021-11-30 19:39:25 +01:00
|
|
|
|
|
2023-03-21 14:44:03 +01:00
|
|
|
|
def departement_name
|
|
|
|
|
APIGeoService.departement_name(code_departement)
|
2021-11-30 19:39:25 +01:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def departement_code_and_name
|
2023-03-21 14:44:03 +01:00
|
|
|
|
"#{code_departement} – #{departement_name}"
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def departement
|
|
|
|
|
{ code: code_departement, name: departement_name }
|
2021-11-30 19:39:25 +01:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def departement?
|
2023-03-21 14:44:03 +01:00
|
|
|
|
code_departement.present?
|
2021-11-30 19:39:25 +01:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def code?
|
|
|
|
|
code.present?
|
|
|
|
|
end
|
|
|
|
|
|
2023-03-21 14:44:03 +01:00
|
|
|
|
def code_postal?
|
|
|
|
|
code_postal.present?
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def name
|
|
|
|
|
if code?
|
|
|
|
|
"#{APIGeoService.commune_name(code_departement, code)} (#{code_postal_with_fallback})"
|
|
|
|
|
else
|
2023-04-04 14:53:57 +02:00
|
|
|
|
value.present? ? value.to_s : ''
|
2023-03-21 14:44:03 +01:00
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def to_s
|
|
|
|
|
name
|
|
|
|
|
end
|
|
|
|
|
|
2021-11-30 19:39:25 +01:00
|
|
|
|
def code
|
|
|
|
|
external_id
|
|
|
|
|
end
|
2023-03-21 14:44:03 +01:00
|
|
|
|
|
|
|
|
|
def selected
|
|
|
|
|
code
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def communes
|
|
|
|
|
if code_postal_with_fallback?
|
|
|
|
|
APIGeoService.communes_by_postal_code(code_postal_with_fallback)
|
|
|
|
|
else
|
|
|
|
|
[]
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def value=(code)
|
|
|
|
|
if code.blank? || !code_postal_with_fallback?
|
|
|
|
|
self.code_departement = nil
|
|
|
|
|
self.external_id = nil
|
|
|
|
|
super(nil)
|
|
|
|
|
else
|
|
|
|
|
commune = communes.find { _1[:code] == code }
|
|
|
|
|
if commune.present?
|
|
|
|
|
self.code_departement = commune[:departement_code]
|
|
|
|
|
self.external_id = commune[:code]
|
|
|
|
|
super(commune[:name])
|
|
|
|
|
else
|
|
|
|
|
self.code_departement = nil
|
|
|
|
|
self.external_id = nil
|
|
|
|
|
super(nil)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def code_postal_with_fallback?
|
|
|
|
|
code_postal_with_fallback.present?
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
# We try to extract the postal code from the value, which is the name of the commune and the
|
|
|
|
|
# postal code in brackets. This is temporary until we do a full data migration.
|
|
|
|
|
def code_postal_with_fallback
|
|
|
|
|
if code_postal?
|
|
|
|
|
code_postal
|
|
|
|
|
elsif value.present?
|
|
|
|
|
match = value.match(/[^(]\(([^\)]*)\)$/)
|
|
|
|
|
match[1] if match.present?
|
|
|
|
|
else
|
|
|
|
|
nil
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
|
|
def on_code_postal_change
|
|
|
|
|
if code_postal_changed?
|
|
|
|
|
if communes.one?
|
|
|
|
|
self.value = communes.first[:code]
|
|
|
|
|
else
|
|
|
|
|
self.value = nil
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
2020-01-14 18:46:07 +01:00
|
|
|
|
end
|