4e51b46b68c7aa24865479b3ece8c385ad097edc
[lhc/web/spip_carte_de_sites.git] / contenu / page-carte_de_sites.html
1 [(#REM)
2 Modele carte_de_site
3
4 Parametres :
5
6 - legende = non : ne pas afficher la legende
7 ]
8
9 <!-- Carte -->
10 <div id="map" style="width: 540px; height: 400px">
11 <script src="[(#CHEMIN{lib/CloudMade-Leaflet-edb7d25/dist/leaflet.js}|url_absolue)]"></script>
12
13 <script>
14 <BOUCLE_ateliers_types(MOTS){type = Ateliers}{par num titre}>
15 var group_#ID_MOT = new L.LayerGroup();
16 <BOUCLE_sites(SITES){id_mot}>
17 <BOUCLE_coord(GIS){id_syndic}>
18 var WorkshopIcon = L.Icon.extend({
19 iconUrl: '[(#LOGO_MOT||extraire_attribut{src}|url_absolue)]',
20 shadowUrl: '[(#LOGO_MOT_SURVOL||extraire_attribut{src}|url_absolue)]',
21 iconSize: new L.Point(17, 28),
22 shadowSize: new L.Point(17, 17),
23 iconAnchor: new L.Point(13, 17),
24 popupAnchor: new L.Point(0, -33)
25 });
26 siteIcon = new WorkshopIcon()
27 var markerAtelier = new L.Marker(new L.LatLng(#LAT, #LON), {icon: siteIcon});
28 markerAtelier.bindPopup("\
29 <span style='float: left; width: 45px;'><img src='[(#LOGO_SYNDIC||extraire_attribut{src}|url_absolue)]' alt='' style='width: 45px;' width='45'></span>\
30 <a href='[(#ID_SYNDIC|generer_url_entite{site})]'>#NOM_SITE</a><br/>#DESCRIPTIF\
31 <span class='spip_documents spip_documents_right' style='float: right; width: 100px;'>\<img src='[(#LOGO_SYNDIC_SURVOL||extraire_attribut{src}|url_absolue)]' alt='' style='width: 100px;' width='100'></span>\
32 #ADRESSE<br/> #CODE_POSTAL #VILLE<br/>\
33 <a href='[(#URL_SITE)]'>[(#URL_SITE)]</a><br/><br/>\
34 <em>Statut: [(#_ateliers_types:TITRE|supprimer_numero)]</em>\
35 ");
36 group_#ID_MOT.addLayer(markerAtelier)
37 </BOUCLE_coord>
38 </BOUCLE_sites>
39 </BOUCLE_ateliers_types>
40
41 var cloudmadeAttribution = 'Map data &copy; 2011 OpenStreetMap contributors, Imagery &copy; 2011 CloudMade',
42 cloudmadeOptions = {maxZoom: 18, attribution: cloudmadeAttribution},
43 cloudmadeUrl = 'http://{s}.tile.cloudmade.com/BC9A493B41014CAABB98F0471D759707/{styleId}/256/{z}/{x}/{y}.png';
44
45 var midnightCommander = new L.TileLayer(cloudmadeUrl, cloudmadeOptions, {styleId: 999}),
46 minimal = new L.TileLayer(cloudmadeUrl, cloudmadeOptions, {styleId: 14189});
47
48
49 <B_map>
50 var map = new L.Map('map', {center: new L.LatLng(46.8, 2.52), zoom: 5, layers: [<BOUCLE_map(MOTS){type = Ateliers}> group_#ID_MOT,</BOUCLE_map> midnightCommander, minimal]});
51 </B_map>
52
53 var baseMaps = {
54 "Vue de nuit ;-)": midnightCommander,
55 "Vue de jour": minimal
56 };
57
58 <B_groups>
59 var overlayMaps = {
60 <BOUCLE_groups(MOTS){type = Ateliers}{par num titre}>
61 "[(#TITRE|supprimer_numero)]": group_#ID_MOT,</BOUCLE_groups>
62 };
63 </B_groups>
64
65
66 layersControl = new L.Control.Layers(baseMaps, overlayMaps);
67
68 map.addControl(layersControl);
69
70 map.on('click', onMapClick);
71
72 var popup = new L.Popup();
73
74 function onMapClick(e) {
75 var latlngStr = '(' + e.latlng.lat.toFixed(5) + ', ' + e.latlng.lng.toFixed(5) + ')';
76 popup.setLatLng(e.latlng);
77 popup.setContent("Coordonnees de votre clic (Latitude, Longitude)" + latlngStr);
78 map.openPopup(popup);
79 }
80
81 </script>
82 </div>
83
84 <!-- Legende -->
85
86 <B_legende>
87 [(#ENV{legende}|!={non}|oui)
88 <h2 class='h2 spip'>Legende</h2>
89 ]
90 <BOUCLE_legende(MOTS){type = Ateliers}{par num titre}>
91 [(#ENV{legende}|!={non}|oui)
92 <p>#LOGO_MOT_NORMAL [(#TITRE|supprimer_numero)]</p>
93 ]
94 </BOUCLE_legende>
95 </B_legende>
96