You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
140 lines
5.8 KiB
140 lines
5.8 KiB
5 years ago
|
/*******************************************************************************
|
||
|
* KindEditor - WYSIWYG HTML Editor for Internet
|
||
|
* Copyright (C) 2006-2011 kindsoft.net
|
||
|
*
|
||
|
* @author Roddy <luolonghao@gmail.com>
|
||
|
* @site http://www.kindsoft.net/
|
||
|
* @licence http://www.kindsoft.net/license.php
|
||
|
*******************************************************************************/
|
||
|
|
||
|
// Google Maps: http://code.google.com/apis/maps/index.html
|
||
|
|
||
|
KindEditor.plugin('map', function (K) {
|
||
|
var self = this, name = 'map', lang = self.lang(name + '.');
|
||
|
self.clickToolbar(name, function () {
|
||
|
var html = ['<div style="padding:10px 20px;">',
|
||
|
'<div class="ke-dialog-row">',
|
||
|
lang.address + ' <input id="kindeditor_plugin_map_address" name="address" class="ke-input-text" value="" style="width:200px;" /> ',
|
||
|
'<span class="ke-button-common ke-button-outer">',
|
||
|
'<input type="button" name="searchBtn" class="ke-button-common ke-button" value="' + lang.search + '" />',
|
||
|
'</span>',
|
||
|
'</div>',
|
||
|
'<div class="ke-map" style="width:558px;height:360px;"></div>',
|
||
|
'</div>'].join('');
|
||
|
var dialog = self.createDialog({
|
||
|
name: name,
|
||
|
width: 600,
|
||
|
title: self.lang(name),
|
||
|
body: html,
|
||
|
yesBtn: {
|
||
|
name: self.lang('yes'),
|
||
|
click: function (e) {
|
||
|
var geocoder = win.geocoder,
|
||
|
map = win.map,
|
||
|
center = map.getCenter().lat() + ',' + map.getCenter().lng(),
|
||
|
zoom = map.getZoom(),
|
||
|
maptype = map.getMapTypeId(),
|
||
|
url = 'http://maps.googleapis.com/maps/api/staticmap';
|
||
|
url += '?center=' + encodeURIComponent(center);
|
||
|
url += '&zoom=' + encodeURIComponent(zoom);
|
||
|
url += '&size=558x360';
|
||
|
url += '&maptype=' + encodeURIComponent(maptype);
|
||
|
url += '&markers=' + encodeURIComponent(center);
|
||
|
url += '&language=' + self.langType;
|
||
|
url += '&sensor=false';
|
||
|
self.exec('insertimage', url).hideDialog().focus();
|
||
|
}
|
||
|
},
|
||
|
beforeRemove: function () {
|
||
|
searchBtn.remove();
|
||
|
if (doc) {
|
||
|
doc.write('');
|
||
|
}
|
||
|
iframe.remove();
|
||
|
}
|
||
|
});
|
||
|
var div = dialog.div,
|
||
|
addressBox = K('[name="address"]', div),
|
||
|
searchBtn = K('[name="searchBtn"]', div),
|
||
|
win, doc;
|
||
|
var iframeHtml = ['<!doctype html><html><head>',
|
||
|
'<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />',
|
||
|
'<style>',
|
||
|
' html { height: 100% }',
|
||
|
' body { height: 100%; margin: 0; padding: 0; background-color: #FFF }',
|
||
|
' #map_canvas { height: 100% }',
|
||
|
'</style>',
|
||
|
'<script src="http://maps.googleapis.com/maps/api/js?sensor=false&language=' + self.langType + '"></script>',
|
||
|
'<script>',
|
||
|
'var map, geocoder;',
|
||
|
'function initialize() {',
|
||
|
' var latlng = new google.maps.LatLng(31.230393, 121.473704);',
|
||
|
' var options = {',
|
||
|
' zoom: 11,',
|
||
|
' center: latlng,',
|
||
|
' disableDefaultUI: true,',
|
||
|
' panControl: true,',
|
||
|
' zoomControl: true,',
|
||
|
' mapTypeControl: true,',
|
||
|
' scaleControl: true,',
|
||
|
' streetViewControl: false,',
|
||
|
' overviewMapControl: true,',
|
||
|
' mapTypeId: google.maps.MapTypeId.ROADMAP',
|
||
|
' };',
|
||
|
' map = new google.maps.Map(document.getElementById("map_canvas"), options);',
|
||
|
' geocoder = new google.maps.Geocoder();',
|
||
|
' geocoder.geocode({latLng: latlng}, function(results, status) {',
|
||
|
' if (status == google.maps.GeocoderStatus.OK) {',
|
||
|
' if (results[3]) {',
|
||
|
' parent.document.getElementById("kindeditor_plugin_map_address").value = results[3].formatted_address;',
|
||
|
' }',
|
||
|
' }',
|
||
|
' });',
|
||
|
'}',
|
||
|
'function search(address) {',
|
||
|
' if (!map) return;',
|
||
|
' geocoder.geocode({address : address}, function(results, status) {',
|
||
|
' if (status == google.maps.GeocoderStatus.OK) {',
|
||
|
' map.setZoom(11);',
|
||
|
' map.setCenter(results[0].geometry.location);',
|
||
|
' var marker = new google.maps.Marker({',
|
||
|
' map: map,',
|
||
|
' position: results[0].geometry.location',
|
||
|
' });',
|
||
|
' } else {',
|
||
|
' alert("Invalid address: " + address);',
|
||
|
' }',
|
||
|
' });',
|
||
|
'}',
|
||
|
'</script>',
|
||
|
'</head>',
|
||
|
'<body onload="initialize();">',
|
||
|
'<div id="map_canvas" style="width:100%; height:100%"></div>',
|
||
|
'</body></html>'].join('\n');
|
||
|
// TODO:用doc.write(iframeHtml)方式加载时,在IE6上第一次加载报错,暂时使用src方式
|
||
|
var iframe = K('<iframe class="ke-textarea" frameborder="0" src="' + self.pluginsPath + 'map/map.html" style="width:558px;height:360px;"></iframe>');
|
||
|
|
||
|
function ready() {
|
||
|
win = iframe[0].contentWindow;
|
||
|
doc = K.iframeDoc(iframe);
|
||
|
//doc.open();
|
||
|
//doc.write(iframeHtml);
|
||
|
//doc.close();
|
||
|
}
|
||
|
|
||
|
iframe.bind('load', function () {
|
||
|
iframe.unbind('load');
|
||
|
if (K.IE) {
|
||
|
ready();
|
||
|
} else {
|
||
|
setTimeout(ready, 0);
|
||
|
}
|
||
|
});
|
||
|
K('.ke-map', div).replaceWith(iframe);
|
||
|
// search map
|
||
|
searchBtn.click(function () {
|
||
|
win.search(addressBox.val());
|
||
|
});
|
||
|
});
|
||
|
});
|