$(document).ready(function () {
- function remoteEditHandler(bbox, select) {
- var left = bbox.getWest() - 0.0001;
- var top = bbox.getNorth() + 0.0001;
- var right = bbox.getEast() + 0.0001;
- var bottom = bbox.getSouth() - 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;
- }
var map = L.map("small_map", {
attributionControl: false,
zoomControl: false
}).addLayer(new L.OSM.Mapnik());
- L.control.zoom({position: 'topright'})
+ L.OSM.zoom()
.addTo(map);
- $("#small_map").on("resized", function () {
- map.invalidateSize();
- });
-
var params = $("#small_map").data();
+ var object, bbox;
if (params.type == "changeset") {
- var bbox = L.latLngBounds([params.minlat, params.minlon],
- [params.maxlat, params.maxlon]);
+ bbox = L.latLngBounds([params.minlat, params.minlon],
+ [params.maxlat, params.maxlon]);
map.fitBounds(bbox);
}).addTo(map);
$("#loading").hide();
- $("#browse_map .geolink").show();
+ $("#browse_map .secondary-actions").show();
$("a[data-editor=remote]").click(function () {
return remoteEditHandler(bbox);
});
- var centre = bbox.getCenter();
- updatelinks(centre.lng, centre.lat, 16, null, params.minlon, params.minlat, params.maxlon, params.maxlat);
+ updatelinks(map.getCenter(), 16, null, [[params.minlat, params.minlon],
+ [params.maxlat, params.maxlon]]);
} else if (params.type == "note") {
- var object = {type: params.type, id: params.id};
+ object = {type: params.type, id: params.id};
map.setView([params.lat, params.lon], 16);
L.marker([params.lat, params.lon], { icon: getUserIcon() }).addTo(map);
- var bbox = map.getBounds();
+ bbox = map.getBounds();
$("#loading").hide();
- $("#browse_map .geolink").show();
+ $("#browse_map .secondary-actions").show();
$("a[data-editor=remote]").click(function () {
return remoteEditHandler(bbox);
});
- updatelinks(params.lon, params.lat, 16, null,
- bbox.getWest(), bbox.getSouth(),
- bbox.getEast(), bbox.getNorth(),
- object);
+ updatelinks(params, 16, null, bbox, object);
} else {
- $("#object_larger_map").hide();
- $("#object_edit").hide();
+ $("#object_larger_map, #object_edit").hide();
- var object = {type: params.type, id: params.id};
+ object = {type: params.type, id: params.id};
if (!params.visible) {
object.version = params.version - 1;
}
- addObjectToMap(object, map, {
- zoom: true,
+ map.addObject(object, {
+ zoom: true,
callback: function(extent) {
$("#loading").hide();
- $("#browse_map .geolink").show();
- if (extent) {
+ if (extent && extent.isValid()) {
+ $("#browse_map .secondary-actions").show();
+
$("a.bbox[data-editor=remote]").click(function () {
return remoteEditHandler(extent);
});
$("#object_larger_map").show();
$("#object_edit").show();
- var centre = extent.getCenter();
- updatelinks(centre.lng,
- centre.lat,
- 16, null,
- extent.getWest(),
- extent.getSouth(),
- extent.getEast(),
- extent.getNorth(),
- object);
- } else {
- $("#small_map").hide();
+ updatelinks(map.getCenter(), 16, null, extent, object);
}
}
});
}
-
- createMenu("area_edit", "area_edit_menu", "right");
- createMenu("object_edit", "object_edit_menu", "right");
});