Merge pull request #6148 from consuldemocracy/add_label_to_edit_form_map_markers
Add ARIA labels to admin settings map marker
This commit is contained in:
@@ -193,7 +193,6 @@
|
|||||||
|
|
||||||
if (App.Map.validCoordinates(coordinates)) {
|
if (App.Map.validCoordinates(coordinates)) {
|
||||||
marker = createMarker(coordinates.lat, coordinates.long, coordinates.title);
|
marker = createMarker(coordinates.lat, coordinates.long, coordinates.title);
|
||||||
marker.options.id = coordinates.investment_id;
|
|
||||||
marker.bindPopup(App.Map.getPopupContent(coordinates));
|
marker.bindPopup(App.Map.getPopupContent(coordinates));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,25 +1,10 @@
|
|||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="small-12 column">
|
<div class="small-12 column">
|
||||||
<div id="admin-map" class="map"
|
<%= form_for map_location, url: admin_update_map_path, method: :put, html: { id: "map-form" } do |f| %>
|
||||||
data-map
|
<%= render_map(map_location, form: f) %>
|
||||||
data-map-center-latitude="<%= Setting["map.latitude"] %>"
|
<%= f.hidden_field :latitude %>
|
||||||
data-map-center-longitude="<%= Setting["map.longitude"] %>"
|
<%= f.hidden_field :longitude %>
|
||||||
data-map-zoom="<%= Setting["map.zoom"] %>"
|
<%= f.hidden_field :zoom %>
|
||||||
data-map-tiles-provider="<%= Rails.application.secrets.map_tiles_provider %>"
|
|
||||||
data-map-tiles-provider-attribution="<%= Rails.application.secrets.map_tiles_provider_attribution %>"
|
|
||||||
data-marker-editable="true"
|
|
||||||
data-marker-latitude="<%= Setting["map.latitude"] %>"
|
|
||||||
data-marker-longitude="<%= Setting["map.longitude"] %>"
|
|
||||||
data-latitude-input-selector="#latitude"
|
|
||||||
data-longitude-input-selector="#longitude"
|
|
||||||
data-zoom-input-selector="#zoom">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<%= form_tag admin_update_map_path, method: :put, id: "map-form" do |f| %>
|
|
||||||
|
|
||||||
<%= hidden_field_tag :latitude, Setting["map.latitude"] %>
|
|
||||||
<%= hidden_field_tag :longitude, Setting["map.longitude"] %>
|
|
||||||
<%= hidden_field_tag :zoom, Setting["map.zoom"] %>
|
|
||||||
<%= hidden_field_tag :tab, tab if tab %>
|
<%= hidden_field_tag :tab, tab if tab %>
|
||||||
|
|
||||||
<div class="small-12 medium-6 large-4 margin-top">
|
<div class="small-12 medium-6 large-4 margin-top">
|
||||||
|
|||||||
@@ -1,7 +1,18 @@
|
|||||||
class Admin::Settings::MapFormComponent < ApplicationComponent
|
class Admin::Settings::MapFormComponent < ApplicationComponent
|
||||||
attr_reader :tab
|
attr_reader :tab
|
||||||
|
use_helpers :render_map
|
||||||
|
|
||||||
def initialize(tab: nil)
|
def initialize(tab: nil)
|
||||||
@tab = tab
|
@tab = tab
|
||||||
end
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def map_location
|
||||||
|
MapLocation.new(
|
||||||
|
latitude: Setting["map.latitude"],
|
||||||
|
longitude: Setting["map.longitude"],
|
||||||
|
zoom: Setting["map.zoom"]
|
||||||
|
)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -44,16 +44,7 @@
|
|||||||
<%= render Documents::NestedComponent.new(f) %>
|
<%= render Documents::NestedComponent.new(f) %>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
<% if feature?(:map) %>
|
<%= render MapLocations::FormFieldsComponent.new(f, map_location: map_location) %>
|
||||||
<div>
|
|
||||||
<%= render "map_locations/form_fields",
|
|
||||||
form: f,
|
|
||||||
map_location: investment.map_location || MapLocation.new,
|
|
||||||
label: t("budgets.investments.form.map_location"),
|
|
||||||
help: t("budgets.investments.form.map_location_instructions"),
|
|
||||||
i18n_namespace: "budgets.investments" %>
|
|
||||||
</div>
|
|
||||||
<% end %>
|
|
||||||
|
|
||||||
<div>
|
<div>
|
||||||
<%= f.text_field :location %>
|
<%= f.text_field :location %>
|
||||||
|
|||||||
@@ -19,4 +19,8 @@ class Budgets::Investments::FormComponent < ApplicationComponent
|
|||||||
def categories
|
def categories
|
||||||
Tag.category.order(:name)
|
Tag.category.order(:name)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def map_location
|
||||||
|
investment.map_location || MapLocation.new(investment: Budget::Investment.new)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
12
app/components/map_locations/form_fields_component.html.erb
Normal file
12
app/components/map_locations/form_fields_component.html.erb
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
<fieldset>
|
||||||
|
<legend><%= label %></legend>
|
||||||
|
<p class="help-text" id="tag-list-help-text"><%= help %></p>
|
||||||
|
|
||||||
|
<%= form.fields_for :map_location, map_location do |fields| %>
|
||||||
|
<%= render_map(map_location, form: fields) %>
|
||||||
|
|
||||||
|
<%= fields.hidden_field :latitude %>
|
||||||
|
<%= fields.hidden_field :longitude %>
|
||||||
|
<%= fields.hidden_field :zoom %>
|
||||||
|
<% end %>
|
||||||
|
</fieldset>
|
||||||
23
app/components/map_locations/form_fields_component.rb
Normal file
23
app/components/map_locations/form_fields_component.rb
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
class MapLocations::FormFieldsComponent < ApplicationComponent
|
||||||
|
attr_reader :form, :map_location
|
||||||
|
use_helpers :render_map
|
||||||
|
|
||||||
|
def initialize(form, map_location:)
|
||||||
|
@form = form
|
||||||
|
@map_location = map_location
|
||||||
|
end
|
||||||
|
|
||||||
|
def render?
|
||||||
|
feature?(:map)
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def label
|
||||||
|
t("proposals.form.map_location")
|
||||||
|
end
|
||||||
|
|
||||||
|
def help
|
||||||
|
t("proposals.form.map_location_instructions")
|
||||||
|
end
|
||||||
|
end
|
||||||
@@ -52,16 +52,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
<% if feature?(:map) %>
|
<%= render MapLocations::FormFieldsComponent.new(f, map_location: map_location) %>
|
||||||
<div>
|
|
||||||
<%= render "map_locations/form_fields",
|
|
||||||
form: f,
|
|
||||||
map_location: proposal.map_location || MapLocation.new,
|
|
||||||
label: t("proposals.form.map_location"),
|
|
||||||
help: t("proposals.form.map_location_instructions"),
|
|
||||||
i18n_namespace: "proposals" %>
|
|
||||||
</div>
|
|
||||||
<% end %>
|
|
||||||
|
|
||||||
<div>
|
<div>
|
||||||
<%= f.label :tag_list, t("proposals.form.tags_label") %>
|
<%= f.label :tag_list, t("proposals.form.tags_label") %>
|
||||||
|
|||||||
@@ -15,4 +15,8 @@ class Proposals::FormComponent < ApplicationComponent
|
|||||||
def categories
|
def categories
|
||||||
Tag.category.order(:name)
|
Tag.category.order(:name)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def map_location
|
||||||
|
proposal.map_location || MapLocation.new(proposal: Proposal.new)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
<%= tag.div(id: dom_id(map_location), class: "map-location map", data: data) %>
|
<%= tag.div(id: dom_id(map_location), class: "map-location map", data: data) %>
|
||||||
|
|
||||||
<% if editable? %>
|
<% if show_remove_marker_button? %>
|
||||||
<%= remove_marker %>
|
<%= remove_marker %>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|||||||
@@ -18,6 +18,10 @@ class Shared::MapLocationComponent < ApplicationComponent
|
|||||||
form.present?
|
form.present?
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def show_remove_marker_button?
|
||||||
|
editable? && map_location.mappable.present?
|
||||||
|
end
|
||||||
|
|
||||||
def latitude
|
def latitude
|
||||||
map_location.latitude.presence || Setting["map.latitude"]
|
map_location.latitude.presence || Setting["map.latitude"]
|
||||||
end
|
end
|
||||||
@@ -58,12 +62,20 @@ class Shared::MapLocationComponent < ApplicationComponent
|
|||||||
marker_investments_coordinates: investments_coordinates,
|
marker_investments_coordinates: investments_coordinates,
|
||||||
marker_latitude: map_location.latitude.presence,
|
marker_latitude: map_location.latitude.presence,
|
||||||
marker_longitude: map_location.longitude.presence,
|
marker_longitude: map_location.longitude.presence,
|
||||||
marker_title: map_location.title.presence,
|
marker_title: marker_coordinates_text,
|
||||||
marker_clustering: feature?("map.feature.marker_clustering"),
|
marker_clustering: feature?("map.feature.marker_clustering"),
|
||||||
geozones: geozones_data
|
geozones: geozones_data
|
||||||
}.merge(input_selectors)
|
}.merge(input_selectors)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def marker_coordinates_text
|
||||||
|
return unless map_location.available?
|
||||||
|
|
||||||
|
t("proposals.form.map_marker_coordinates",
|
||||||
|
latitude: map_location.latitude,
|
||||||
|
longitude: map_location.longitude)
|
||||||
|
end
|
||||||
|
|
||||||
def input_selectors
|
def input_selectors
|
||||||
if form
|
if form
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -13,9 +13,9 @@ class Admin::SettingsController < Admin::BaseController
|
|||||||
end
|
end
|
||||||
|
|
||||||
def update_map
|
def update_map
|
||||||
Setting["map.latitude"] = params[:latitude].to_f
|
Setting["map.latitude"] = params[:map_location][:latitude].to_f
|
||||||
Setting["map.longitude"] = params[:longitude].to_f
|
Setting["map.longitude"] = params[:map_location][:longitude].to_f
|
||||||
Setting["map.zoom"] = params[:zoom].to_i
|
Setting["map.zoom"] = params[:map_location][:zoom].to_i
|
||||||
redirect_to request_referer, notice: t("admin.settings.index.map.flash.update")
|
redirect_to request_referer, notice: t("admin.settings.index.map.flash.update")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -8,17 +8,12 @@ class MapLocation < ApplicationRecord
|
|||||||
latitude.present? && longitude.present? && zoom.present?
|
latitude.present? && longitude.present? && zoom.present?
|
||||||
end
|
end
|
||||||
|
|
||||||
def title
|
def mappable
|
||||||
(proposal || investment)&.title
|
proposal || investment
|
||||||
end
|
end
|
||||||
|
|
||||||
def json_data
|
def title
|
||||||
{
|
mappable&.title
|
||||||
investment_id: investment_id,
|
|
||||||
proposal_id: proposal_id,
|
|
||||||
lat: latitude,
|
|
||||||
long: longitude
|
|
||||||
}
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.from_heading(heading)
|
def self.from_heading(heading)
|
||||||
|
|||||||
@@ -1,10 +0,0 @@
|
|||||||
<%= form.label :map_location, label %>
|
|
||||||
<p class="help-text" id="tag-list-help-text"><%= help %></p>
|
|
||||||
|
|
||||||
<%= form.fields_for :map_location, map_location do |m_l_fields| %>
|
|
||||||
<%= render_map(map_location, form: m_l_fields) %>
|
|
||||||
|
|
||||||
<%= m_l_fields.hidden_field :latitude %>
|
|
||||||
<%= m_l_fields.hidden_field :longitude %>
|
|
||||||
<%= m_l_fields.hidden_field :zoom %>
|
|
||||||
<% end %>
|
|
||||||
@@ -80,8 +80,6 @@ en:
|
|||||||
tags_instructions: "Tag this proposal. You can choose from proposed categories or add your own"
|
tags_instructions: "Tag this proposal. You can choose from proposed categories or add your own"
|
||||||
tags_label: Tags
|
tags_label: Tags
|
||||||
tags_placeholder: "Enter the tags you would like to use, separated by commas (',')"
|
tags_placeholder: "Enter the tags you would like to use, separated by commas (',')"
|
||||||
map_location: "Map location"
|
|
||||||
map_location_instructions: "Navigate the map to the location and place the marker."
|
|
||||||
index:
|
index:
|
||||||
title: Participatory budgeting
|
title: Participatory budgeting
|
||||||
unfeasible: Unfeasible investment projects
|
unfeasible: Unfeasible investment projects
|
||||||
|
|||||||
@@ -328,6 +328,7 @@ en:
|
|||||||
tags_placeholder: "Enter the tags you would like to use, separated by commas (',')"
|
tags_placeholder: "Enter the tags you would like to use, separated by commas (',')"
|
||||||
map_location: "Map location"
|
map_location: "Map location"
|
||||||
map_location_instructions: "Navigate the map to the location and place the marker."
|
map_location_instructions: "Navigate the map to the location and place the marker."
|
||||||
|
map_marker_coordinates: "Latitude: %{latitude}. Longitude: %{longitude}"
|
||||||
map_remove_marker: "Remove map marker"
|
map_remove_marker: "Remove map marker"
|
||||||
index:
|
index:
|
||||||
featured_proposals: Featured
|
featured_proposals: Featured
|
||||||
|
|||||||
@@ -80,8 +80,6 @@ es:
|
|||||||
tags_instructions: "Etiqueta este proyecto. Puedes elegir entre las categorías propuestas o introducir las que desees"
|
tags_instructions: "Etiqueta este proyecto. Puedes elegir entre las categorías propuestas o introducir las que desees"
|
||||||
tags_label: Etiquetas
|
tags_label: Etiquetas
|
||||||
tags_placeholder: "Escribe las etiquetas que desees separadas por coma (',')"
|
tags_placeholder: "Escribe las etiquetas que desees separadas por coma (',')"
|
||||||
map_location: "Ubicación en el mapa"
|
|
||||||
map_location_instructions: "Navega por el mapa hasta la ubicación y coloca el marcador."
|
|
||||||
index:
|
index:
|
||||||
title: Presupuestos participativos
|
title: Presupuestos participativos
|
||||||
unfeasible: Proyectos de gasto no viables
|
unfeasible: Proyectos de gasto no viables
|
||||||
|
|||||||
@@ -328,6 +328,7 @@ es:
|
|||||||
tags_placeholder: "Escribe las etiquetas que desees separadas por coma (',')"
|
tags_placeholder: "Escribe las etiquetas que desees separadas por coma (',')"
|
||||||
map_location: "Ubicación en el mapa"
|
map_location: "Ubicación en el mapa"
|
||||||
map_location_instructions: "Navega por el mapa hasta la ubicación y coloca el marcador."
|
map_location_instructions: "Navega por el mapa hasta la ubicación y coloca el marcador."
|
||||||
|
map_marker_coordinates: "Latitud: %{latitude}. Longitud: %{longitude}"
|
||||||
map_remove_marker: "Eliminar el marcador"
|
map_remove_marker: "Eliminar el marcador"
|
||||||
index:
|
index:
|
||||||
featured_proposals: Destacadas
|
featured_proposals: Destacadas
|
||||||
|
|||||||
10
spec/components/admin/settings/map_form_component_spec.rb
Normal file
10
spec/components/admin/settings/map_form_component_spec.rb
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
require "rails_helper"
|
||||||
|
|
||||||
|
describe Admin::Settings::MapFormComponent do
|
||||||
|
it "does not render a button to remove the marker" do
|
||||||
|
render_inline Admin::Settings::MapFormComponent.new
|
||||||
|
|
||||||
|
expect(page).to have_css ".map-location"
|
||||||
|
expect(page).not_to have_button "Remove map marker"
|
||||||
|
end
|
||||||
|
end
|
||||||
@@ -33,4 +33,17 @@ describe Budgets::Investments::FormComponent do
|
|||||||
expect(page).not_to have_field "I agree to the Privacy Policy and the Terms and conditions of use"
|
expect(page).not_to have_field "I agree to the Privacy Policy and the Terms and conditions of use"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "map" do
|
||||||
|
it "renders a button to remove the map marker" do
|
||||||
|
Setting["feature.map"] = true
|
||||||
|
|
||||||
|
render_inline Budgets::Investments::FormComponent.new(
|
||||||
|
budget.investments.new,
|
||||||
|
url: budget_investments_path(budget)
|
||||||
|
)
|
||||||
|
|
||||||
|
expect(page).to have_button "Remove map marker"
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
24
spec/components/map_locations/form_fields_component_spec.rb
Normal file
24
spec/components/map_locations/form_fields_component_spec.rb
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
require "rails_helper"
|
||||||
|
|
||||||
|
describe MapLocations::FormFieldsComponent do
|
||||||
|
let(:proposal) { Proposal.new }
|
||||||
|
let(:map_location) { MapLocation.new }
|
||||||
|
let(:form) { ConsulFormBuilder.new(:proposal, proposal, ApplicationController.new.view_context, {}) }
|
||||||
|
let(:component) { MapLocations::FormFieldsComponent.new(form, map_location: map_location) }
|
||||||
|
|
||||||
|
it "is rendered when the map feature is enabled" do
|
||||||
|
Setting["feature.map"] = true
|
||||||
|
|
||||||
|
render_inline component
|
||||||
|
|
||||||
|
expect(page).to be_rendered
|
||||||
|
end
|
||||||
|
|
||||||
|
it "is not rendered when the map feature is not enabled" do
|
||||||
|
Setting["feature.map"] = false
|
||||||
|
|
||||||
|
render_inline component
|
||||||
|
|
||||||
|
expect(page).not_to be_rendered
|
||||||
|
end
|
||||||
|
end
|
||||||
17
spec/components/proposals/form_component_spec.rb
Normal file
17
spec/components/proposals/form_component_spec.rb
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
require "rails_helper"
|
||||||
|
|
||||||
|
describe Proposals::FormComponent do
|
||||||
|
include Rails.application.routes.url_helpers
|
||||||
|
|
||||||
|
before { sign_in(create(:user)) }
|
||||||
|
|
||||||
|
describe "map" do
|
||||||
|
it "renders a button to remove the map marker" do
|
||||||
|
Setting["feature.map"] = true
|
||||||
|
|
||||||
|
render_inline Proposals::FormComponent.new(Proposal.new, url: proposals_path)
|
||||||
|
|
||||||
|
expect(page).to have_button "Remove map marker"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
62
spec/components/shared/map_location_component_spec.rb
Normal file
62
spec/components/shared/map_location_component_spec.rb
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
require "rails_helper"
|
||||||
|
|
||||||
|
describe Shared::MapLocationComponent do
|
||||||
|
describe "remove marker button" do
|
||||||
|
it "is not rendered when there's no form" do
|
||||||
|
map_location = build(:map_location, proposal: Proposal.new)
|
||||||
|
|
||||||
|
render_inline Shared::MapLocationComponent.new(map_location)
|
||||||
|
|
||||||
|
expect(page).not_to have_button "Remove map marker"
|
||||||
|
end
|
||||||
|
|
||||||
|
it "is not rendered when there's no mappable" do
|
||||||
|
map_location = build(:map_location)
|
||||||
|
form = ConsulFormBuilder.new(:map_location, map_location, ApplicationController.new.view_context, {})
|
||||||
|
|
||||||
|
render_inline Shared::MapLocationComponent.new(map_location, form: form)
|
||||||
|
|
||||||
|
expect(page).not_to have_button "Remove map marker"
|
||||||
|
end
|
||||||
|
|
||||||
|
it "is rendered when there's a form and a mappable" do
|
||||||
|
map_location = build(:map_location, proposal: Proposal.new)
|
||||||
|
form = ConsulFormBuilder.new(:map_location, map_location, ApplicationController.new.view_context, {})
|
||||||
|
|
||||||
|
render_inline Shared::MapLocationComponent.new(map_location, form: form)
|
||||||
|
|
||||||
|
expect(page).to have_button "Remove map marker"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "marker title" do
|
||||||
|
it "uses the coordinates when there's a mappable" do
|
||||||
|
map_location = build(
|
||||||
|
:map_location,
|
||||||
|
proposal: Proposal.new(title: "Meet me here"),
|
||||||
|
latitude: "25.25",
|
||||||
|
longitude: "13.14"
|
||||||
|
)
|
||||||
|
|
||||||
|
render_inline Shared::MapLocationComponent.new(map_location)
|
||||||
|
|
||||||
|
expect(page).to have_css "[data-marker-title='Latitude: 25.25. Longitude: 13.14']"
|
||||||
|
end
|
||||||
|
|
||||||
|
it "uses the coordinates when there's no mappable" do
|
||||||
|
map_location = build(:map_location, latitude: "25.25", longitude: "13.14")
|
||||||
|
|
||||||
|
render_inline Shared::MapLocationComponent.new(map_location)
|
||||||
|
|
||||||
|
expect(page).to have_css "[data-marker-title='Latitude: 25.25. Longitude: 13.14']"
|
||||||
|
end
|
||||||
|
|
||||||
|
it "is not present when the map location isn't available" do
|
||||||
|
map_location = build(:map_location, latitude: "25.25", longitude: nil)
|
||||||
|
|
||||||
|
render_inline Shared::MapLocationComponent.new(map_location)
|
||||||
|
|
||||||
|
expect(page).not_to have_css "[data-marker-title]"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
@@ -17,36 +17,21 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
describe "At #{mappable_new_path}" do
|
describe "At #{mappable_new_path}" do
|
||||||
before { set_arguments(arguments, mappable, mappable_path_arguments) }
|
before { set_arguments(arguments, mappable, mappable_path_arguments) }
|
||||||
|
|
||||||
scenario "Should not show marker by default on create #{mappable_factory_name}" do
|
scenario "Should show marker and create #{mappable_factory_name} with map" do
|
||||||
do_login_for user, management: management
|
do_login_for user, management: management
|
||||||
visit send(mappable_new_path, arguments)
|
visit send(mappable_new_path, arguments)
|
||||||
|
|
||||||
send("fill_in_#{mappable_factory_name}")
|
send("fill_in_#{mappable_factory_name}")
|
||||||
|
|
||||||
within ".map-location" do
|
within_fieldset "Map location" do
|
||||||
expect(page).not_to have_css(".map-icon")
|
expect(page).not_to have_css ".map-icon"
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
scenario "Should show marker on create #{mappable_factory_name} when click on map" do
|
find("#new_map_location").click
|
||||||
do_login_for user, management: management
|
|
||||||
visit send(mappable_new_path, arguments)
|
|
||||||
|
|
||||||
send("fill_in_#{mappable_factory_name}")
|
|
||||||
find("#new_map_location").click
|
|
||||||
|
|
||||||
within ".map-location" do
|
|
||||||
expect(page).to have_css ".map-icon"
|
expect(page).to have_css ".map-icon"
|
||||||
expect(page).not_to have_css ".map-icon[aria-label]"
|
expect(page).not_to have_css ".map-icon[aria-label]"
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
scenario "Should create #{mappable_factory_name} with map" do
|
|
||||||
do_login_for user, management: management
|
|
||||||
visit send(mappable_new_path, arguments)
|
|
||||||
|
|
||||||
send("fill_in_#{mappable_factory_name}")
|
|
||||||
find("#new_map_location").click
|
|
||||||
send("submit_#{mappable_factory_name}_form")
|
send("submit_#{mappable_factory_name}_form")
|
||||||
|
|
||||||
within ".map-location" do
|
within ".map-location" do
|
||||||
@@ -96,7 +81,7 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
|
|
||||||
go_back
|
go_back
|
||||||
|
|
||||||
within ".map-location" do
|
within_fieldset "Map location" do
|
||||||
expect(page).to have_css(".leaflet-map-pane", count: 1)
|
expect(page).to have_css(".leaflet-map-pane", count: 1)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -105,15 +90,16 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
do_login_for user, management: management
|
do_login_for user, management: management
|
||||||
visit send(mappable_new_path, arguments)
|
visit send(mappable_new_path, arguments)
|
||||||
|
|
||||||
within ".map-location" do
|
within_fieldset "Map location" do
|
||||||
expect(page).not_to have_css(".map-icon")
|
expect(page).not_to have_css ".map-icon"
|
||||||
end
|
end
|
||||||
expect(page.execute_script("return App.Map.maps[0].getZoom();")).to eq(10)
|
expect(page.execute_script("return App.Map.maps[0].getZoom();")).to eq(10)
|
||||||
|
|
||||||
map_zoom_in
|
map_zoom_in
|
||||||
find("#new_map_location").click
|
|
||||||
|
|
||||||
within ".map-location" do
|
within_fieldset "Map location" do
|
||||||
|
find("#new_map_location").click
|
||||||
|
|
||||||
expect(page).to have_css(".map-icon")
|
expect(page).to have_css(".map-icon")
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -129,9 +115,9 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
|
|
||||||
go_back
|
go_back
|
||||||
|
|
||||||
within ".map-location" do
|
within_fieldset "Map location" do
|
||||||
expect(page).to have_css(".map-icon")
|
expect(page).to have_css ".map-icon"
|
||||||
expect(page.execute_script("return App.Map.maps[0].getZoom();")).to eq(11)
|
expect(page.execute_script("return App.Map.maps[0].getZoom();")).to eq 11
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -139,14 +125,15 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
do_login_for user, management: management
|
do_login_for user, management: management
|
||||||
visit send(mappable_new_path, arguments)
|
visit send(mappable_new_path, arguments)
|
||||||
|
|
||||||
within ".map-location" do
|
within_fieldset "Map location" do
|
||||||
expect(page).not_to have_css(".map-icon")
|
expect(page).not_to have_css ".map-icon"
|
||||||
end
|
end
|
||||||
|
|
||||||
place_map_at(-68.592487, -62.391357)
|
place_map_at(-68.592487, -62.391357)
|
||||||
find("#new_map_location").click
|
|
||||||
|
|
||||||
within ".map-location" do
|
within_fieldset "Map location" do
|
||||||
|
find("#new_map_location").click
|
||||||
|
|
||||||
expect(page).to have_css(".map-icon")
|
expect(page).to have_css(".map-icon")
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -162,8 +149,8 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
|
|
||||||
go_back
|
go_back
|
||||||
|
|
||||||
within ".map-location" do
|
within_fieldset "Map location" do
|
||||||
expect(page).to have_css(".map-icon")
|
expect(page).to have_css ".map-icon"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -180,17 +167,27 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
end
|
end
|
||||||
|
|
||||||
describe "At #{mappable_edit_path}", if: mappable_edit_path.present? do
|
describe "At #{mappable_edit_path}", if: mappable_edit_path.present? do
|
||||||
scenario "Should edit map on #{mappable_factory_name} and contain default values" do
|
scenario "Should edit mappable on #{mappable_factory_name} without changing the map" do
|
||||||
mappable.map_location.update!(latitude: 51.48, longitude: 0.0)
|
mappable.map_location.update!(latitude: 51.48, longitude: 0.0)
|
||||||
|
|
||||||
do_login_for mappable.author, management: management
|
do_login_for mappable.author, management: management
|
||||||
|
|
||||||
visit send(mappable_edit_path, id: mappable.id)
|
visit send(mappable_edit_path, id: mappable.id)
|
||||||
|
|
||||||
expect(page).to have_content "Navigate the map to the location and place the marker."
|
expect(page).to have_content "Navigate the map to the location and place the marker."
|
||||||
|
expect(page).to have_css ".map-icon[aria-label='Latitude: 51.48. Longitude: 0.0']"
|
||||||
expect(page).to have_field "#{mappable_factory_name}_map_location_attributes_latitude", type: :hidden,
|
expect(page).to have_field "#{mappable_factory_name}_map_location_attributes_latitude", type: :hidden,
|
||||||
with: "51.48"
|
with: "51.48"
|
||||||
expect(page).to have_field "#{mappable_factory_name}_map_location_attributes_longitude", type: :hidden,
|
expect(page).to have_field "#{mappable_factory_name}_map_location_attributes_longitude", type: :hidden,
|
||||||
with: "0.0"
|
with: "0.0"
|
||||||
|
|
||||||
|
fill_in "#{mappable_factory_name.camelize} title", with: "New title"
|
||||||
|
click_button "Save changes"
|
||||||
|
|
||||||
|
expect(page).not_to have_button "Save changes"
|
||||||
|
expect(page).to have_css ".map-location"
|
||||||
|
expect(page).to have_css ".map-location[data-marker-latitude='51.48']"
|
||||||
|
expect(page).to have_css ".map-location[data-marker-longitude='0.0']"
|
||||||
end
|
end
|
||||||
|
|
||||||
scenario "Should edit default values from map on #{mappable_factory_name} edit page" do
|
scenario "Should edit default values from map on #{mappable_factory_name} edit page" do
|
||||||
@@ -200,7 +197,10 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
do_login_for mappable.author, management: management
|
do_login_for mappable.author, management: management
|
||||||
|
|
||||||
visit send(mappable_edit_path, id: mappable.id)
|
visit send(mappable_edit_path, id: mappable.id)
|
||||||
find(".map-location").click(x: 30, y: 30)
|
|
||||||
|
within_fieldset "Map location" do
|
||||||
|
find(".map-location").click(x: 30, y: 30)
|
||||||
|
end
|
||||||
|
|
||||||
new_latitude = find_field(
|
new_latitude = find_field(
|
||||||
"#{mappable_factory_name}_map_location_attributes_latitude", type: :hidden
|
"#{mappable_factory_name}_map_location_attributes_latitude", type: :hidden
|
||||||
@@ -219,31 +219,16 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
expect(page).not_to have_css ".map-location[data-marker-longitude='#{original_longitude}']"
|
expect(page).not_to have_css ".map-location[data-marker-longitude='#{original_longitude}']"
|
||||||
end
|
end
|
||||||
|
|
||||||
scenario "Should edit mappable on #{mappable_factory_name} without change map" do
|
|
||||||
original_longitude = map_location.longitude
|
|
||||||
original_latitude = map_location.latitude
|
|
||||||
|
|
||||||
do_login_for mappable.author, management: management
|
|
||||||
|
|
||||||
visit send(mappable_edit_path, id: mappable.id)
|
|
||||||
fill_in "#{mappable_factory_name.camelize} title", with: "New title"
|
|
||||||
click_button "Save changes"
|
|
||||||
|
|
||||||
expect(page).not_to have_button "Save changes"
|
|
||||||
expect(page).to have_css ".map-location"
|
|
||||||
expect(page).to have_css ".map-location[data-marker-latitude='#{original_latitude}']"
|
|
||||||
expect(page).to have_css ".map-location[data-marker-longitude='#{original_longitude}']"
|
|
||||||
end
|
|
||||||
|
|
||||||
scenario "Can not display map on #{mappable_factory_name} edit when remove map marker" do
|
scenario "Can not display map on #{mappable_factory_name} edit when remove map marker" do
|
||||||
do_login_for mappable.author, management: management
|
do_login_for mappable.author, management: management
|
||||||
|
|
||||||
visit send(mappable_edit_path, id: mappable.id)
|
visit send(mappable_edit_path, id: mappable.id)
|
||||||
click_button "Remove map marker"
|
within_fieldset("Map location") { click_button "Remove map marker" }
|
||||||
click_button "Save changes"
|
click_button "Save changes"
|
||||||
|
|
||||||
expect(page).not_to have_button "Save changes"
|
expect(page).not_to have_button "Save changes"
|
||||||
expect(page).not_to have_css ".map-location"
|
expect(page).not_to have_css ".map-location"
|
||||||
|
expect(page).not_to have_content "Map location can't be blank"
|
||||||
end
|
end
|
||||||
|
|
||||||
scenario "Can not display map on #{mappable_factory_name} edit when feature.map is disabled" do
|
scenario "Can not display map on #{mappable_factory_name} edit when feature.map is disabled" do
|
||||||
@@ -257,17 +242,6 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
expect(page).not_to have_button "Save changes"
|
expect(page).not_to have_button "Save changes"
|
||||||
expect(page).not_to have_css ".map-location"
|
expect(page).not_to have_css ".map-location"
|
||||||
end
|
end
|
||||||
|
|
||||||
scenario "No need to skip map on update" do
|
|
||||||
do_login_for mappable.author, management: management
|
|
||||||
|
|
||||||
visit send(mappable_edit_path, id: mappable.id)
|
|
||||||
click_button "Remove map marker"
|
|
||||||
click_button "Save changes"
|
|
||||||
|
|
||||||
expect(page).not_to have_button "Save changes"
|
|
||||||
expect(page).not_to have_content "Map location can't be blank"
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "At #{mappable_show_path}" do
|
describe "At #{mappable_show_path}" do
|
||||||
@@ -282,8 +256,10 @@ shared_examples "mappable" do |mappable_factory_name, mappable_association_name,
|
|||||||
do_login_for user, management: management if management
|
do_login_for user, management: management if management
|
||||||
visit send(mappable_show_path, arguments)
|
visit send(mappable_show_path, arguments)
|
||||||
|
|
||||||
|
label = "Latitude: #{map_location.latitude}. Longitude: #{map_location.longitude}"
|
||||||
|
|
||||||
within ".map-location" do
|
within ".map-location" do
|
||||||
expect(page).to have_css ".map-icon[aria-label='#{mappable.title}']"
|
expect(page).to have_css ".map-icon[aria-label='#{label}']"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -21,22 +21,16 @@ describe "Admin settings", :admin do
|
|||||||
end
|
end
|
||||||
|
|
||||||
describe "Map settings initialization" do
|
describe "Map settings initialization" do
|
||||||
before do
|
scenario "Map is only initialized when the map settings tab content is shown" do
|
||||||
Setting["feature.map"] = true
|
Setting["feature.map"] = true
|
||||||
end
|
|
||||||
|
|
||||||
scenario "When `Map settings` tab content is hidden map should not be initialized" do
|
|
||||||
visit admin_settings_path
|
visit admin_settings_path
|
||||||
|
|
||||||
expect(page).not_to have_css("#admin-map.leaflet-container", visible: :all)
|
expect(page).not_to have_css ".map-location.leaflet-container", visible: :all
|
||||||
end
|
|
||||||
|
|
||||||
scenario "When `Map settings` tab content is shown map should be initialized" do
|
|
||||||
visit admin_settings_path
|
|
||||||
|
|
||||||
click_link "Map configuration"
|
click_link "Map configuration"
|
||||||
|
|
||||||
expect(page).to have_css("#admin-map.leaflet-container")
|
expect(page).to have_css ".map-location.leaflet-container"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -50,41 +44,7 @@ describe "Admin settings", :admin do
|
|||||||
expect(page).to have_content "To show the map to users you must enable " \
|
expect(page).to have_content "To show the map to users you must enable " \
|
||||||
'"Proposals and budget investments geolocation" ' \
|
'"Proposals and budget investments geolocation" ' \
|
||||||
'on "Features" tab.'
|
'on "Features" tab.'
|
||||||
expect(page).not_to have_css("#admin-map")
|
expect(page).not_to have_css ".map-location"
|
||||||
end
|
|
||||||
|
|
||||||
scenario "Should be able when map feature activated" do
|
|
||||||
Setting["feature.map"] = true
|
|
||||||
|
|
||||||
visit admin_settings_path
|
|
||||||
click_link "Map configuration"
|
|
||||||
|
|
||||||
expect(page).to have_css("#admin-map")
|
|
||||||
expect(page).not_to have_content "To show the map to users you must enable " \
|
|
||||||
'"Proposals and budget investments geolocation" ' \
|
|
||||||
'on "Features" tab.'
|
|
||||||
end
|
|
||||||
|
|
||||||
scenario "Should show successful notice" do
|
|
||||||
Setting["feature.map"] = true
|
|
||||||
|
|
||||||
visit admin_settings_path
|
|
||||||
click_link "Map configuration"
|
|
||||||
|
|
||||||
within "#map-form" do
|
|
||||||
click_button "Update"
|
|
||||||
end
|
|
||||||
|
|
||||||
expect(page).to have_content "Map configuration updated successfully"
|
|
||||||
end
|
|
||||||
|
|
||||||
scenario "Should display marker by default" do
|
|
||||||
Setting["feature.map"] = true
|
|
||||||
|
|
||||||
visit admin_settings_path
|
|
||||||
|
|
||||||
expect(find("#latitude", visible: :hidden).value).to eq "51.48"
|
|
||||||
expect(find("#longitude", visible: :hidden).value).to eq "0.0"
|
|
||||||
end
|
end
|
||||||
|
|
||||||
scenario "Should update marker" do
|
scenario "Should update marker" do
|
||||||
@@ -92,13 +52,26 @@ describe "Admin settings", :admin do
|
|||||||
|
|
||||||
visit admin_settings_path
|
visit admin_settings_path
|
||||||
click_link "Map configuration"
|
click_link "Map configuration"
|
||||||
find("#admin-map").click
|
|
||||||
|
expect(page).to have_css ".map-location"
|
||||||
|
expect(page).not_to have_content "To show the map to users you must enable " \
|
||||||
|
'"Proposals and budget investments geolocation" ' \
|
||||||
|
'on "Features" tab.'
|
||||||
|
|
||||||
|
expect(page).to have_field "Latitude", with: "51.48"
|
||||||
|
expect(page).to have_field "Longitude", with: "0.0"
|
||||||
|
expect(page).to have_css ".map-icon[aria-label='Latitude: 51.48. Longitude: 0.0']"
|
||||||
|
|
||||||
within "#map-form" do
|
within "#map-form" do
|
||||||
|
find(".map-location").click
|
||||||
click_button "Update"
|
click_button "Update"
|
||||||
end
|
end
|
||||||
|
|
||||||
expect(find("#latitude", visible: :hidden).value).not_to eq "51.48"
|
|
||||||
expect(page).to have_content "Map configuration updated successfully"
|
expect(page).to have_content "Map configuration updated successfully"
|
||||||
|
expect(page).to have_field "Latitude"
|
||||||
|
expect(page).to have_css ".map-icon"
|
||||||
|
expect(page).not_to have_field "Latitude", with: "51.48"
|
||||||
|
expect(page).not_to have_css ".map-icon[aria-label='Latitude: 51.48. Longitude: 0.0']"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -305,9 +305,8 @@ describe "Budgets" do
|
|||||||
{
|
{
|
||||||
lat: map_location[:latitude],
|
lat: map_location[:latitude],
|
||||||
long: map_location[:longitude],
|
long: map_location[:longitude],
|
||||||
investment_title: investment.title,
|
title: investment.title,
|
||||||
investment_id: investment.id,
|
link: "/budgets/#{budget.id}/investments/#{investment.id}"
|
||||||
budget_id: budget.id
|
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -316,7 +315,8 @@ describe "Budgets" do
|
|||||||
visit budgets_path
|
visit budgets_path
|
||||||
|
|
||||||
within ".map-location" do
|
within ".map-location" do
|
||||||
expect(page).to have_css(".map-icon", count: 1, visible: :all)
|
expect(page).to have_css ".map-icon", count: 1, visible: :all
|
||||||
|
expect(page).to have_css ".map-icon[aria-label='#{investment.title}']", visible: :all
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user