]> git.openstreetmap.org Git - rails.git/blobdiff - app/assets/javascripts/edit/id.js.erb
iD: listen to manual hashchanges from iframe parent
[rails.git] / app / assets / javascripts / edit / id.js.erb
index bedabb1f9e7cfcf7a5beb3c99e5ef70199dd3e22..90318788c72de8342527aaeb3ab7b944d0d86ecf 100644 (file)
@@ -1,13 +1,16 @@
+//= require qs/dist/qs
+
 $(document).ready(function () {
   var id = $("#id-embed");
 
 $(document).ready(function () {
   var id = $("#id-embed");
 
-  if (id.data("key")) {
-    var hashParams = OSM.params(location.hash.substring(1)),
-        mapParams = OSM.mapParams(),
-        params = {};
+  if (id.data("configured") === true) {
+    var hash = location.hash.substring(1);
+    var hashParams = hash ? OSM.params(hash) : {};
+    var mapParams = OSM.mapParams();
+    var params = {};
 
     if (mapParams.object) {
 
     if (mapParams.object) {
-      params.id = mapParams.object.type[0] + mapParams.object.id;
+      params.id = mapParams.object.type + '/' + mapParams.object.id;
       mapParams = OSM.parseHash(location.hash);
       if (mapParams.center) {
         params.map = mapParams.zoom + '/' + mapParams.center.lat + '/' + mapParams.center.lng;
       mapParams = OSM.parseHash(location.hash);
       if (mapParams.center) {
         params.map = mapParams.zoom + '/' + mapParams.center.lat + '/' + mapParams.center.lng;
@@ -20,7 +23,21 @@ $(document).ready(function () {
 
     if (hashParams.background) params.background = hashParams.background;
     if (hashParams.comment) params.comment = hashParams.comment;
 
     if (hashParams.background) params.background = hashParams.background;
     if (hashParams.comment) params.comment = hashParams.comment;
+    if (hashParams.disable_features) params.disable_features = hashParams.disable_features;
+    if (hashParams.hashtags) params.hashtags = hashParams.hashtags;
+    if (hashParams.locale) params.locale = hashParams.locale;
+    if (hashParams.maprules) params.maprules = hashParams.maprules;
     if (hashParams.offset) params.offset = hashParams.offset;
     if (hashParams.offset) params.offset = hashParams.offset;
+    if (hashParams.photo) params.photo = hashParams.photo;
+    if (hashParams.photo_dates) params.photo_dates = hashParams.photo_dates;
+    if (hashParams.photo_overlay) params.photo_overlay = hashParams.photo_overlay;
+    if (hashParams.photo_username) params.photo_username = hashParams.photo_username;
+    if (hashParams.presets) params.presets = hashParams.presets;
+    if (hashParams.source) params.source = hashParams.source;
+    if (hashParams.validationDisable) params.validationDisable = hashParams.validationDisable;
+    if (hashParams.validationWarning) params.validationWarning = hashParams.validationWarning;
+    if (hashParams.validationError) params.validationError = hashParams.validationError;
+    if (hashParams.walkthrough) params.walkthrough = hashParams.walkthrough;
 
     if (id.data("gpx")) {
       params.gpx = id.data("gpx");
 
     if (id.data("gpx")) {
       params.gpx = id.data("gpx");
@@ -28,7 +45,7 @@ $(document).ready(function () {
       params.gpx = hashParams.gpx;
     }
 
       params.gpx = hashParams.gpx;
     }
 
-    id.attr("src", id.data("url") + "#" + querystring.stringify(params));
+    id.attr("src", id.data("url") + "#" + Qs.stringify(params));
   } else {
     alert(I18n.t("site.edit.id_not_configured"));
   }
   } else {
     alert(I18n.t("site.edit.id_not_configured"));
   }