
                    
                            <div class="wh-bauforum-google-maps-container">
                                <div class="hero-image-container">
                                    <div class="wh-bauforum-filter-container">
                                        <form name="bauforumSearchForm" id="bauforumSearchForm" action="/ajax/?search-bauforum=1" method="POST" data-parsley-validate="">
                                            <div class="row">
                                                <div class="col-md-12">
                                                    <div id="request-data" class="d-none" data-zip="" data-country="CH"></div>
                                                    <div class="filter-items-wrapper">
                                                        <div class="address-search-wrapper">
                                                            <label for="addressSearch" class="form-label">Adresse</label>
                                                            <div class="address-search-parsley-wrapper">
                                                                <input type="text" name="tx_whbauforum_maps_address" id="addressSearch" placeholder="Code postal ..." class="form-control" data-parsley-errors-container="#address-search-error-container" data-parsley-custom103="1" data-parsley-error-message="Veuillez entrer un code postal valide">
                                                                <div id="address-search-error-container"></div>
                                                            </div>
                                                        </div>
                                                        <div class="country-search-wrapper">
                                                            <label for="countrySearch" class="form-label">Pays</label>
                                                            <select id="countrySearch" class="form-select" name="tx_whbauforum_maps_country">
                                                                <option value="D">Allemagne</option>
                                                                <option value="L">Luxembourg</option>
                                                                <option value="CH">la Suisse</option>
                                                            </select>
                                                        </div>
                                                        <div class="geolocation-search-wrapper">
                                                            <div class="checkbox">
                                                                <label class="form-check-label" for="geolocation">
                                                                    Utilisez votre propre emplacement
                                                                    <input type="checkbox" id="geolocation" name="geolocation" value="1" class="form-check-input">
                                                                    <span class="checkmark"></span>
                                                                </label>
                                                            </div>

                                                            <input type="hidden" name="tx_whbauforum_maps_lat" id="lat" value="0" />
                                                            <input type="hidden" name="tx_whbauforum_maps_lon" id="lon" value="0" />

                                                            <div id="geolocation-load" style="display:none;">Le lieu est en cours de détermination...</div>
                                                            <div id="geolocation-error" style="display:none;">Veuillez autoriser l'accès à votre emplacement</div>
                                                        </div>

                                                        <div class="radius-search-wrapper">
                                                            <label for="radius" class="form-label"><span class="radius-label">Rayon:</span><span id="rangeValue"></span><span class="km-text">km</span></label>
                                                            <input type="range" name="tx_whbauforum_maps_radius" id="radius" value="0" min="0" max="150" />
                                                        </div>
                                                        <div class="submit-button-wrapper">
                                                            <button type="submit" title="Chercher une agence conseil" aria-label="Chercher une agence conseil" class="btn-primary" id="searchLocation">Chercher une agence conseil</button>
                                                        </div>
                                                    </div>
                                                </div>
                                            </div>
                                        </form>
                                        <div id="map-anchor"></div>
                                    </div>
                                </div>
                                <div class="wh-content-container">
                                    <div class="google-maps-grid">
                                        <div class="map-container">
                                            <div id="map"></div>
                                        </div>
                                        <div class="bauforen-ajax-list-wrapper">
                                            <div id="bauforenAjaxList">
                                                <div class="search-init-info">
                                                    <div class="init-info-icon">
                                                        <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="#FF0000" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z" /><circle cx="12" cy="10" r="3" /></svg>
                                                    </div>
                                                    <div class="init-info-text">
                                                        Veuillez saisir votre CP <strong>et le rayon souhaité</strong> pour obtenir une liste <strong>des agences conseil</strong> près de chez vous..
                                                    </div>
                                                </div>
                                            </div>
                                            <div id="no-results">
                                                Aucun résultat trouvé
                                            </div>
                                            <div id="loading-animation">
                                                <img class="loading-animation" title="WeberHaus Logo Lade-Animation" alt="WeberHaus Logo Lade-Animation" src="/typo3conf/ext/wh_template/Resources/Public/Images/gif_WeberHaus-icon-loading.gif" width="80" height="80" />
                                            </div>
                                        </div>
                                    </div>
                                </div>
                                
                                        <script async defer src="https://maps.googleapis.com/maps/api/js?key=AIzaSyALPce1CYQvNR4WLtXod5FV1QCBZ69y2LQ&libraries=places&callback=initMap&language=fr"></script>
                                    
                                <script>
                                    let map;
                                    let markers = [];

                                    let noResultsString = $('#no-results').html();

                                    function initMap() {
                                        map = new google.maps.Map(document.getElementById('map'), {
                                            center: {lat: 48.6186854, lng: 7.8908066},
                                            zoom: 5,
                                        });
                                    }

                                    function clearMarkers() {
                                        for (let i = 0; i < markers.length; i++) {
                                            if (markers[i]) {
                                                markers[i].setMap(null);
                                            }
                                        }
                                        markers = [];
                                    }
                                    function getHtmlTemplate(item, i) {
                                        let langLabels = $('#lang-labels').data();
                                        let teamName1 = item.teamName1;
                                        let teamName2 = item.teamName2;
                                        let teamName3 = item.teamName3;
                                        let teamCity = item.teamCity;
                                        let teamPhone1 = item.teamPhone1;
                                        let teamPhoneHref = item.teamPhone1.replace(/\s/g,'');
                                        let teamZipCode = item.teamZipCode;
                                        let teamStreet = item.teamStreet;
                                        let forumUid = item.forumUid;
                                        let forumUrl = item.forumPageUri;
                                        let icon = '<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="#FF0000" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z" /><circle cx="12" cy="10" r="3" /></svg>';
                                        let distance = item.distance + ' km';
                                        let distanceVisibilityClass = 'd-block';
                                        if(item.distance === 0) {
                                            distanceVisibilityClass = 'd-none';
                                        }
                                        let htmlstring = '';

                                        htmlstring += '' +
                                            '<div class="gm-bauforum-item">' +
                                            '<div class="gm-bauforum-item-content">' +
                                            '<div class="team-name-1">' +
                                            (forumUrl !== "" ? '<a href="' + forumUrl + '" class="gm-bauforum-link" title="' + teamName1 + '">' + teamName1 + '</a>' : '' + teamName1 + '') +
                                            '</div>' +
                                            '<div class="team-name-2">' + teamName2 + '</div>' +
                                            '<div class="team-name-3">' + teamName3 + '</div>' +
                                            '<div class="team-street">' + teamStreet + '</div>' +
                                            '<div class="team-address">' + teamZipCode + ' ' + teamCity + '</div>' +
                                            '<div class="team-phone-container">' +
                                            '<div class="phone-label">Tel:</div>' +
                                            '<div class="phone-numbers">' +
                                            '<a href="tel:' + teamPhoneHref + '" class="gm-bauforum-link" title="' + teamPhone1 + '">' + teamPhone1 + '</a>' +
                                            '</div>' +
                                            '</div>' +
                                            '</div>' +
                                            '<div class="gm-bauforum-item-distance">' +
                                            '<div class="distance-label ' + distanceVisibilityClass + '">'+langLabels["distance"]+'</div>' +
                                            '<div class="distance-value ' + distanceVisibilityClass + '">' + distance.replace(".", ",") + '</div>' +
                                            '</div>' +
                                            '<div class="gm-bauforum-item-icon" id="bauforum-item-' + forumUid + '">' + icon + '</div>' +
                                            '</div>';

                                        return htmlstring;
                                    }

                                    function getInfoWindowHtml(item) {
                                        let teamName1 = item.teamName1;
                                        let teamName2 = item.teamName2;
                                        let teamName3 = item.teamName3;
                                        let teamCity = item.teamCity;
                                        let teamPhone1 = item.teamPhone1;
                                        let teamPhoneHref = item.teamPhone1.replace(/\s/g,'');
                                        let teamZipCode = item.teamZipCode;
                                        let teamStreet = item.teamStreet;
                                        let forumUrl = item.forumPageUri;

                                        let infoWindowHtml = '';
                                        infoWindowHtml += '<div class="info-window-wrapper">';
                                        infoWindowHtml += '<div class="info-team-name-1">' + (forumUrl !== "" ? '<a href="' + forumUrl + '" class="gm-bauforum-link" title="' + teamName1 + '">' + teamName1 + '</a>' : '' + teamName1 + '') + '</div>';
                                        infoWindowHtml += '<div class="info-team-name-2">' + teamName2 + '</div>';
                                        infoWindowHtml += '<div class="info-team-name-3">' + teamName3 + '</div>';
                                        infoWindowHtml += '<div class="info-team-street">' + teamStreet + '</div>';
                                        infoWindowHtml += '<div class="info-team-address">' + teamZipCode + ' ' + teamCity + '</div>';
                                        infoWindowHtml += '<div class="info-team-phone-container">';
                                        infoWindowHtml += '<div class="info-phone-label">Tel:</div>';
                                        infoWindowHtml += '<div class="info-phone-numbers"><a href="tel:' + teamPhoneHref + '" class="gm-bauforum-link" title="' + teamPhone1 + '">' + teamPhone1 + '</a></div>';
                                        infoWindowHtml += '</div>';
                                        infoWindowHtml += '</div>';

                                        return infoWindowHtml;
                                    }

                                    function startSearch() {
                                        let form = $('#bauforumSearchForm');
                                        let bauforenAjaxList = $('#bauforenAjaxList');
                                        let noResultsContainer = $('#no-results');

                                        bauforenAjaxList.html('');
                                        $('#loading-animation').show();
                                        $('#geolocation-load').hide();
                                        let infowindow = new google.maps.InfoWindow({
                                            pixelOffset: new google.maps.Size(-5, -20)
                                        });
                                        clearMarkers();
                                        $.post(form.attr('action'), form.serialize(), function(response){
                                            if(response['empty'] === true) {
                                                $('#loading-animation').hide();
                                                //noResultsContainer.css('display','flex');
                                                //bauforenAjaxList.append(noResultsContainer);
                                                bauforenAjaxList.html('<div class="no-results">' + noResultsString + '</div>');
                                            } else {
                                                let mapBounds = new google.maps.LatLngBounds();
                                                if (response !== null && Object.keys(response).length !== 0){
                                                    noResultsContainer.css('display','none');
                                                    $.each(response, function(i, item) {
                                                        let marker = new google.maps.Marker({
                                                            position: new google.maps.LatLng(item.lat, item.lon),
                                                            map: map,
                                                            icon: '/typo3conf/ext/wh_template/Resources/Public/Images/icon_map-pin-solid.png',
                                                            animation: google.maps.Animation.DROP,
                                                            location_id: item.forumUid
                                                        });
                                                        markers.push(marker);
                                                        mapBounds.extend(marker.position);
                                                        $('#loading-animation').hide();
                                                        bauforenAjaxList.append(getHtmlTemplate(item, i));
                                                        let infoWindowContent = getInfoWindowHtml(item);
                                                        let bauForumItem = $('#bauforum-item-' + item.forumUid);
                                                        bauForumItem.bind('click', marker, function(event) {
                                                            $.each(markers, function(i, marker) {
                                                                marker.setAnimation(null);
                                                            });

                                                            marker.setAnimation(google.maps.Animation.BOUNCE);
                                                            infowindow.setContent(infoWindowContent);
                                                            infowindow.open(map, marker);
                                                            let mapElement = document.getElementById("map-anchor");
                                                            mapElement.scrollIntoView({behavior: "smooth", block: "start"});
                                                        });
                                                        google.maps.event.addListener(marker, 'click', (function(marker, i) {
                                                            return function() {
                                                                $.each(markers, function(i, marker) {
                                                                    marker.setAnimation(null);
                                                                });
                                                                marker.setAnimation(google.maps.Animation.BOUNCE);
                                                                infowindow.setContent(infoWindowContent);
                                                                infowindow.open(map, marker);
                                                            }
                                                        })(marker, i));
                                                    });
                                                    map.fitBounds(mapBounds);
                                                    if(Object.keys(response).length === 1){
                                                        map.setOptions({ zoom: 16 });
                                                    }
                                                }
                                            }
                                        });
                                    }

                                    $(document).ready(function(){
                                        let searchForm = $('#bauforumSearchForm');
                                        let requestData = $('#request-data').data();
                                        let zipCode = requestData['zip'];
                                        let countryShortCode = requestData['country'];
                                        if(countryShortCode !== '') {
                                            $('#countrySearch').val(countryShortCode);
                                        }
                                        ;
                                        if(zipCode !== '') {
                                            $('#addressSearch').val(zipCode);
                                            setTimeout(function(){
                                                startSearch();
                                            }, 300);
                                        }

                                        let searchInfoHtml = $('#bauforenAjaxList').html();
                                        $(document).on('submit', searchForm,function () {
                                            //return true;
                                            let zipCodeString = $('#addressSearch').val();
                                            let zipcodeRegex = new RegExp("^([0-9]{4,5})$");
                                            let check = zipcodeRegex.test(zipCodeString);

                                            if (zipCodeString.length > 0 && check) {
                                                let geocoder = new google.maps.Geocoder();
                                                let address = document.getElementById("addressSearch").value;
                                                geocoder.geocode( { 'address': address}, function(results, status) {
                                                    if (status === google.maps.GeocoderStatus.OK) {
                                                        $('#lat').val(results[0].geometry.location.lat());
                                                        $('#lon').val(results[0].geometry.location.lng());
                                                        startSearch();
                                                        return false;
                                                    } else {
                                                        console.log("Geocode was not successful for the following reason: " + status);
                                                        startSearch();
                                                        return false;
                                                    }
                                                });
                                            } else {
                                                $('#lat').val(0);
                                                $('#lon').val(0);
                                                startSearch();
                                                return false;
                                            }
                                            return false;
                                        });

                                        $(document).on('change', '#geolocation',function () {
                                            if ($(this).is(':checked')) {
                                                $('#addressSearch').attr("readonly", true);
                                                $('#geolocation-load').css('display','flex');

                                                navigator.geolocation.getCurrentPosition(function(position){
                                                    let geocoder = new google.maps.Geocoder();
                                                    let point = new google.maps.LatLng(position.coords.latitude, position.coords.longitude);


                                                    geocoder.geocode(
                                                        {'latLng': point},
                                                        function (results, status) {
                                                            if (status === google.maps.GeocoderStatus.OK) {
                                                                let postalCode = results[0].address_components.find(function (component) {
                                                                    return component.types[0] === "postal_code";
                                                                });
                                                                let countryCode = results[0].address_components.find(function (component) {
                                                                    return component.types[0] === "country";
                                                                });
                                                                let countrySelect = $('#countrySearch');
                                                                switch(countryCode.short_name) {
                                                                    case 'DE':
                                                                        countrySelect.val('D');
                                                                        break;
                                                                    case 'CH':
                                                                        countrySelect.val('CH');
                                                                        break;
                                                                    case 'LU':
                                                                        countrySelect.val('L');
                                                                        break;
                                                                    default:
                                                                        countrySelect.val('D');
                                                                }
                                                                $("#addressSearch").val(postalCode.long_name);
                                                                $('#geolocation-error').hide();
                                                                $('#geolocation-load').hide();
                                                                $('#lat').val(position.coords.latitude);
                                                                $('#lon').val(position.coords.longitude);

                                                                startSearch();

                                                            } else {
                                                                console.log("Geocode was not successful for the following reason: " + status);
                                                            }
                                                        }
                                                    );
                                                }, function () {
                                                    // fehler
                                                    $('#geolocation-error').css('display','flex');
                                                    $('#geolocation-load').hide();
                                                });
                                            } else{
                                                //$('#addressSearch').val('');
                                                $('#addressSearch').attr("readonly", false);
                                                $('#geolocation-error').hide();
                                                //clearMarkers();
                                                //$('#bauforenAjaxList').html(searchInfoHtml);
                                            }
                                        });

                                    });
                                    let inputRangeSlider = document.getElementById("radius");
                                    let rangeValue = document.getElementById("rangeValue");
                                    let initValPercent = (inputRangeSlider.valueAsNumber  - parseInt(inputRangeSlider.min)) /
                                        (parseInt(inputRangeSlider.max) - parseInt(inputRangeSlider.min));
                                    inputRangeSlider.style = 'background-image: -webkit-gradient(linear, 0% 0%, 100% 0%, color-stop(' + initValPercent + ', #ff0000), color-stop(' + initValPercent + ', #e5e5e3));';

                                    rangeValue.innerHTML = inputRangeSlider.value;
                                    inputRangeSlider.innerHTML = inputRangeSlider.value;
                                    inputRangeSlider.oninput = function() {
                                        rangeValue.innerHTML = this.value;

                                        let valPercent = (inputRangeSlider.valueAsNumber  - parseInt(inputRangeSlider.min)) /
                                            (parseInt(inputRangeSlider.max) - parseInt(inputRangeSlider.min));
                                        inputRangeSlider.style = 'background-image: -webkit-gradient(linear, 0% 0%, 100% 0%, color-stop(' + valPercent + ', #ff0000), color-stop(' + valPercent + ', #e5e5e3));';


                                    }
                                </script>
                            </div>
                        
                
Mit Klick auf Google Maps willige ich in die Verarbeitung meiner Daten durch Google ein. Diese Einwilligung kann jederzeit mit Wirkung für die Zukunft widerrufen werden. Weitere Informationen können unserer Datenschutzerklärung entnommen werden.
Aperçu de toutes les agences conseil
Montreux
Agence Suisse Romande
Avenue des Alpes 80 B
1820 Montreux
Tèl:
079 9372180
Vers l’agence conseil
Thun
Zelglistrasse 6
3608 Thun
Tèl:
078 8809001
Vers l’agence conseil
Zentralschweiz
Gartenstrasse 18
3800 Unterseen
Tèl:
033 2215177
Vers l’agence conseil
Arisdorf
Partner von WeberHaus Schweiz
Ringstrasse 78
4422 Arisdorf
Tèl:
061 81130-33
Vers l’agence conseil
Locarno
Home Expo
Bernstrasse Ost Nr. 46
5034 Suhr
Tèl:
062 842 32 32
Vers l’agence conseil
Suhr
Home Expo
Bernstrasse Ost Nr. 46
5034 Suhr
Tèl:
062 842 32 32
Vers l’agence conseil
Kreuzlingen
Müligässli 1
8598 Bottighofen
Tèl:
044 945 27 27
Vers l’agence conseil