]> git.openstreetmap.org Git - rails.git/blob - app/assets/javascripts/index.js
Use $(document).ready() to initialise browse JS
[rails.git] / app / assets / javascripts / index.js
1 //= require index/browse
2 //= require index/export
3 //= require index/key
4
5 $(document).ready(function () {
6   var marker;
7   var params = OSM.mapParams();
8   var map = createMap("map");
9
10   if (!params.object_zoom) {
11     if (params.bbox) {
12       var bbox = new OpenLayers.Bounds(params.minlon, params.minlat, params.maxlon, params.maxlat);
13
14       map.zoomToExtent(proj(bbox));
15
16       if (params.box) {
17         $(window).load(function() { addBoxToMap(bbox) });
18       }
19     } else {
20       setMapCenter(new OpenLayers.LonLat(params.lon, params.lat), params.zoom);
21     }
22   }
23
24   if (params.layers) {
25     setMapLayers(params.layers);
26   }
27
28   if (params.marker) {
29     marker = addMarkerToMap(new OpenLayers.LonLat(params.mlon, params.mlat));
30   }
31
32   if (params.object) {
33     var url = "/api/" + OSM.API_VERSION + "/" + params.object_type + "/" + params.object_id;
34
35     if (params.object_type != "node") {
36       url += "/full";
37     }
38
39     $(window).load(function() { addObjectToMap(url, params.object_zoom) });
40   }
41
42   map.events.register("moveend", map, updateLocation);
43   map.events.register("changelayer", map, updateLocation);
44
45   updateLocation();
46   handleResize();
47
48   $("#show_data").click(function (e) {
49     $.ajax({ url: $(this).attr('href'), success: function (sidebarHtml) {
50       startBrowse(sidebarHtml);
51     }});
52     e.preventDefault();
53   });
54
55   $("body").on("click", "a.set_position", function () {
56     var data = $(this).data();
57     var centre = new OpenLayers.LonLat(data.lon, data.lat);
58
59     if (data.minLon && data.minLat && data.maxLon && data.maxLat) {
60       var bbox = new OpenLayers.Bounds(data.minLon, data.minLat, data.maxLon, data.maxLat);
61
62       map.zoomToExtent(proj(bbox));
63     } else {
64       setMapCenter(centre, data.zoom);
65     }
66
67     if (marker) {
68       removeMarkerFromMap(marker);
69     }
70
71     marker = addMarkerToMap(centre, getArrowIcon());
72
73     return false;
74   });
75
76   function updateLocation() {
77     var lonlat = unproj(map.getCenter());
78     var zoom = map.getZoom();
79     var layers = getMapLayers();
80     var extents = unproj(map.getExtent());
81     var expiry = new Date();
82
83     updatelinks(lonlat.lon, lonlat.lat, zoom, layers, extents.left, extents.bottom, extents.right, extents.top, params.object_type, params.object_id);
84
85     expiry.setYear(expiry.getFullYear() + 10);
86     $.cookie("_osm_location", [lonlat.lon, lonlat.lat, zoom, layers].join("|"), {expires: expiry});
87   }
88
89   function remoteEditHandler(event) {
90     var extent = unproj(map.getExtent());
91     var loaded = false;
92
93     $("#linkloader").load(function () { loaded = true; });
94     $("#linkloader").attr("src", "http://127.0.0.1:8111/load_and_zoom?left=" + extent.left + "&top=" + extent.top + "&right=" + extent.right + "&bottom=" + extent.bottom);
95
96     setTimeout(function () {
97       if (!loaded) alert(I18n.t('site.index.remote_failed'));
98     }, 1000);
99
100     return false;
101   }
102
103   $("a[data-editor=remote]").click(remoteEditHandler);
104
105   if (OSM.preferred_editor == "remote" && $('body').hasClass("site-edit")) {
106     remoteEditHandler();
107   }
108
109   $(window).resize(function() {
110     var centre = map.getCenter();
111     var zoom = map.getZoom();
112
113     handleResize();
114
115     map.setCenter(centre, zoom);
116   });
117
118   $("#exportanchor").click(function (e) {
119     $.ajax({ url: $(this).data('url'), success: function (sidebarHtml) {
120       startExport(sidebarHtml);
121     }});
122     e.preventDefault();
123   });
124
125   if (window.location.pathname == "/export") {
126     $("#exportanchor").click();
127   }
128
129   $("#search_form").submit(function () {
130     var extent = unproj(map.getExtent());
131
132     $("#sidebar_title").html(I18n.t('site.sidebar.search_results'));
133     $("#sidebar_content").load($(this).attr("action"), {
134       query: $("#query").val(),
135       minlon: extent.left,
136       minlat: extent.bottom,
137       maxlon: extent.right,
138       maxlat: extent.top
139     }, openSidebar);
140
141     return false;
142   });
143
144   if ($("#query").val()) {
145     $("#search_form").submit();
146   }
147 });