diff --git a/decidim-admin/app/packs/stylesheets/decidim/admin/modules/_address.scss b/decidim-admin/app/packs/stylesheets/decidim/admin/modules/_address.scss new file mode 100644 index 0000000000000..988cb50ed4bc7 --- /dev/null +++ b/decidim-admin/app/packs/stylesheets/decidim/admin/modules/_address.scss @@ -0,0 +1,5 @@ +@import "stylesheets/decidim/modules/address"; + +.address{ + padding: 1rem; +} diff --git a/decidim-admin/app/packs/stylesheets/decidim/admin/modules/_modules.scss b/decidim-admin/app/packs/stylesheets/decidim/admin/modules/_modules.scss index 9d43d857829ce..6ab7e022b2504 100644 --- a/decidim-admin/app/packs/stylesheets/decidim/admin/modules/_modules.scss +++ b/decidim-admin/app/packs/stylesheets/decidim/admin/modules/_modules.scss @@ -40,3 +40,6 @@ //Admin dashboard @import "stylesheets/decidim/admin/modules/users_statistics"; @import "stylesheets/decidim/admin/modules/moderations"; + +// Address styling +@import "stylesheets/decidim/admin/modules/address"; diff --git a/decidim-proposals/app/views/decidim/proposals/admin/proposals/show.html.erb b/decidim-proposals/app/views/decidim/proposals/admin/proposals/show.html.erb index 07ecad25a6392..3c39e410cf025 100644 --- a/decidim-proposals/app/views/decidim/proposals/admin/proposals/show.html.erb +++ b/decidim-proposals/app/views/decidim/proposals/admin/proposals/show.html.erb @@ -38,6 +38,13 @@ <%= t ".body" %>: <%= simple_format(present(proposal).body(strip_tags: true)) %> + <% if component_settings.geocoding_enabled? %> +
+ <%= t ".geolocated_at" %>: + <%= render partial: "decidim/shared/static_map", locals: { icon_name: "proposals", geolocalizable: proposal } %> +
+ <% end %> +
<%= t ".created_at" %>: <%= l proposal.created_at, format: :decidim_short %>
diff --git a/decidim-proposals/config/locales/en.yml b/decidim-proposals/config/locales/en.yml index 6a8d13ec0d970..d566324563484 100644 --- a/decidim-proposals/config/locales/en.yml +++ b/decidim-proposals/config/locales/en.yml @@ -540,6 +540,7 @@ en: endorsements_count: Endorsements count endorsements_ranking: Ranking by endorsements endorsers: Endorsers + geolocated_at: Geolocated at link: Link n_more_endorsers: one: and 1 more diff --git a/decidim-proposals/spec/system/admin/view_proposal_details_from_admin_spec.rb b/decidim-proposals/spec/system/admin/view_proposal_details_from_admin_spec.rb index a2eed1021ce0c..c519c49a9b489 100644 --- a/decidim-proposals/spec/system/admin/view_proposal_details_from_admin_spec.rb +++ b/decidim-proposals/spec/system/admin/view_proposal_details_from_admin_spec.rb @@ -90,6 +90,38 @@ end end + context "when it is a proposal with geocoding data" do + let!(:proposal) { create(:proposal, component: component, address: address, latitude: latitude, longitude: longitude) } + + it "does not show the address" do + go_to_admin_proposal_page(proposal) + expect(page).not_to have_css(".address") + expect(page).not_to have_css(".address__info") + expect(page).not_to have_css(".address__map") + expect(page).not_to have_content(address) + end + + context "when component has geocoding enabled" do + let!(:component) do + create(:proposal_component, + manifest: manifest, + participatory_space: participatory_process, + settings: { + geocoding_enabled: true + }) + end + + it "shows the address" do + go_to_admin_proposal_page(proposal) + within ".address" do + expect(page).to have_css(".address__info") + expect(page).to have_css(".address__map") + expect(page).to have_content(address) + end + end + end + end + describe "with supports" do before do create_list :proposal_vote, 2, proposal: proposal diff --git a/decidim-proposals/spec/system/proposals_spec.rb b/decidim-proposals/spec/system/proposals_spec.rb index 63998ab012607..eaf89b41989f5 100644 --- a/decidim-proposals/spec/system/proposals_spec.rb +++ b/decidim-proposals/spec/system/proposals_spec.rb @@ -144,6 +144,40 @@ end end + context "when it is a proposal with geocoding data" do + let!(:proposal) { create(:proposal, component: component, address: address, latitude: latitude, longitude: longitude) } + + it "does not show the address" do + visit_component + click_link proposal_title + expect(page).not_to have_css(".card__content.address") + expect(page).not_to have_css(".address__info") + expect(page).not_to have_css(".address__map") + expect(page).not_to have_content(address) + end + + context "when component has geocoding enabled" do + let!(:component) do + create(:proposal_component, + manifest: manifest, + participatory_space: participatory_process, + settings: { + geocoding_enabled: true + }) + end + + it "shows the address" do + visit_component + click_link proposal_title + within ".card__content.address" do + expect(page).to have_css(".address__info") + expect(page).to have_css(".address__map") + expect(page).to have_content(address) + end + end + end + end + context "when it is an official meeting proposal" do include_context "with rich text editor content" let!(:proposal) { create(:proposal, :official_meeting, body: content, component: component) }