]> git.openstreetmap.org Git - rails.git/blob - app/assets/javascripts/index.js
Fix mobile map and other minor mobile adjustments
[rails.git] / app / assets / javascripts / index.js
1 //= require_self
2 //= require index/browse
3 //= require index/export
4 //= require index/key
5
6 $(document).ready(function () {
7   var permalinks = $("#permalink").detach().html();
8   var marker;
9   var params = OSM.mapParams();
10   var map = createMap("map");
11
12   L.control.scale().addTo(map);
13
14   map.attributionControl.setPrefix(permalinks);
15
16   map.on("moveend baselayerchange", updateLocation);
17
18   if (!params.object_zoom) {
19     if (params.bbox) {
20       var bbox = L.latLngBounds([params.minlat, params.minlon],
21                                 [params.maxlat, params.maxlon]);
22
23       map.fitBounds(bbox);
24
25       if (params.box) {
26         addBoxToMap(bbox);
27       }
28     } else {
29       map.setView([params.lat, params.lon], params.zoom);
30     }
31   }
32
33   if (params.layers) {
34     setMapLayers(params.layers);
35   }
36
37   if (params.marker) {
38     marker = L.marker([params.mlat, params.mlon], {icon: getUserIcon()}).addTo(map);
39   }
40
41   if (params.object) {
42     addObjectToMap(params.object, params.object_zoom);
43   }
44
45   handleResize();
46
47   $("body").on("click", "a.set_position", function (e) {
48     e.preventDefault();
49
50     var data = $(this).data();
51     var centre = L.latLng(data.lat, data.lon);
52
53     if (data.minLon && data.minLat && data.maxLon && data.maxLat) {
54       map.fitBounds([[data.minLat, data.minLon],
55                      [data.maxLat, data.maxLon]]);
56     } else {
57       map.setView(centre, data.zoom);
58     }
59
60     if (marker) {
61       map.removeLayer(marker);
62     }
63
64     marker = L.marker(centre, {icon: getUserIcon()}).addTo(map);
65   });
66
67   function updateLocation() {
68     var center = map.getCenter();
69     var zoom = map.getZoom();
70     var layers = getMapLayers();
71     var extents = map.getBounds();
72
73     updatelinks(center.lng,
74                 center.lat,
75                 zoom,
76                 layers,
77                 extents.getWestLng(),
78                 extents.getSouthLat(),
79                 extents.getEastLng(),
80                 extents.getNorthLat(),
81                 params.object);
82
83     var expiry = new Date();
84     expiry.setYear(expiry.getFullYear() + 10);
85     $.cookie("_osm_location", [center.lng, center.lat, zoom, layers].join("|"), {expires: expiry});
86   }
87
88   function remoteEditHandler() {
89     var extent = map.getBounds();
90     var loaded = false;
91
92     $("#linkloader").load(function () { loaded = true; });
93     $("#linkloader").attr("src", "http://127.0.0.1:8111/load_and_zoom?left=" + extent.getWestLng()
94                                                                    + "&bottom=" + extent.getSouthLat()
95                                                                    + "&right=" + extent.getEastLng()
96                                                                    + "&top=" + extent.getNorthLat());
97
98     setTimeout(function () {
99       if (!loaded) alert(I18n.t('site.index.remote_failed'));
100     }, 1000);
101
102     return false;
103   }
104
105   $("a[data-editor=remote]").click(remoteEditHandler);
106
107   if (OSM.preferred_editor == "remote" && $('body').hasClass("site-edit")) {
108     remoteEditHandler();
109   }
110
111   $(window).resize(handleResize);
112
113   $("#search_form").submit(function () {
114     var bounds = map.getBounds();
115
116     $("#sidebar_title").html(I18n.t('site.sidebar.search_results'));
117     $("#sidebar_content").load($(this).attr("action"), {
118       query: $("#query").val(),
119       minlon: bounds.getWestLng(),
120       minlat: bounds.getSouthLat(),
121       maxlon: bounds.getEastLng(),
122       maxlat: bounds.getNorthLat()
123     }, openSidebar);
124
125     return false;
126   });
127
128   if ($("#query").val()) {
129     $("#search_form").submit();
130   }
131
132   // Focus the search field for browsers that don't support
133   // the HTML5 'autofocus' attribute
134   if (!("autofocus" in document.createElement("input"))) {
135     $("#query").focus();
136   }
137 });