<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
    <script type="text/javascript" src="../internal.js"></script>
    <style type="text/css">
        .content {
            width: 530px;
            height: 350px;
            margin: 10px auto;
        }

        .content table {
            width: 100%
        }

        .content table td {
            vertical-align: middle;
        }

        #address {
            width: 220px;
            height: 21px;
            background: #FFF;
            border: 1px solid #d7d7d7;
            line-height: 21px;
        }
    </style>
    <script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?sensor=false"></script>
</head>
<body>
<div class="content">
    <table>
        <tr>
            <td><label for="address"><var id="lang_input_address"></var></label></td>
            <td><input id="address" type="text"/></td>
            <td><a id="doSearch" href="javascript:void(0)" class="button"><var id="lang_input_search"></var></a></td>
        </tr>
    </table>
    <div id="container" style="width: 100%; height: 340px;margin: 5px auto; border: 1px solid gray;"></div>
</div>
<script type="text/javascript">
    domUtils.on(window, "load", function () {
        var map = new google.maps.Map(document.getElementById('container'), {
            zoom: 3,
            streetViewControl: false,
            scaleControl: true,
            mapTypeId: google.maps.MapTypeId.ROADMAP
        });
        var imgcss;
        var marker = new google.maps.Marker({
            map: map,
            draggable: true
        });

        function doSearch() {
            var address = document.getElementById('address').value;
            var geocoder = new google.maps.Geocoder();
            geocoder.geocode({'address': address}, function (results, status) {
                if (status == google.maps.GeocoderStatus.OK) {
                    var bounds = results[0].geometry.viewport;
                    map.fitBounds(bounds);
                    marker.setPosition(results[0].geometry.location);
                    marker.setTitle(address);
                } else alert(lang.searchError);
            });
        }

        $G('address').onkeydown = function (evt) {
            evt = evt || event;
            if (evt.keyCode == 13) {
                doSearch();
            }
        };
        $G("doSearch").onclick = doSearch;
        dialog.onok = function () {
            var center = map.getCenter();
            var point = marker.getPosition();
            var url = "http://maps.googleapis.com/maps/api/staticmap?center=" + center.lat() + ',' + center.lng() + "&zoom=" + map.zoom + "&size=520x340&maptype=" + map.getMapTypeId() + "&markers=" + point.lat() + ',' + point.lng() + "&sensor=false";
            editor.execCommand('inserthtml', '<img width="520" height="340" src="' + url + '"' + (imgcss ? ' style="' + imgcss + '"' : '') + '/>');
        };

        function getPars(str, par) {
            var reg = new RegExp(par + "=((\\d+|[.,])*)", "g");
            return reg.exec(str)[1];
        }

        var img = editor.selection.getRange().getClosedNode();
        if (img && img.src.indexOf("http://maps.googleapis.com/maps/api/staticmap") != -1) {
            var url = img.getAttribute("src");
            var centers = getPars(url, "center").split(",");
            point = new google.maps.LatLng(Number(centers[0]), Number(centers[1]));
            map.setCenter(point);
            map.setZoom(Number(getPars(url, "zoom")));
            centers = getPars(url, "markers").split(",");
            marker.setPosition(new google.maps.LatLng(Number(centers[0]), Number(centers[1])));
            imgcss = img.style.cssText;
        } else {
            setTimeout(function () {
                doSearch();
            }, 30)
        }
    });

</script>
</body>
</html>