123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- /*******************************************************************************
- * 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
- *******************************************************************************/
- // Baidu Maps: http://dev.baidu.com/wiki/map/index.php?title=%E9%A6%96%E9%A1%B5
- KindEditor.plugin('baidumap', function(K) {
- var self = this, name = 'baidumap', lang = self.lang(name + '.');
- var mapWidth = K.undef(self.mapWidth, 558);
- var mapHeight = K.undef(self.mapHeight, 360);
- self.clickToolbar(name, function() {
- var html = ['<div style="padding:10px 20px;">',
- '<div class="ke-header">',
- // left start
- '<div class="ke-left">',
- 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>',
- // right start
- '<div class="ke-right">',
- '<input type="checkbox" id="keInsertDynamicMap" name="insertDynamicMap" value="1" /> <label for="keInsertDynamicMap">' + lang.insertDynamicMap + '</label>',
- '</div>',
- '<div class="ke-clearfix"></div>',
- '</div>',
- '<div class="ke-map" style="width:' + mapWidth + 'px;height:' + mapHeight + 'px;"></div>',
- '</div>'].join('');
- var dialog = self.createDialog({
- name : name,
- width : mapWidth + 42,
- title : self.lang(name),
- body : html,
- yesBtn : {
- name : self.lang('yes'),
- click : function(e) {
- var map = win.map;
- var centerObj = map.getCenter();
- var center = centerObj.lng + ',' + centerObj.lat;
- var zoom = map.getZoom();
- var url = [checkbox[0].checked ? self.pluginsPath + 'baidumap/index.html' : 'http://api.map.baidu.com/staticimage',
- '?center=' + encodeURIComponent(center),
- '&zoom=' + encodeURIComponent(zoom),
- '&width=' + mapWidth,
- '&height=' + mapHeight,
- '&markers=' + encodeURIComponent(center),
- '&markerStyles=' + encodeURIComponent('l,A')].join('');
- if (checkbox[0].checked) {
- self.insertHtml('<iframe src="' + url + '" frameborder="0" style="width:' + (mapWidth + 2) + 'px;height:' + (mapHeight + 2) + 'px;"></iframe>');
- } else {
- self.exec('insertimage', url);
- }
- self.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),
- checkbox = K('[name="insertDynamicMap"]', dialog.div),
- win, doc;
- var iframe = K('<iframe class="ke-textarea" frameborder="0" src="' + self.pluginsPath + 'baidumap/map.html" style="width:' + mapWidth + 'px;height:' + mapHeight + 'px;"></iframe>');
- function ready() {
- win = iframe[0].contentWindow;
- doc = K.iframeDoc(iframe);
- }
- 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());
- });
- });
- });
|