2024-04-29 00:17:15 +02:00
|
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
2020-01-14 18:46:07 +01:00
|
|
|
|
class Champs::CommuneChamp < Champs::TextChamp
|
2023-12-06 17:12:02 +01:00
|
|
|
|
store_accessor :value_json, :code_departement, :code_postal, :code_region
|
2023-10-13 16:06:26 +02:00
|
|
|
|
before_save :on_codes_change, if: :should_refresh_after_code_change?
|
2021-11-17 12:52:47 +01:00
|
|
|
|
|
2024-09-05 17:12:13 +02:00
|
|
|
|
validates :external_id, presence: true, if: -> { validate_champ_value_or_prefill? && value.present? }
|
|
|
|
|
after_validation :instrument_external_id_error, if: -> { errors.include?(:external_id) }
|
|
|
|
|
|
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-11-17 12:48:25 +01:00
|
|
|
|
if departement?
|
|
|
|
|
"#{code_departement} – #{departement_name}"
|
|
|
|
|
end
|
2023-03-21 14:44:03 +01:00
|
|
|
|
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
|
|
|
|
|
|
2023-04-05 18:02:42 +02:00
|
|
|
|
alias postal_code code_postal
|
|
|
|
|
|
2023-03-21 14:44:03 +01:00
|
|
|
|
def name
|
2024-04-10 11:08:25 +02:00
|
|
|
|
APIGeoService.safely_normalize_city_name(code_departement, code, safe_to_s)
|
2023-03-21 14:44:03 +01:00
|
|
|
|
end
|
|
|
|
|
|
2021-11-30 19:39:25 +01:00
|
|
|
|
def code
|
|
|
|
|
external_id
|
|
|
|
|
end
|
2023-03-21 14:44:03 +01:00
|
|
|
|
|
|
|
|
|
def selected
|
2024-05-06 21:44:41 +02:00
|
|
|
|
code? ? "#{code}-#{code_postal}" : nil
|
2023-03-21 14:44:03 +01:00
|
|
|
|
end
|
|
|
|
|
|
2024-05-06 21:44:41 +02:00
|
|
|
|
def selected_items
|
|
|
|
|
if code?
|
|
|
|
|
[{ label: to_s, value: selected }]
|
2023-03-21 14:44:03 +01:00
|
|
|
|
else
|
|
|
|
|
[]
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2024-05-06 21:44:41 +02:00
|
|
|
|
def code=(code)
|
|
|
|
|
if code.blank?
|
|
|
|
|
self.code_departement = nil
|
|
|
|
|
self.code_postal = nil
|
|
|
|
|
self.external_id = nil
|
|
|
|
|
self.value = nil
|
|
|
|
|
elsif code.match?(/-/)
|
|
|
|
|
codes = code.split('-')
|
|
|
|
|
self.external_id = codes.first
|
|
|
|
|
self.code_postal = codes.second
|
|
|
|
|
else
|
|
|
|
|
self.external_id = code
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2023-03-21 14:44:03 +01:00
|
|
|
|
private
|
|
|
|
|
|
2023-06-23 15:46:37 +02:00
|
|
|
|
def safe_to_s
|
|
|
|
|
value.present? ? value.to_s : ''
|
|
|
|
|
end
|
|
|
|
|
|
2024-05-06 21:44:41 +02:00
|
|
|
|
def communes
|
|
|
|
|
if code_postal?
|
|
|
|
|
APIGeoService.communes_by_postal_code(code_postal)
|
|
|
|
|
else
|
|
|
|
|
[]
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2023-10-13 16:06:26 +02:00
|
|
|
|
def on_codes_change
|
|
|
|
|
return if !code?
|
|
|
|
|
|
|
|
|
|
commune = communes.find { _1[:code] == code }
|
|
|
|
|
|
|
|
|
|
if commune.present?
|
|
|
|
|
self.code_departement = commune[:departement_code]
|
2023-12-06 17:12:02 +01:00
|
|
|
|
self.code_region = commune[:region_code]
|
2023-10-13 16:06:26 +02:00
|
|
|
|
self.value = commune[:name]
|
|
|
|
|
else
|
|
|
|
|
self.code_departement = nil
|
|
|
|
|
self.code_postal = nil
|
|
|
|
|
self.external_id = nil
|
|
|
|
|
self.value = nil
|
2023-03-21 14:44:03 +01:00
|
|
|
|
end
|
|
|
|
|
end
|
2023-10-13 16:06:26 +02:00
|
|
|
|
|
|
|
|
|
def should_refresh_after_code_change?
|
|
|
|
|
!departement? || code_postal_changed? || external_id_changed?
|
|
|
|
|
end
|
2024-09-05 17:12:13 +02:00
|
|
|
|
|
|
|
|
|
def instrument_external_id_error
|
|
|
|
|
Sentry.capture_message(
|
|
|
|
|
"Commune with value and no external id Edge case reached",
|
|
|
|
|
extra: { request_id: Current.request_id }
|
|
|
|
|
)
|
|
|
|
|
end
|
2020-01-14 18:46:07 +01:00
|
|
|
|
end
|