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