| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 | /******************************************************************************** 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*******************************************************************************/KindEditor.plugin('insertfile', function(K) {	var self = this, name = 'insertfile',		allowFileManager = K.undef(self.allowFileManager, false),		uploadJson = K.undef(self.uploadJson, self.basePath + 'php/upload_json.php'),		lang = self.lang(name + '.');		self.plugin.fileDialog = function(options) {		var fileUrl = K.undef(options.fileUrl, 'http://'),			fileTitle = K.undef(options.fileTitle, ''),			clickFn = options.clickFn;		var html = [			'<div style="padding:10px 20px;">',			'<div class="ke-dialog-row">',			'<label for="keUrl" style="width:60px;">' + lang.url + '</label>',			'<input type="text" id="keUrl" name="url" class="ke-input-text" style="width:160px;" />  ',			'<input type="button" class="ke-upload-button" value="' + lang.upload + '" />  ',			'<span class="ke-button-common ke-button-outer">',			'<input type="button" class="ke-button-common ke-button" name="viewServer" value="' + lang.viewServer + '" />',			'</span>',			'</div>',			//title			'<div class="ke-dialog-row">',			'<label for="keTitle" style="width:60px;">' + lang.title + '</label>',			'<input type="text" id="keTitle" class="ke-input-text" name="title" value="" style="width:160px;" /></div>',			'</div>',			//form end			'</form>',			'</div>'			].join('');		var dialog = self.createDialog({			name : name,			width : 450,			height : 180,			title : self.lang(name),			body : html,			yesBtn : {				name : self.lang('yes'),				click : function(e) {					var url = K.trim(urlBox.val()),						title = titleBox.val();					if (url == 'http://' || K.invalidUrl(url)) {						alert(self.lang('invalidUrl'));						urlBox[0].focus();						return;					}					if (K.trim(title) === '') {						title = url;					}					clickFn.call(self, url, title);				}			},			beforeRemove : function() {				viewServerBtn.remove();				uploadbutton.remove();			}		}),		div = dialog.div;		var urlBox = K('[name="url"]', div),			viewServerBtn = K('[name="viewServer"]', div),			titleBox = K('[name="title"]', div);		var uploadbutton = K.uploadbutton({			button : K('.ke-upload-button', div)[0],			fieldName : 'imgFile',			url : K.addParam(uploadJson, 'dir=file'),			afterUpload : function(data) {				dialog.hideLoading();				if (data.error === 0) {					var url = K.formatUrl(data.url, 'absolute');					urlBox.val(url);					if (self.afterUpload) {						self.afterUpload.call(self, url);					}					alert(self.lang('uploadSuccess'));				} else {					alert(data.message);				}			},			afterError : function(html) {				dialog.hideLoading();				self.errorDialog(html);			}		});		uploadbutton.fileBox.change(function(e) {			dialog.showLoading(self.lang('uploadLoading'));			uploadbutton.submit();		});		if (allowFileManager) {			viewServerBtn.click(function(e) {				self.loadPlugin('filemanager', function() {					self.plugin.filemanagerDialog({						viewType : 'LIST',						dirName : 'file',						clickFn : function(url, title) {							if (self.dialogs.length > 1) {								K('[name="url"]', div).val(url);								self.hideDialog();							}						}					});				});			});		} else {			viewServerBtn.hide();		}		urlBox.val(fileUrl);		titleBox.val(fileTitle);		urlBox[0].focus();		urlBox[0].select();	};	self.clickToolbar(name, function() {		self.plugin.fileDialog({			clickFn : function(url, title) {				var html = '<a href="' + url + '" data-ke-src="' + url + '" target="_blank">' + title + '</a>';				self.insertHtml(html).hideDialog().focus();			}		});	});});
 |