feat(rna/rnf): expose rnf/rna title
This commit is contained in:
parent
cfd568b98d
commit
9a70a9526d
6 changed files with 42 additions and 6 deletions
|
@ -4,8 +4,8 @@ module AddressableColumnConcern
|
||||||
extend ActiveSupport::Concern
|
extend ActiveSupport::Concern
|
||||||
|
|
||||||
included do
|
included do
|
||||||
def columns(procedure:, displayable: true, prefix: nil)
|
def addressable_columns(procedure:, displayable: true, prefix: nil)
|
||||||
addressable_columns = [
|
[
|
||||||
["code postal (5 chiffres)", '$.postal_code', :text, []],
|
["code postal (5 chiffres)", '$.postal_code', :text, []],
|
||||||
["commune", '$.city_name', :text, []],
|
["commune", '$.city_name', :text, []],
|
||||||
["département", '$.departement_code', :enum, APIGeoService.departement_options],
|
["département", '$.departement_code', :enum, APIGeoService.departement_options],
|
||||||
|
@ -22,8 +22,6 @@ module AddressableColumnConcern
|
||||||
type:
|
type:
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
super.concat(addressable_columns)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -10,4 +10,20 @@ class TypesDeChamp::RNATypeDeChamp < TypesDeChamp::TypeDeChampBase
|
||||||
def champ_value_for_export(champ, path = :value)
|
def champ_value_for_export(champ, path = :value)
|
||||||
champ.identifier
|
champ.identifier
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def columns(procedure:, displayable: true, prefix: nil)
|
||||||
|
super
|
||||||
|
.concat(addressable_columns(procedure:, displayable:, prefix:))
|
||||||
|
.concat([
|
||||||
|
Columns::JSONPathColumn.new(
|
||||||
|
procedure_id: procedure.id,
|
||||||
|
stable_id:,
|
||||||
|
tdc_type: type_champ,
|
||||||
|
label: "#{libelle_with_prefix(prefix)} – Titre au répertoire national des associations",
|
||||||
|
type: :text,
|
||||||
|
jsonpath: '$.title',
|
||||||
|
displayable:
|
||||||
|
)
|
||||||
|
])
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -35,6 +35,22 @@ class TypesDeChamp::RNFTypeDeChamp < TypesDeChamp::TextTypeDeChamp
|
||||||
|
|
||||||
def champ_blank?(champ) = champ.external_id.blank?
|
def champ_blank?(champ) = champ.external_id.blank?
|
||||||
|
|
||||||
|
def columns(procedure:, displayable: true, prefix: nil)
|
||||||
|
super
|
||||||
|
.concat(addressable_columns(procedure:, displayable:, prefix:))
|
||||||
|
.concat([
|
||||||
|
Columns::JSONPathColumn.new(
|
||||||
|
procedure_id: procedure.id,
|
||||||
|
stable_id:,
|
||||||
|
tdc_type: type_champ,
|
||||||
|
label: "#{libelle_with_prefix(prefix)} – Titre au répertoire national des fondations ",
|
||||||
|
type: :text,
|
||||||
|
jsonpath: '$.title',
|
||||||
|
displayable:
|
||||||
|
)
|
||||||
|
])
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def paths
|
def paths
|
||||||
|
|
|
@ -8,4 +8,8 @@ class TypesDeChamp::SiretTypeDeChamp < TypesDeChamp::TypeDeChampBase
|
||||||
end
|
end
|
||||||
|
|
||||||
def champ_blank_or_invalid?(champ) = Siret.new(siret: champ.value).invalid?
|
def champ_blank_or_invalid?(champ) = Siret.new(siret: champ.value).invalid?
|
||||||
|
|
||||||
|
def columns(procedure:, displayable: true, prefix: nil)
|
||||||
|
super.concat(addressable_columns(procedure:, displayable:, prefix:))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -170,7 +170,7 @@ FactoryBot.define do
|
||||||
|
|
||||||
factory :champ_do_not_use_rna, class: 'Champs::RNAChamp' do
|
factory :champ_do_not_use_rna, class: 'Champs::RNAChamp' do
|
||||||
value { 'W173847273' }
|
value { 'W173847273' }
|
||||||
value_json { AddressProxy::ADDRESS_PARTS.index_by(&:itself) }
|
value_json { AddressProxy::ADDRESS_PARTS.index_by(&:itself).merge(title: "LA PRÉVENTION ROUTIERE") }
|
||||||
end
|
end
|
||||||
|
|
||||||
factory :champ_do_not_use_engagement_juridique, class: 'Champs::EngagementJuridiqueChamp' do
|
factory :champ_do_not_use_engagement_juridique, class: 'Champs::EngagementJuridiqueChamp' do
|
||||||
|
@ -183,7 +183,7 @@ FactoryBot.define do
|
||||||
factory :champ_do_not_use_rnf, class: 'Champs::RNFChamp' do
|
factory :champ_do_not_use_rnf, class: 'Champs::RNFChamp' do
|
||||||
value { '075-FDD-00003-01' }
|
value { '075-FDD-00003-01' }
|
||||||
external_id { '075-FDD-00003-01' }
|
external_id { '075-FDD-00003-01' }
|
||||||
value_json { AddressProxy::ADDRESS_PARTS.index_by(&:itself) }
|
value_json { AddressProxy::ADDRESS_PARTS.index_by(&:itself).merge(title: "Fondation SFR") }
|
||||||
end
|
end
|
||||||
|
|
||||||
factory :champ_do_not_use_expression_reguliere, class: 'Champs::ExpressionReguliereChamp' do
|
factory :champ_do_not_use_expression_reguliere, class: 'Champs::ExpressionReguliereChamp' do
|
||||||
|
|
|
@ -41,6 +41,8 @@ describe Columns::ChampColumn do
|
||||||
expect_type_de_champ_values('mesri', eq([nil]))
|
expect_type_de_champ_values('mesri', eq([nil]))
|
||||||
expect_type_de_champ_values('cojo', eq([nil]))
|
expect_type_de_champ_values('cojo', eq([nil]))
|
||||||
expect_type_de_champ_values('expression_reguliere', eq([nil]))
|
expect_type_de_champ_values('expression_reguliere', eq([nil]))
|
||||||
|
expect_type_de_champ_values('rna', eq(["W173847273", "postal_code", "city_name", "departement_code", "region_name", "LA PRÉVENTION ROUTIERE"]))
|
||||||
|
expect_type_de_champ_values('rnf', eq(["075-FDD-00003-01", "postal_code", "city_name", "departement_code", "region_name", "Fondation SFR"]))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue