/* * 表情处理 */ var smilies_array = new Array(); smilies_array[1] = [['1', ':smile:', 'smile.gif', '28', '28', '28', '微笑'], ['2', ':sad:', 'sad.gif', '28', '28', '28', '难过'], ['3', ':biggrin:', 'biggrin.gif', '28', '28', '28', '呲牙'], ['4', ':cry:', 'cry.gif', '28', '28', '28', '大哭'], ['5', ':huffy:', 'huffy.gif', '28', '28', '28', '发怒'], ['6', ':shocked:', 'shocked.gif', '28', '28', '28', '惊讶'], ['7', ':tongue:', 'tongue.gif', '28', '28', '28', '调皮'], ['8', ':shy:', 'shy.gif', '28', '28', '28', '害羞'], ['9', ':titter:', 'titter.gif', '28', '28', '28', '偷笑'], ['10', ':sweat:', 'sweat.gif', '28', '28', '28', '流汗'], ['11', ':mad:', 'mad.gif', '28', '28', '28', '抓狂'], ['12', ':lol:', 'lol.gif', '28', '28', '28', '阴险'], ['13', ':loveliness:', 'loveliness.gif', '28', '28', '28', '可爱'], ['14', ':funk:', 'funk.gif', '28', '28', '28', '惊恐'], ['15', ':curse:', 'curse.gif', '28', '28', '28', '咒骂'], ['16', ':dizzy:', 'dizzy.gif', '28', '28', '28', '晕'], ['17', ':shutup:', 'shutup.gif', '28', '28', '28', '闭嘴'], ['18', ':sleepy:', 'sleepy.gif', '28', '28', '28', '睡'], ['19', ':hug:', 'hug.gif', '28', '28', '28', '拥抱'], ['20', ':victory:', 'victory.gif', '28', '28', '28', '胜利'], ['21', ':sun:', 'sun.gif', '28', '28', '28', '太阳'], ['22', ':moon:', 'moon.gif', '28', '28', '28', '月亮'], ['23', ':kiss:', 'kiss.gif', '28', '28', '28', '示爱'], ['24', ':handshake:', 'handshake.gif', '28', '28', '28', '握手']]; (function ($) { $.fn.smilies = function (options) { var settings = $.extend({}, {smilies_id: '_message'}, options); settings.smilies_div = "#" + settings.smilies_id + "_smilies_div"; $(document).click(function () { $(settings.smilies_div).html(''); $(settings.smilies_div).hide(); }); $(this).after('
'); $(settings.smilies_div).position({ of: $("body"), at: "left bottom", offset: "10 10" }); $(this).on('click', function () { //光标处插入代码功能 smiliesshowdiv(this); return false; }); //显示和隐藏表情模块 function smiliesshowdiv(btnobj) { if ($(settings.smilies_div).css("display") == 'none') { if ($(settings.smilies_div).html() == '') { smilies_show(8, 'e_' + settings.smilies_id + '_'); } $(settings.smilies_div).show(); smiliesposition(btnobj); } else { $(settings.smilies_div).hide(); } } //弹出层位置控制 function smiliesposition(btnobj) { $(settings.smilies_div).position({ of: btnobj, at: "left bottom", offset: "110 57" }); } function smilies_show(smcols, seditorkey) { if (seditorkey && !$("#" + seditorkey + 'sml_menu')[0]) { var div = document.createElement("div"); div.id = seditorkey + 'sml_menu'; div.className = 'sllt'; $(settings.smilies_div).append(div); div = document.createElement("div"); div.id = '' + settings.smilies_id + '_smilies_content'; div.style.overflow = 'hidden'; $("#" + seditorkey + 'sml_menu').append(div); } smilies_onload(smcols, seditorkey); //image绑定操作函数 $('#' + settings.smilies_id + '_smilies_content').find("td").bind('click', function () { insertsmilie(this); }); } function insertsmilie(smilieone) { var code = $(smilieone).attr('codetext'); insertAtCaret(code); $('#' + settings.smilies_id).focus(); $(settings.smilies_div).html(''); $(settings.smilies_div).hide(); } function insertAtCaret(textFeildValue) { var textObj = $('#' + settings.smilies_id).get(0); if (document.all && textObj.createTextRange && textObj.caretPos) { var caretPos = textObj.caretPos; caretPos.text = caretPos.text.charAt(caretPos.text.length - 1) == '' ? textFeildValue + '' : textFeildValue; } else if (textObj.setSelectionRange) { var rangeStart = textObj.selectionStart; var rangeEnd = textObj.selectionEnd; var tempStr1 = textObj.value.substring(0, rangeStart); var tempStr2 = textObj.value.substring(rangeEnd); textObj.value = tempStr1 + textFeildValue + tempStr2; textObj.focus(); var len = textFeildValue.length; textObj.setSelectionRange(rangeStart + len, rangeStart + len); textObj.blur(); } else { textObj.value += textFeildValue; } } function smilies_onload(smcols, seditorkey) { seditorkey = !seditorkey ? '' : seditorkey; $('#' + settings.smilies_id + '_smilies_content').html('
'); smilies_switch(smcols, seditorkey); } function smilies_switch(smcols, seditorkey) { var page = 1; if (!smilies_array || !smilies_array[page]) return; smiliesdata = ''; j = k = 0; img = []; for (i in smilies_array[page]) { if (j >= smcols) { smiliesdata += ''; j = 0; } var s = smilies_array[page][i]; smilieimg = BASESITEROOT + '/static/plugins/js/smilies/images/' + s[2]; img[k] = new Image(); img[k].src = smilieimg; smiliesdata += s && s[0] ? '
' + s[1] + '' : ''; j++; k++; } smiliesdata += '
'; $('#' + settings.smilies_id + '_smilies_content_data').html(smiliesdata); } } })(jQuery);