prashantcs053
7/4/2017 - 5:14 AM

google address auto fill with map in gravity form list field

google address auto fill with map in gravity form list field

add_filter('gform_column_input_content_2_12_1', 'change_column2_content', 10, 6);

function change_column2_content($input, $input_info, $field, $text, $value, $form_id) {
    $input_field_name = 'map_container';
    $hidden_field_name = 'input_' . $field->id . '[]';
    $tabindex = GFCommon::get_tabindex();
    ob_start();
    ?>
    <div style="display:none;" class="overlay" onClick="style.pointerEvents = 'none'"></div> <div class="<?php echo $input_field_name ?>"  style="width:100%;height:230px"></div><input type="hidden" name="map_val_lat[]" value="" class="map_val_lat"><input type="hidden" name="map_val_lng[]" value=""class="map_val_lng"><a class="vogue_gf_custom_loc" href="javascript:void(0);">Still can't find your store?</a><div style="display:none;" class="cus_address ginput_complex ginput_container has_street has_city has_state has_zip has_country ginput_container_address gfield_trigger_change" id="cus_address">
        <span class="ginput_full address_line_1" id="cus_address_1_container">
            <label for="cus_address_1" id="cus_address_1_label">Street Address</label>
            <input type="text" name="input_46.1" id="cus_address_1" value="" tabindex="26.1">
        </span>
        <span class="ginput_left address_city" id="cus_address_3_container">
            <label for="cus_address_3" id="cus_address_3_label">City</label>
            <input type="text" name="input_46.3" id="cus_address_3" value="" tabindex="26.2">
        </span>
        <span class="ginput_right address_state" id="cus_address_4_container">
            <label for="cus_address_4" id="cus_address_4_label">State / Province / Region</label>
            <input type="text" name="input_46.4" id="cus_address_4" value="" tabindex="26.3">
        </span>
        <span class="ginput_left address_zip" id="cus_address_5_container">
            <label for="cus_address_5" id="cus_address_5_label">ZIP / Postal Code</label>
            <input type="text" name="input_46.5" id="cus_address_5" value="" tabindex="26.4">
        </span>
        <div class="gf_clear gf_clear_complex"></div>
    </div>
    <?php
    $input .= ob_get_clean();
    return $input;
}
/*adding dynamically list field label increments*/
add_action('wp_head', 'hook_css');
function hook_css() {
    ?><style>
       body .gw-number-rows table.gfield_list {
            counter-reset: gflistrowcounter;
        }       .gw-number-rows .gfield_list tbody tr:before {
            content: counter(gflistrowcounter);
            counter-increment: gflistrowcounter;
             font-size: 0;            
        }    
     
        .gfield_list_icons:before{
             content:'';
             font-size: 0 !important;
        }
        .register_form .address_autofill_repeater .ginput_container_list .gfield_list thead  {
            display:none; 
        }
        .gform_wrapper ul.gform_fields.form_sublabel_above table.gfield_list td::before, .gform_wrapper ul.gform_fields.form_sublabel_below table.gfield_list td::before {
            content: attr(data-label)' 'counter(gflistrowcounter);           
            font-size: 14px;
            letter-spacing: .5pt;
            white-space: nowrap;
            display: block;
            clear: both;
        }
        .gfield_list_cell.gfield_list_4_cell1, .gfield_list_cell.gfield_list_4_cell2, .gfield_list_cell.gfield_list_4_cell3 {
            display: block;
            float: left;
        }
        .gfield_list_cell.gfield_list_4_cell4 {
            display: block;
            float: right;
        }
        .gfield_list_cell.gfield_list_4_cell1, .gfield_list_cell.gfield_list_4_cell2 {
            width: 99%;
        }
        .gfield_list_4_cell2, .gfield_list_4_cell4, .gfield_list_4_cell3 {
            width: 33%;
        }
        .gform_wrapper table.gfield_list td + td, .gform_wrapper table.gfield_list th + th {
            padding: 0 0 0 0px;
            padding-right: 9px;
        }
        .gfield_list_cell.gfield_list_4_cell1 {
            margin-top: 20px !important;
            border-top: 5px solid #65a9cc !important;
        }
    </style>
    <?php
}

var map = [] || {}, places = [] || {};
var globalMap = [] || {};
var markers = [] || {};
var marker;
var autocomplete = [] || {};
var map_lat = [] || {};
var map_lng = [] || {};
var global_map_lat_lng = {};
var obj_string = '';
var countryRestrict = {country: 'AU'};
var autofill_address;
var geocoder;
var $jK = 0;
function retriveLatLong() {
    if (jQuery(".gfield_list_group").length > 0) {
        global_map_lat_lng = {};
        var tableRow = jQuery(".gfield_list_group");
        tableRow.each(function () {
            var time = jQuery(this).attr("unique-id");
            var lat = jQuery(this).find(".map_val_lat").val();
            var lng = jQuery(this).find(".map_val_lng").val();
            var add = jQuery(this).find("input[name='input_12\[\]']").eq(0).val();
            global_map_lat_lng[time] = {'lat': parseFloat(lat), 'lng': parseFloat(lng), 'add': add};
        });
        jQuery("#input_2_38").val(JSON.stringify(global_map_lat_lng));
    }
}
function addAutocomplete(autofill_address, count) {
    $jK = 0;
    var cityBounds = new google.maps.LatLngBounds(
            new google.maps.LatLng(-37.813628, 144.963058),
            new google.maps.LatLng(-33.868820, 151.209296),
            new google.maps.LatLng(-33.882230, 151.196960)
            );
    geocoder = new google.maps.Geocoder();
    autocomplete[count] = new google.maps.places.Autocomplete((autofill_address), {
        strictBounds: true,
        bounds: cityBounds,
        types: ['address']
//        componentRestrictions: countryRestrict
    });
    places[count] = new google.maps.places.PlacesService(map[count]);
        autocomplete[count].addListener('place_changed', function () {
        // console.log("place_changed");
        $jK = 0;
        jQuery(document).trigger("gmap_place_changed",[count]);
        var place = autocomplete[count].getPlace();
        if (place.geometry) {
            map[count].panTo(place.geometry.location);
            $jK = 1;
//            console.log(place);
//            jQuery("tr[unique-id='" + count + "']").find(".map_val_lat").val(place.geometry.location.lat());
//            jQuery("tr[unique-id='" + count + "']").find(".map_val_lng").val(place.geometry.location.lng());
            map_lat = place.geometry.location.lat();
            map_lng = place.geometry.location.lng();
            GetAndSetLatLong(count, map_lat, map_lng);
            retriveLatLong();
            map[count].setZoom(15);
            markers[count] = new google.maps.Marker({
                position: place.geometry.location,
                map: map[count],
                draggable: true,
            });
            getLatLongWhenDrag(count);
        }
    });
}
function getLatLongWhenDrag(count) {
    google.maps.event.addListener(markers[count], 'dragend', function (event) {
        var lt = this.getPosition().lat();
        var lg = this.getPosition().lng();
        geocodePosition(markers[count].getPosition(), function (responses) {

            var replaceFrom = "";
            var replaceTo = "";
            var getZip = "";
            var all_components = responses[0].address_components;

            for (var key in all_components) {

                if (all_components[key].types[0] == "administrative_area_level_1") {
                    replaceFrom = all_components[key].short_name;
                    replaceTo = all_components[key].long_name;

                }

                if (all_components[key].types[0] == "postal_code") {
                    getZip = all_components[key].short_name;

                }
            }

            if (replaceTo !== "" && replaceFrom !== "") {
                var replacedString = responses[0].formatted_address.replace(replaceFrom, replaceTo);
                replacedString = replacedString.replace(getZip, "");
                console.log(replacedString);
            }


            GetAndSetLatLong(count, lt, lg, replacedString);
        });
    });
}
function GetAndSetLatLong(count, lat, lng, address) {
    if (typeof address != 'undefined') {
        jQuery("tr[unique-id='" + count + "']").find("input[name='input_12\[\]']").eq(0).val(address);
    }
    jQuery("tr[unique-id='" + count + "']").find(".map_val_lat").val(lat);
    jQuery("tr[unique-id='" + count + "']").find(".map_val_lng").val(lng);
    jQuery(".latlong").text("coordinates: " + lat + ", " + lng);
    retriveLatLong();
}
function geocodePosition(pos, callback) {
    geocoder.geocode({
        latLng: pos
    }, function (responses) {
        if (typeof callback == 'function') {
            callback(responses);
        }
        // console.log(responses[0].formatted_address);
    });
}
function initMap(container, count, center) {
    var center_un = false;
    if (typeof center == 'undefined' || center == "undefined") {
        center_un = true;
        center = {lat: -25.3, lng: 133.8};
    }
    if (center.hasOwnProperty('lat')) {
        map[count] = new google.maps.Map(container, {
            zoom: center_un == true ? 4 : 15,
            center: center,
            mapTypeControl: false,
            panControl: false,
            zoomControl: false,
            streetViewControl: false
        });
        markers[count] = new google.maps.Marker({
            position: center,
            map: map[count],
        });
    }
}
if (typeof gform !== "undefined") {
    gform.addAction('gform_list_post_item_add', function ($elem, $container, map_lat, map_lng) {
        var d = new Date();
        var timstamp = d.getTime();
        $elem.attr("unique-id", timstamp);
        var inputAddress = $elem.find(".gfield_list_12_cell1 input");
        var mapElement = $elem.find(".map_container");
        if (inputAddress.length > 0) {
            globalMap.push(timstamp);
            initMap(mapElement[0], timstamp);
            addAutocomplete(inputAddress[0], timstamp);
        }
    });
    gform.addAction('gform_list_post_item_delete', function ($elem, $container, map_lat, map_lng) {
        genrateLocationNumber();
//     call_fixed_var();
    });
}
jQuery(window).load(function () {
    var d = new Date();
    var timstamp = d.getTime();
    if (jQuery("input[name='input_12[]']").length > 0) {
        globalMap.push(timstamp);
        initMap(jQuery(".map_container").eq(0)[0], timstamp);
        addAutocomplete(jQuery("input[name='input_12[]']").eq(0)[0], timstamp);
    }
});
jQuery(document).bind('gform_page_loaded', function (event, form_id, current_page) {
    console.log('form_id= ' + form_id + 'current_page= ' + current_page);
    if (current_page == 2) {
        if (jQuery("#input_2_38").length > 0 && jQuery("#input_2_38").val().length > 0) {
            global_map_lat_lng = JSON.parse(jQuery("#input_2_38").val());
            var $i = 0;
            for (var timstamp in global_map_lat_lng) {
                var $tableRow = jQuery(".gfield_list_group").eq($i);
                if ($tableRow.length > 0) {
                    $tableRow.attr("unique-id", timstamp);
                    initMap($tableRow.find(".map_container")[0], timstamp, {lat: parseFloat(global_map_lat_lng[timstamp]["lat"]), lng: parseFloat(global_map_lat_lng[timstamp]["lng"])});
                    addAutocomplete($tableRow.find("input[name='input_12[]']")[0], timstamp);
                }
                $i++;
            }
        } else {
            var d = new Date();
            var timestamp = d.getTime();
            var $elem = jQuery(".gfield_list .gfield_list_group ").eq(0);
            $elem.attr("unique-id", timestamp);
            if (jQuery("input[name='input_12[]']").length > 0) {
                globalMap.push(timestamp);
                initMap(jQuery(".map_container").eq(0)[0], timestamp);
                addAutocomplete(jQuery("input[name='input_12[]']").eq(0)[0], timestamp);
            }
        }
    }
});
jQuery(document).bind('gform_post_render', function () {
    jQuery('body').on('keyup', 'td[data-label="Column 1"] input[name="input_12[]"]', function (event) {
        $jK = 1;
    });
});
jQuery(document).on('keypress', '.gform_wrapper', function (e) {
    var code = e.keyCode || e.which;
    if (code == 13 && $jK == 1) {
        e.preventDefault();
        return false;
    }
});
<script src="//maps.googleapis.com/maps/api/js?key=AIzaSyAQqe5fTZZbQMcZwhXOuvCx5q9K1UF_7Hk&libraries=places" async defer></script>