123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- /*
- * 表情处理
- */
- 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('<div id="'+settings.smilies_id+'_smilies_div" class="smilies-module"></div>');
- $(settings.smilies_div).position({
- of: $("body"),
- at: "left bottom",
- offset: "10 10"
- });
-
- $(this).live('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('<div id="'+settings.smilies_id+'_smilies_content_data"></div><div class="sllt-p" id="'+settings.smilies_id+'_smilies_content_page"></div>');
- smilies_switch(smcols, seditorkey);
- }
- function smilies_switch(smcols, seditorkey) {
- var page = 1;
- if(!smilies_array || !smilies_array[page]) return;
- smiliesdata = '<table id="'+settings.smilies_id+'_smilies_content_table" cellpadding="0" cellspacing="0"><tr>';
- j = k = 0;
- img = [];
- for(i in smilies_array[page]) {
- if(j >= smcols) {
- smiliesdata += '<tr>';
- j = 0;
- }
- var s = smilies_array[page][i];
- smilieimg = RESOURCE_SITE_URL + '/js/smilies/images/' + s[2];
- img[k] = new Image();
- img[k].src = smilieimg;
- smiliesdata += s && s[0] ? '<td id="' + seditorkey + 'smilie_' + s[0] + '_td" codetext="'+s[1]+'"><img id="'+seditorkey+'smilie_' + s[0] + '" width="' + s[3] +'" height="' + s[4] +'" src="' + smilieimg + '" alt="' + s[1] + '" title="'+s[6]+'" />' : '<td>';
- j++; k++;
- }
- smiliesdata += '</table>';
- $('#'+settings.smilies_id+'_smilies_content_data').html(smiliesdata);
- }
- }
- })(jQuery);
|