mirror of
https://github.com/e107inc/e107.git
synced 2025-01-17 20:58:30 +01:00
81 lines
2.4 KiB
JavaScript
81 lines
2.4 KiB
JavaScript
|
/*
|
||
|
* Content Editable Plugin for jQuery
|
||
|
* Version 1.0.0 (2013-02-15)
|
||
|
* Plugin website: http://labs.fellipesoares.com/plugins/contenteditable
|
||
|
* Author: Fellipe Soares Studio
|
||
|
* Author website: http://www.fellipesoares.com/
|
||
|
* Dual licensed under the MIT and GPL licenses:
|
||
|
* http://www.opensource.org/licenses/mit-license.php
|
||
|
* http://www.gnu.org/licenses/gpl.html
|
||
|
*/
|
||
|
;(function($,window,document){
|
||
|
|
||
|
var updateContent = function(element){
|
||
|
var c = $(element).html();
|
||
|
if(c == '' || c == '<br>' || c == ' ' || c == '</br>'){ c = ''; }
|
||
|
return c;
|
||
|
};
|
||
|
|
||
|
$.fn.contentEditable = function(options){
|
||
|
|
||
|
var defaults = {
|
||
|
'placeholder' : 'Insert content',
|
||
|
'newLineOnEnterKey' : false,
|
||
|
'onActivate' : false,
|
||
|
'onFocusIn' : false,
|
||
|
'onFocusOut' : false,
|
||
|
'onBlur' : false
|
||
|
};
|
||
|
var settings = $.extend( {}, defaults, options);
|
||
|
|
||
|
return this.each(function() {
|
||
|
$(this).attr("contenteditable","true");
|
||
|
this.content = $(this).html();
|
||
|
this.settings = settings;
|
||
|
if(this.content == ''){ $(this).html(settings.placeholder); }
|
||
|
$(this).on('activate',function(){
|
||
|
this.content = updateContent(this);
|
||
|
if(this.content == settings.placeholder){
|
||
|
$(this).empty();
|
||
|
var range, sel;
|
||
|
if ( (sel = document.selection) && document.body.createTextRange) {
|
||
|
range = document.body.createTextRange();
|
||
|
range.moveToElementText(this);
|
||
|
range.select();
|
||
|
}
|
||
|
}
|
||
|
if($.isFunction(settings.onActivate)){ settings.onActivate(this); }
|
||
|
})
|
||
|
.focusin(function(e){
|
||
|
this.content = updateContent(this);
|
||
|
if(this.content == settings.placeholder){
|
||
|
$(this).empty();
|
||
|
var range = document.createRange();
|
||
|
range.selectNodeContents(this);
|
||
|
var sel = window.getSelection();
|
||
|
sel.removeAllRanges();
|
||
|
sel.addRange(range);
|
||
|
}
|
||
|
if(settings.newLineOnEnterKey == false){
|
||
|
$(this).keypress(function(e){
|
||
|
var keycode = (e.keyCode ? e.keyCode : e.which);
|
||
|
if(keycode == '13') {
|
||
|
e.preventDefault();
|
||
|
$(this).focusout().blur();
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
if($.isFunction(settings.onFocusIn)){ settings.onFocusIn(this); }
|
||
|
})
|
||
|
.focusout(function(e){
|
||
|
this.content = updateContent(this);
|
||
|
$(this).unbind("keypress");
|
||
|
if(this.content == ''){ $(this).html(settings.placeholder); }
|
||
|
if($.isFunction(settings.onFocusOut)){ settings.onFocusOut(this); }
|
||
|
}).blur(function(e){
|
||
|
if($.isFunction(settings.onBlur)){ settings.onBlur(this); }
|
||
|
});
|
||
|
});
|
||
|
}
|
||
|
})(jQuery,window,document);
|