# == Schema Information # # Table name: champs # # id :integer not null, primary key # data :jsonb # fetch_external_data_exceptions :string is an Array # prefilled :boolean default(FALSE) # private :boolean default(FALSE), not null # rebased_at :datetime # row :integer # type :string # value :string # value_json :jsonb # created_at :datetime # updated_at :datetime # dossier_id :integer # etablissement_id :integer # external_id :string # parent_id :bigint # type_de_champ_id :integer # class Champs::PaysChamp < Champs::TextChamp def for_export [formatted_value, code] end def to_s formatted_value end def for_tag formatted_value end def selected code || value end def value=(code) if code&.size == 2 self.external_id = code super(APIGeoService.country_name(code, locale: 'FR')) elsif code.blank? self.external_id = nil super(nil) elsif code != value self.external_id = APIGeoService.country_code(code) super(code) end end def code external_id || APIGeoService.country_code(value) end private def formatted_value if external_id APIGeoService.country_name(external_id) else value.present? ? value.to_s : '' end end end