X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/35458c009652645972a9167d80aba1c4fdce82cf..aba79a5e3dba586d7762c353808f125476eb3d2d:/app/assets/javascripts/index.js diff --git a/app/assets/javascripts/index.js b/app/assets/javascripts/index.js index 91855f823..db858c7c1 100644 --- a/app/assets/javascripts/index.js +++ b/app/assets/javascripts/index.js @@ -93,6 +93,16 @@ $(document).ready(function () { map.dataLayer = new L.OSM.DataLayer(null); map.dataLayer.options.code = 'D'; + if (OSM.STATUS != 'api_offline' && OSM.STATUS != 'database_offline') { + if (params.layers.indexOf(map.noteLayer.options.code) >= 0) { + map.addLayer(map.noteLayer); + } + + if (params.layers.indexOf(map.dataLayer.options.code) >= 0) { + map.addLayer(map.dataLayer); + } + } + var position = $('html').attr('dir') === 'rtl' ? 'topleft' : 'topright'; L.OSM.zoom({position: position}) @@ -163,16 +173,14 @@ $(document).ready(function () { }); } - var marker = L.marker([0, 0], {icon: getUserIcon()}); - - if (!params.object_zoom) { - if (params.bounds) { - map.fitBounds(params.bounds); - } else { - map.setView([params.lat, params.lon], params.zoom); - } + if (params.bounds) { + map.fitBounds(params.bounds); + } else { + map.setView([params.lat, params.lon], params.zoom); } + var marker = L.marker([0, 0], {icon: getUserIcon()}); + if (params.marker) { marker.setLatLng([params.mlat, params.mlon]).addTo(map); } @@ -210,13 +218,15 @@ $(document).ready(function () { }); } - initializeBrowse(map, params); - initializeNotes(map, params); + initializeBrowse(map); + initializeNotes(map); OSM.Index = function(map) { - var page = {}; + var page = {}, minimized = false; page.pushstate = page.popstate = function(path) { + if (minimized) $("#sidebar").addClass("minimized"); + map.invalidateSize(); $("#view_tab").addClass("current"); $('#sidebar_content').load(path); }; @@ -225,18 +235,36 @@ $(document).ready(function () { $("#view_tab").removeClass("current"); }; + page.minimizeSidebar = function() { + $("#sidebar").addClass("minimized"); + map.invalidateSize(); + minimized = true; + }; + + $(document).on("click", "#sidebar_content .close", page.minimizeSidebar); + return page; }; OSM.Browse = function(map) { var page = {}; - page.pushstate = page.popstate = function(path) { - $('#sidebar_content').load(path, page.load); + page.pushstate = page.popstate = function(path, type, id) { + $("#sidebar").removeClass("minimized"); + map.invalidateSize(); + $('#sidebar_content').load(path, function() { + page.load(path, type, id); + }); }; - page.load = function() { - map.addObject(OSM.mapParams().object, {zoom: true}); + page.load = function(path, type, id) { + if (OSM.STATUS === 'api_offline' || OSM.STATUS === 'database_offline') return; + + if (type === 'note') { + map.noteLayer.showNote(parseInt(id)); + } else { + map.addObject({type: type, id: parseInt(id)}, {zoom: true}); + } }; page.unload = function() {