HOME


Mini Shell 1.0
DIR: /home/otwalrll/.trash/wp-content.1/themes/consultio/elementor/js/
Upload File :
Current File : /home/otwalrll/.trash/wp-content.1/themes/consultio/elementor/js/ct-gm-widget.js
(function ($) {
    /**
     * @param $scope The Widget wrapper element as a jQuery element
     * @param $ The jQuery alias
     */
    var WidgetCustomGMHandler = function ($scope, $) {
        $scope.find(".map-render").each(function () {
            /* map type */
            var map_type;
            switch ($(this).attr('data-type')) {
                case 'HYBRID':
                    map_type = google.maps.MapTypeId.HYBRID;
                    break;
                case 'SATELLITE':
                    map_type = google.maps.MapTypeId.SATELLITE;
                    break;
                case 'TERRAIN':
                    map_type = google.maps.MapTypeId.TERRAIN;
                    break;
                default:
                    map_type = google.maps.MapTypeId.ROADMAP;
                    break;
            }

            /* get controls */
            var controls = $.parseJSON(decodeURIComponent($(this)
                .attr('data-controls')));

            /* get style */
            style = $.parseJSON(decodeURIComponent(($(this)
                .attr('data-template'))));

            var mapOptions = {
                zoom: parseInt($(this).attr('data-zoom')),
                center: new google.maps.LatLng(51.505858, -0.123633),
                mapTypeId: map_type,
                scrollwheel: controls.scrollwheel,
                panControl: controls.pancontrol,
                zoomControl: controls.zoomcontrol,
                scaleControl: controls.scalecontrol,
                mapTypeControl: controls.maptypecontrol,
                streetViewControl: controls.streetviewcontrol,
                overviewMapControl: controls.overviewmapcontrol,
                styles: style
            };
            var map = new google.maps.Map($(this).get(0),
                mapOptions);

            /* map center */
            if ($(this).attr('data-coordinate').length > 0) {
                var coordinate = $(this).attr('data-coordinate')
                    .split(',');
                if (coordinate.length == 2) {
                    map.setCenter(new google.maps.LatLng(
                        coordinate[0], coordinate[1]));
                }
            } else {
                if ($(this).attr('data-address').length > 0) {
                    $.getJSON('https://maps.google.com/maps/api/geocode/json?address=' + $(this).attr('data-address') + '',
                        function (data) {
                        console.log(data);
                            var lat = data.results[0].geometry.location.lat;
                            var lng = data.results[0].geometry.location.lng;
                            map.setCenter(new google.maps.LatLng(lat, lng));
                        });
                }
            }
            /* marker */
            var locations = $.parseJSON(decodeURIComponent($(this).attr('data-marker')));

            if (locations.markerlist != undefined) {
                locations.markerlist = $.parseJSON(decodeURIComponent((locations.markerlist)));
                if (Array.isArray(locations.markerlist)) {
                    for (var i = 0; i < locations.markerlist.length; i++) {
                        var item = {};
                        if(locations.markerlist[i].title != '' || locations.markerlist[i].desc != ''){
                            item.markerdesc = '<div class="info-content"><h5>';
                            if(locations.markerlist[i].title != ''){
                                item.markerdesc += locations.markerlist[i].title;
                            }
                            item.markerdesc += '</h5><span>';
                            if(locations.markerlist[i].desc != ''){
                                item.markerdesc += locations.markerlist[i].desc;
                            }
                            item.markerdesc += '</span></div>';
                        }
                        item.markercoordinate = locations.markerlist[i].coordinate;
                        if(locations.markerlist[i].icon != undefined){
                            item.markericon = locations.markerlist[i].icon;
                        }
                        markerRender(map, item);
                    }
                }
            }

            if (locations.markercoordinate != undefined) {
                markerRender(map, locations);
            }

            /* */
            function markerRender(map, locations) {
                "use strict";
                var location = locations.markercoordinate
                    .split(',');
                if (location.length == 2) {
                    var myLatLng = new google.maps.LatLng(
                        location[0], location[1]);

                    var mk = {
                        position: myLatLng,
                        map: map,
                        optimized: false
                    }

                    if (locations.markericon != undefined) {
                        mk.icon = {
                            url: locations.markericon
                        };
                    }
                    google.maps.event.addListenerOnce(map, 'idle', function () {
                        setTimeout(function () {
                            $('img[usemap="#gmimap0"]').wrap("<div class='marker-icon'></div>");
                        }, 200);
                    });

                    var marker = new google.maps.Marker(mk);
                    if (locations.markerdesc != undefined) {
                        var infowindow = new google.maps.InfoWindow(
                            {
                                content: locations.markerdesc,
                                maxWidth: controls.infowidth,
                            });
                        if (controls.infoclick) {
                            google.maps.event.addListener(marker,
                                'click', function () {
                                    infowindow
                                        .open(map, marker);
                                });
                        } else {
                            infowindow.open(map, marker);
                        }
                    }
                }
            }
        });
    };

    // Make sure you run this code under Elementor.
    $(window).on('elementor/frontend/init', function () {
        elementorFrontend.hooks.addAction('frontend/element_ready/ct_google_map.default', WidgetCustomGMHandler);
    });
})(jQuery);