From: Tom MacWright Date: Fri, 23 Mar 2012 21:45:50 +0000 (-0400) Subject: Introduce a new layer switcher X-Git-Tag: live~6309 X-Git-Url: https://git.openstreetmap.org./rails.git/commitdiff_plain/8f4ed911e094d359ed630f034b76e02bc8d51705?hp=afeee2923ff8340e4d9b8027a0d32b26bfcef17f Introduce a new layer switcher The new layer switcher behaves the same as the standard one but has less cruft and more attractive styling. --- diff --git a/app/assets/images/carat.png b/app/assets/images/carat.png new file mode 100644 index 000000000..7fdf17e32 Binary files /dev/null and b/app/assets/images/carat.png differ diff --git a/app/assets/javascripts/map.js.erb b/app/assets/javascripts/map.js.erb index aff258ad2..d05d00993 100644 --- a/app/assets/javascripts/map.js.erb +++ b/app/assets/javascripts/map.js.erb @@ -11,7 +11,7 @@ function createMap(divName, options) { controls: options.controls || [ new OpenLayers.Control.ArgParser(), new OpenLayers.Control.Attribution(), - new OpenLayers.Control.LayerSwitcher(), + new SimpleLayerSwitcher(), new OpenLayers.Control.Navigation(), new OpenLayers.Control.PanZoom(), new OpenLayers.Control.PanZoomBar(), diff --git a/app/assets/javascripts/openlayers.js.erb b/app/assets/javascripts/openlayers.js.erb index c428da014..9119a7b43 100644 --- a/app/assets/javascripts/openlayers.js.erb +++ b/app/assets/javascripts/openlayers.js.erb @@ -1,5 +1,6 @@ //= require OpenLayers //= require OpenStreetMap +//= require simplelayerswitcher OpenLayers.Util.imageURLs = { "404.png": "<%= asset_path 'img/404.png' %>", diff --git a/app/assets/javascripts/simplelayerswitcher.js b/app/assets/javascripts/simplelayerswitcher.js new file mode 100644 index 000000000..db3c720bb --- /dev/null +++ b/app/assets/javascripts/simplelayerswitcher.js @@ -0,0 +1,175 @@ +var SimpleLayerSwitcher = OpenLayers.Class(OpenLayers.Control, { + layerStates: null, + layersDiv: null, + ascending: true, + + initialize: function(options) { + OpenLayers.Control.prototype.initialize.apply(this, arguments); + this.layerStates = []; + }, + + destroy: function() { + OpenLayers.Event.stopObservingElement(this.div); + + //clear out layers info and unregister their events + this.map.events.un({ + "addlayer": this.redraw, + "changelayer": this.redraw, + "removelayer": this.redraw, + "changebaselayer": this.redraw, + scope: this + }); + OpenLayers.Control.prototype.destroy.apply(this, arguments); + }, + + setMap: function(map) { + OpenLayers.Control.prototype.setMap.apply(this, arguments); + + this.map.events.on({ + "addlayer": this.redraw, + "changelayer": this.redraw, + "removelayer": this.redraw, + "changebaselayer": this.redraw, + scope: this + }); + }, + + draw: function() { + OpenLayers.Control.prototype.draw.apply(this); + this.loadContents(); + this.redraw(); + return this.div; + }, + + checkRedraw: function() { + var redraw = false; + if ( !this.layerStates.length || + (this.map.layers.length != this.layerStates.length) ) { + redraw = true; + } else { + for (var i=0, len=this.layerStates.length; i
  • <%= link_to t('layouts.edit_with', :editor => t("editor.#{editor}.description")), {:controller => 'site', :action => 'edit', :editor => editor}, {:id => editor + 'anchor', :class => "geolink llz object"} %>
  • <% end %> + <% unless STATUS == :api_offline or STATUS == :database_offline %> +
  • <%= link_to_function(t('browse.start_rjs.data_layer_name'), 'toggleData()') %>
  • + <% end %> diff --git a/app/views/site/index.html.erb b/app/views/site/index.html.erb index 9102214af..fb8f4462e 100644 --- a/app/views/site/index.html.erb +++ b/app/views/site/index.html.erb @@ -135,8 +135,10 @@ end map = createMap("map"); <% unless STATUS == :api_offline or STATUS == :database_offline %> - map.dataLayer = new OpenLayers.Layer("<%= I18n.t 'browse.start_rjs.data_layer_name' %>", { "visibility": false }); - map.dataLayer.events.register("visibilitychanged", map.dataLayer, toggleData); + map.dataLayer = new OpenLayers.Layer("<%= I18n.t 'browse.start_rjs.data_layer_name' %>", { + visibility: false, + displayInLayerSwitcher: false + }); map.addLayer(map.dataLayer); <% end %> @@ -187,11 +189,7 @@ end } function toggleData() { - if (map.dataLayer.visibility) { - $.ajax({ url: "<%= url_for :controller => :browse, :action => :start %>" }); - } else if (map.dataLayer.active) { - closeSidebar(); - } + $.ajax({ url: "<%= url_for :controller => :browse, :action => :start %>" }); } function setPosition(lat, lon, zoom, min_lon, min_lat, max_lon, max_lat) { diff --git a/config/locales/en.yml b/config/locales/en.yml index 70b95fb65..f31330ed7 100644 --- a/config/locales/en.yml +++ b/config/locales/en.yml @@ -221,7 +221,7 @@ en: view_data: "View data for current map view" manually_select: "Manually select a different area" start_rjs: - data_layer_name: "Data" + data_layer_name: "Browse Map Data" data_frame_title: "Data" zoom_or_select: "Zoom in or select an area of the map to view" drag_a_box: "Drag a box on the map to select an area"