]> git.openstreetmap.org Git - rails.git/blobdiff - app/assets/javascripts/leaflet.sidebar.js
Use the distance_in_words_ago scope for trace display
[rails.git] / app / assets / javascripts / leaflet.sidebar.js
index 961842668f25432a3c4905e8df6f8b9a3163fc58..bb046f99ad13ae029c840912e7a7be611494a365 100644 (file)
@@ -1,7 +1,8 @@
-L.OSM.sidebar = function(selector) {
+L.OSM.sidebar = function (selector) {
   var control = {},
     sidebar = $(selector),
     current = $(),
   var control = {},
     sidebar = $(selector),
     current = $(),
+    currentButton = $(),
     map;
 
   control.addTo = function (_) {
     map;
 
   control.addTo = function (_) {
@@ -9,30 +10,37 @@ L.OSM.sidebar = function(selector) {
     return control;
   };
 
     return control;
   };
 
-  control.addPane = function(pane) {
+  control.addPane = function (pane) {
     pane
       .hide()
       .appendTo(sidebar);
   };
 
     pane
       .hide()
       .appendTo(sidebar);
   };
 
-  control.togglePane = function(pane) {
+  control.togglePane = function (pane, button) {
     current
       .hide()
     current
       .hide()
-      .trigger('hide');
+      .trigger("hide");
+
+    currentButton
+      .removeClass("active");
 
     if (current === pane) {
       $(sidebar).hide();
 
     if (current === pane) {
       $(sidebar).hide();
-      current = $();
+      current = currentButton = $();
     } else {
       $(sidebar).show();
       current = pane;
     } else {
       $(sidebar).show();
       current = pane;
+      currentButton = button || $();
     }
 
     }
 
+    map.invalidateSize({ pan: false, animate: false });
+
     current
       .show()
     current
       .show()
-      .trigger('show');
+      .trigger("show");
 
 
-    map.invalidateSize({pan: false, animate: false});
+    currentButton
+      .addClass("active");
   };
 
   return control;
   };
 
   return control;