Move browse JS to page-specific script file
authorJohn Firebaugh <john.firebaugh@gmail.com>
Sat, 29 Sep 2012 21:45:15 +0000 (14:45 -0700)
committerTom Hughes <tom@compton.nu>
Sun, 30 Sep 2012 11:14:25 +0000 (12:14 +0100)
app/assets/javascripts/browse.js [new file with mode: 0644]
app/views/browse/_map.html.erb
config/environments/production.rb

diff --git a/app/assets/javascripts/browse.js b/app/assets/javascripts/browse.js
new file mode 100644 (file)
index 0000000..4249401
--- /dev/null
@@ -0,0 +1,88 @@
+function remoteEditHandler(event, bbox, select) {
+  var left = bbox.left - 0.0001;
+  var top = bbox.top + 0.0001;
+  var right = bbox.right + 0.0001;
+  var bottom = bbox.bottom - 0.0001;
+  var loaded = false;
+
+  $("#linkloader").load(function () { loaded = true; });
+
+  if (select) {
+    $("#linkloader").attr("src", "http://127.0.0.1:8111/load_and_zoom?left=" + left + "&top=" + top + "&right=" + right + "&bottom=" + bottom + "&select=" + select);
+  } else {
+    $("#linkloader").attr("src", "http://127.0.0.1:8111/load_and_zoom?left=" + left + "&top=" + top + "&right=" + right + "&bottom=" + bottom);
+  }
+
+  setTimeout(function () {
+    if (!loaded) alert(I18n.t('site.index.remote_failed'));
+  }, 1000);
+
+  return false;
+}
+
+function init() {
+  var map = createMap("small_map", {
+    controls: [ new OpenLayers.Control.Navigation() ]
+  });
+
+  var params = $("#small_map").data();
+  if (params.type == "changeset") {
+    var bbox = new OpenLayers.Bounds(params.minlon, params.minlat, params.maxlon, params.maxlat);
+    var centre = bbox.getCenterLonLat();
+
+    map.zoomToExtent(proj(bbox));
+    addBoxToMap(bbox);
+
+    $("#loading").hide();
+    $("#browse_map .geolink").show();
+
+    $("a[data-editor=remote]").click(function (event) {
+      return remoteEditHandler(event, bbox);
+    });
+
+    updatelinks(centre.lon, centre.lat, 16, null, params.minlon, params.minlat, params.maxlon, params.maxlat);
+  } else {
+    var url = "/api/" + OSM.API_VERSION + "/" + params.type + "/" + params.id;
+
+    if (params.type != "node") {
+      url += "/full";
+    } else if (!params.visible) {
+      var previous_version = params.version - 1;
+      url += "/" + previous_version;
+    }
+
+    $("#object_larger_map").hide();
+    $("#object_edit").hide();
+
+    addObjectToMap(url, true, function(extent) {
+      $("#loading").hide();
+      $("#browse_map .geolink").show();
+
+      if (extent) {
+        extent.transform(map.getProjectionObject(), map.displayProjection);
+
+        var centre = extent.getCenterLonLat();
+
+        $("a.bbox[data-editor=remote]").click(function (event) {
+          return remoteEditHandler(event, extent);
+        });
+
+        $("a.object[data-editor=remote]").click(function (event) {
+          return remoteEditHandler(event, extent, params.type + params.id);
+        });
+
+        $("#object_larger_map").show();
+        $("#object_edit").show();
+
+        updatelinks(centre.lon, centre.lat, 16, null, extent.left, extent.bottom, extent.right, extent.top, params.type, params.id);
+      } else {
+        $("#small_map").hide();
+      }
+    });
+  }
+
+  createMenu("area_edit", "area_edit_menu", "right");
+  createMenu("object_edit", "object_edit_menu", "right");
+}
+
+window.onload = init;
index ff6ccae3c9ce7a2bfdd7976b5c07d76f118c1026..d598847fc5b5491a3e3756d14011e620f55df248 100644 (file)
@@ -3,6 +3,11 @@
 
 <div id="browse_map">
   <% if map.instance_of? Changeset or (map.instance_of? Node and map.version > 1) or map.visible %>
+
+  <% content_for :head do %>
+    <%= javascript_include_tag "browse" %>
+  <% end %>
+
   <%
      if map.instance_of? Changeset
        bbox = map.bbox.to_unscaled
     <% end %>
   </ul>
 </div>
-
-<% if map.instance_of? Changeset or (map.instance_of? Node and map.version > 1) or map.visible %>
-  <script type="text/javascript">
-    function remoteEditHandler(event, bbox, select) {
-      var left = bbox.left - 0.0001;
-      var top = bbox.top + 0.0001;
-      var right = bbox.right + 0.0001;
-      var bottom = bbox.bottom - 0.0001;
-      var loaded = false;
-
-      $("#linkloader").load(function () { loaded = true; });
-
-      if (select) {
-        $("#linkloader").attr("src", "http://127.0.0.1:8111/load_and_zoom?left=" + left + "&top=" + top + "&right=" + right + "&bottom=" + bottom + "&select=" + select);
-      } else {
-        $("#linkloader").attr("src", "http://127.0.0.1:8111/load_and_zoom?left=" + left + "&top=" + top + "&right=" + right + "&bottom=" + bottom);
-      }
-
-      setTimeout(function () {
-        if (!loaded) alert(I18n.t('site.index.remote_failed'));
-      }, 1000);
-
-      return false;
-    }
-
-    function init() {
-      var map = createMap("small_map", {
-        controls: [ new OpenLayers.Control.Navigation() ]
-      });
-
-      var params = $("#small_map").data();
-      if (params.type == "changeset") {
-        var bbox = new OpenLayers.Bounds(params.minlon, params.minlat, params.maxlon, params.maxlat);
-        var centre = bbox.getCenterLonLat();
-
-        map.zoomToExtent(proj(bbox));
-        addBoxToMap(bbox);
-
-        $("#loading").hide();
-        $("#browse_map .geolink").show();
-
-        $("a[data-editor=remote]").click(function (event) {
-          return remoteEditHandler(event, bbox);
-        });
-
-        updatelinks(centre.lon, centre.lat, 16, null, params.minlon, params.minlat, params.maxlon, params.maxlat);
-      } else {
-        var url = "/api/" + OSM.API_VERSION + "/" + params.type + "/" + params.id;
-
-        if (params.type != "node") {
-          url += "/full";
-        } else if (!params.visible) {
-          var previous_version = params.version - 1;
-          url += "/" + previous_version;
-        }
-
-        $("#object_larger_map").hide();
-        $("#object_edit").hide();
-
-        addObjectToMap(url, true, function(extent) {
-          $("#loading").hide();
-          $("#browse_map .geolink").show();
-
-          if (extent) {
-            extent.transform(map.getProjectionObject(), map.displayProjection);
-
-            var centre = extent.getCenterLonLat();
-
-            $("a.bbox[data-editor=remote]").click(function (event) {
-              return remoteEditHandler(event, extent);
-            });
-
-            $("a.object[data-editor=remote]").click(function (event) {
-              return remoteEditHandler(event, extent, params.type + params.id);
-            });
-
-            $("#object_larger_map").show();
-            $("#object_edit").show();
-
-            updatelinks(centre.lon, centre.lat, 16, null, extent.left, extent.bottom, extent.right, extent.top, params.type, params.id);
-          } else {
-            $("#small_map").hide();
-          }
-        });
-      }
-
-      createMenu("area_edit", "area_edit_menu", "right");
-      createMenu("object_edit", "object_edit_menu", "right");
-    }
-
-    window.onload = init;
-  </script>
-<% end %>
index a930fb93bc0b485a98872841e02324c57e2b64ad..054f65404dd0e42541843cc3e0a485a0a339b1ec 100644 (file)
@@ -56,7 +56,7 @@ OpenStreetMap::Application.configure do
   # config.action_controller.asset_host = "http://assets.example.com"
 
   # Precompile additional assets (application.js, application.css, and all non-JS/CSS are already added)
-  config.assets.precompile += %w( index.js edit.js pngfix.js swfobject.js )
+  config.assets.precompile += %w( index.js edit.js browse.js pngfix.js swfobject.js )
   config.assets.precompile += %w( large-ltr.css small-ltr.css print-ltr.css )
   config.assets.precompile += %w( large-rtl.css small-rtl.css print-rtl.css )
   config.assets.precompile += %w( browse.css theme/openstreetmap/style.css )