1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- {% extends 'layout/layout_1_col.tpl'|get_template %}
- {% block content %}
- <div id="map" style="width:100%; height:600px"></div>
- <script>
- function start()
- {
- var options = {
- center: new google.maps.LatLng(45.526, 6.255),
- zoom: 5,
- mapTypeId: google.maps.MapTypeId.ROADMAP
- };
- var map = new google.maps.Map(document.getElementById("map"), options);
- var oms = new OverlappingMarkerSpiderfier(map);
- var cities = '{{ places | escape('js') }}';
- cities = JSON.parse(cities);
- var imageCity = {
- url: '{{ image_city }}'
- }
- var stageCity = {
- url:'{{ image_stage }}'
- }
-
- var markers = [];
- if (cities.length) {
- for (var i = 0; i < cities.length; i++) {
-
- if ('ville_lat' in cities[i]) {
- var markerOptions = {
- position: new google.maps.LatLng(cities[i]['ville_lat'], cities[i]['ville_long']),
- title: cities[i]['complete_name'],
- city: cities[i],
- icon: imageCity,
- };
- var marker = new google.maps.Marker(markerOptions);
- markers.push(marker);
- oms.addMarker(marker);
- }
-
- if ('stage_lat' in cities[i]) {
- var markerOptions = {
- position: new google.maps.LatLng(cities[i]['stage_lat'], cities[i]['stage_long']),
- title: cities[i]['complete_name'],
- city: cities[i],
- icon: stageCity,
- };
- var marker = new google.maps.Marker(markerOptions);
- markers.push(marker);
- oms.addMarker(marker);
- }
- }
-
- var markerClusterer = new MarkerClusterer(map, markers, {
- maxZoom: 9,
- imagePath: 'https://cdn.rawgit.com/googlemaps/js-marker-clusterer/gh-pages/images/m'
- });
-
- if (markers.length) {
- var bounds = new google.maps.LatLngBounds();
- for (var i = 0; i < markers.length; ++i) {
- bounds.extend(markers[i].position);
- }
-
-
- }
-
- var infoWindow = new google.maps.InfoWindow();
- oms.addListener('click', function (marker, event) {
- infoWindow.setContent('<a href="{{ url }}?u=' + marker.city['id'] + '">' + marker.city['complete_name'] + '</a>');
- infoWindow.open(map, marker);
- });
- google.maps.event.addListener(markerClusterer, 'clusterclick', function (cluster) {
- map.fitBounds(cluster.getBounds());
- if (map.getZoom() > 14) {
- map.setZoom(14);
- }
- });
- }
- }
- </script>
- <script async defer type="text/javascript" src="https://maps.google.com/maps/api/js?key={{ api_key }}&callback=start"></script>
- <img src="{{ image_city }}" /> {{ field_1 }} <br />
- <img src="{{ image_stage }}" /> {{ field_2 }}
- {% endblock %}
|