]> git.openstreetmap.org Git - rails.git/blobdiff - app/assets/javascripts/index/history.js
Restore autofocusing of the search field
[rails.git] / app / assets / javascripts / index / history.js
index 27774f05b55476eddf0cc5fe628c061e0a944e45..8103f047ed5d054e29c0a65fb27c2654150a965b 100644 (file)
@@ -1,3 +1,5 @@
+//= require jquery.simulate
+
 OSM.History = function(map) {
   var page = {};
 
@@ -41,33 +43,10 @@ OSM.History = function(map) {
   }
 
   function clickChangeset(id, e) {
-    var evt, el = $("#changeset_" + id).find("a.changeset_id")[0];
-    if ('createEvent' in document) {
-      evt = document.createEvent('MouseEvents');
-      evt.initMouseEvent('click',
-        true, // canBubble
-        true, // cancelable
-        window, // 'AbstractView'
-        e.clicks, // click count
-        e.screenX, // screenX
-        e.screenY, // screenY
-        e.clientX, // clientX
-        e.clientY, // clientY
-        e.ctrlKey, // ctrl
-        e.altKey, // alt
-        e.shiftKey, // shift
-        e.metaKey, // meta
-        e.button, // mouse button
-        e.relatedTarget // relatedTarget
-      );
-      el.dispatchEvent(evt);
-    } else {
-      evt = document.createEventObject();
-      el.fireEvent('onclick', evt);
-    }
+    $("#changeset_" + id).find("a.changeset_id").simulate("click", e);
   }
 
-  function loadData() {
+  function update() {
     var data = {list: '1'};
 
     if (window.location.pathname === '/history') {
@@ -83,6 +62,11 @@ OSM.History = function(map) {
         updateMap();
       }
     });
+
+    var feedLink = $('link[type="application/atom+xml"]'),
+      feedHref = feedLink.attr('href').split('?')[0];
+
+    feedLink.attr('href', feedHref + '?bbox=' + data.bbox);
   }
 
   function loadMore(e) {
@@ -142,18 +126,15 @@ OSM.History = function(map) {
     map.addLayer(group);
 
     if (window.location.pathname === '/history') {
-      map.on("moveend", loadData)
+      map.on("moveend", update);
     }
 
-    loadData();
+    update();
   };
 
   page.unload = function() {
     map.removeLayer(group);
-
-    if (window.location.pathname === '/history') {
-      map.off("moveend", loadData)
-    }
+    map.off("moveend", update);
 
     $("#history_tab").removeClass("current");
   };