]> git.openstreetmap.org Git - rails.git/blob - app/assets/javascripts/changeset.js
starting to cleanup+style map controls.
[rails.git] / app / assets / javascripts / changeset.js
1 $(document).ready(function () {
2   var changesets = [], rects = {};
3
4   var map = L.map("changeset_list_map", {
5     attributionControl: false,
6     zoomControl: false
7   }).addLayer(new L.OSM.Mapnik());
8
9   L.control.zoom({position: 'topright'})
10     .addTo(map);
11
12   $("#changeset_list_map").on("resized", function () {
13     map.invalidateSize();
14   });
15
16   var group = L.featureGroup().addTo(map);
17
18   $("[data-changeset]").each(function () {
19     var changeset = $(this).data('changeset');
20     if (changeset.bbox) {
21       changeset.bounds = L.latLngBounds([changeset.bbox.minlat, changeset.bbox.minlon],
22                                         [changeset.bbox.maxlat, changeset.bbox.maxlon]);
23       changesets.push(changeset);
24     }
25   });
26
27   changesets.sort(function (a, b) {
28     return b.bounds.getSize() - a.bounds.getSize();
29   });
30
31   for (var i = 0; i < changesets.length; ++i) {
32     var changeset = changesets[i],
33         rect = L.rectangle(changeset.bounds,
34                            {weight: 2, color: "#ee9900", fillColor: "#ffff55", fillOpacity: 0});
35     rect.id = changeset.id;
36     rects[changeset.id] = rect;
37     rect.addTo(group);
38   }
39
40   function highlightChangeset(id) {
41     rects[id].setStyle({fillOpacity: 0.5});
42     $("#changeset_" + id).addClass("selected");
43   }
44
45   function unHighlightChangeset(id) {
46     rects[id].setStyle({fillOpacity: 0});
47     $("#changeset_" + id).removeClass("selected");
48   }
49
50   group.on({
51     mouseover: function (e) {
52       highlightChangeset(e.layer.id);
53     },
54     mouseout: function (e) {
55       unHighlightChangeset(e.layer.id);
56     }
57   });
58
59   $("[data-changeset]").on({
60     mouseover: function () {
61       highlightChangeset($(this).data("changeset").id);
62     },
63     mouseout: function () {
64       unHighlightChangeset($(this).data("changeset").id);
65     }
66   });
67
68   $(window).scroll(function() {
69         if ($(window).scrollTop() > $('.content-heading').outerHeight() + $('#top-bar').outerHeight() ) {
70             $('#changeset_list_map_wrapper').addClass('scrolled');
71         } else {
72             $('#changeset_list_map_wrapper').removeClass('scrolled');
73         }
74   });
75
76   var params = OSM.mapParams();
77   if (params.bbox) {
78     map.fitBounds([[params.minlat, params.minlon],
79                    [params.maxlat, params.maxlon]]);
80   } else {
81     map.fitBounds(group.getBounds());
82   }
83 });