function initMap() {
var bounds = new google.maps.LatLngBounds();
var map = new google.maps.Map(document.getElementById('artisans-map'), {
styles: styleMap
});
var icon = {
url: "https://artisans.quelleenergie.fr/assets/icones/geolocalize-02-57f71366ba86f935cf6949b551c67cc17042750d0fc34a5d7af80ac028bfae86.svg",
scaledSize: new google.maps.Size(40, 40)
}
var iconSelectionne = {
url: "https://artisans.quelleenergie.fr/assets/icones/geolocalize-01-5fe26a2a4ce9fd6566cc27b4fabb592a37fa7722f3e3d73019830ede8c4dbd05.svg",
scaledSize: new google.maps.Size(40, 40)
}
var markers = [[45.885729, 1.2789939, "entreprise-bechade"], [48.7979614, 2.4981881, "eco-concept-2d7fafc3-50cd-45fa-9482-0ef05e3f497d"], [49.3017659, 1.1838879, "wibault-plomberie-chauffagiste-c575808f-1e1c-4baf-a231-8f98f5ed67d8"], [48.9089849, 2.2285095, "afraite-batiment-sarl-d8088311-1a04-4149-9203-cdf98bf7adc6"], [50.70761299999999, 2.5318798, "brv-renovation"], [44.6191825, 4.9401646, "sarl-girard-m-freres-18752"], [49.0741282, 6.101566099999999, "eimi-elec-a1b25079-67e3-45a5-84a0-f332ce9b20aa"], [47.8300778, -1.6696355, "mca-isolation"], [43.815015, 4.3351219, "generale-services-francais-de-traitement-efcdb5a0-fa96-4df7-aa34-47e8dc9ac440"], [43.1585908, 2.9675164, "generale-services-francais-de-traitement-7ecda476-7dc4-4e67-8e09-9ef0182685dc"]];
var dernierMarkerSelectionne;
var listeObjetMarkers = []
for( i = 0; i < markers.length; i++ ) {
var position = new google.maps.LatLng(markers[i][0], markers[i][1]);
bounds.extend(position);
marker = new google.maps.Marker({
position: position,
map: map,
url: markers[i][2],
icon: icon
});
listeObjetMarkers.push(marker)
google.maps.event.addListener(marker, 'click', function() {
montreCardArtisan(this);
});
}
map.fitBounds(bounds)
map.panToBounds(bounds)
$('.artisans-container .artisan-item').hover(function(){
montrePositionArtisan($(this));
});
function deselectionneMarker() {
if (dernierMarkerSelectionne != undefined) {
dernierMarkerSelectionne.setIcon(icon);
}
}
function selectionneMarker(element) {
$('.artisan-item.selectionne').removeClass('selectionne')
element.toggleClass('selectionne')
}
function montreCardArtisan(marker) {
deselectionneMarker();
marker.setIcon(iconSelectionne);
var element = $('#'+marker.url);
$('html, body').animate({
scrollTop: element.offset().top
}, 600 );
selectionneMarker(element);
dernierMarkerSelectionne = marker
}
function montrePositionArtisan(element) {
selectionneMarker(element)
var index = element.attr('id')
for( i = 0; i < markers.length; i++ ) {
if (listeObjetMarkers[i].url == index) {
deselectionneMarker();
listeObjetMarkers[i].setIcon(iconSelectionne);
dernierMarkerSelectionne = listeObjetMarkers[i]
}
};
}
}
$(document).on('turbolinks:load', function () {
initMap();
});