+ ];
+ }
+
+ options = $.extend({zoomControl: true, panZoomControl: true, layerControl: true}, options);
+
+ map = L.map(divName, $.extend({}, options, {panControl: false, zoomsliderControl: false, maxZoom: 18}));
+
+ if (map.attributionControl) {
+ map.attributionControl.setPrefix('');
+ }
+
+ if (options.panZoomControl) {
+ new L.Control.Pan().addTo(map);
+ new L.Control.Zoomslider({stepHeight: 7}).addTo(map);
+ }
+
+ var layersControl = L.control.layers();
+
+ if (options.layerControl) {
+ layersControl.addTo(map);
+ map.layersControl = layersControl;
+ }
+
+ for (var i = 0; i < layers.length; i++) {
+ layers[i].layer = new (layers[i].klass)(layers[i]);
+ layersControl.addBaseLayer(layers[i].layer, layers[i].name);
+ }
+
+ layers[0].layer.addTo(map);
+
+ $("#" + divName).on("resized", function () {
+ map.invalidateSize();
+ });
+
+ return map;
+}
+
+function getUserIcon(url) {
+ return L.icon({
+ iconUrl: url || <%= asset_path('marker-red.png').to_json %>,
+ iconSize: [25, 41],
+ iconAnchor: [12, 41],
+ popupAnchor: [1, -34],
+ shadowUrl: <%= asset_path('images/marker-shadow.png').to_json %>,
+ shadowSize: [41, 41]
+ });
+}
+
+function addObjectToMap(object, options) {
+ if (objectLoader) {
+ objectLoader.abort();
+ }
+
+ if (objectLayer) {
+ map.removeLayer(objectLayer);
+ }
+
+ objectLoader = $.ajax({
+ url: OSM.apiUrl(object),
+ dataType: "xml",
+ success: function (xml) {
+ objectLayer = new L.OSM.DataLayer(null, {
+ styles: {
+ node: options.style,
+ way: options.style,
+ area: options.style
+ }
+ });
+
+ objectLayer.interestingNode = function (node, ways, relations) {
+ if (object.type === "node") {
+ return true;
+ } else if (object.type === "relation") {
+ for (var i = 0; i < relations.length; i++)
+ if (relations[i].members.indexOf(node) != -1)
+ return true;
+ } else {
+ return false;
+ }
+ };
+
+ objectLayer.addData(xml);
+
+ var bounds = objectLayer.getBounds();
+
+ if (options.zoom) {
+ map.fitBounds(bounds);