user.js 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999
  1. var new_interval = 1;//消息提醒计时
  2. var connect = 0;//连接状态
  3. var new_msg = 0;//新消息数
  4. var obj = {};
  5. var chat_log = {};
  6. var connect_list = {};
  7. var connect_n = 0;
  8. var web_info = new Array();//页面信息
  9. var friend_list = new Array();//我的好友
  10. var recent_list = new Array();//最近联系人
  11. var user_list = new Array();//所有会员信息
  12. var msg_list = new Array();//收到消息
  13. var goods_list = new Array();//所有商品信息
  14. var store_goods = new Array();//店铺推荐的商品
  15. var dialog_show = 0;//对话框是否打开
  16. var user_show = 0;//当前选择的会员
  17. var msg_max = 20;//消息数
  18. var chat_audio = 1;//消息提醒声音开关
  19. var audio_info = '<object width="1" height="1" style="position: absolute; left: -1px;" id="msg_audio" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000">' +
  20. '<param value="' + CHAT_SITE_URL + '/audio.swf" name="movie"><param value="always" name="allowscriptaccess">' +
  21. '<embed width="1" height="1" allowscriptaccess="always" src="' + CHAT_SITE_URL + '/audio.swf" name="msg_audio"></object>';
  22. $(function () {
  23. if (user['u_id'] != '') {
  24. web_info['chat_goods_html'] = '';
  25. web_info['html_title'] = $(document).attr('title');
  26. web_info['msg_dialog'] = '<div id="new_msg_dialog" class="msg-windows"><div class="user-tab-bar"><ul class="user-list" id="user_list"></ul></div>' +
  27. '<div class="msg-dialog"><div class="dialog-body">' +
  28. '<div id="msg_list" class="msg-contnet"><div id="user_msg_list"></div></div>' +
  29. '<div class="msg-input-box"><div class="msg-input-title"><div class="chat_tools"><i id="chat_show_smilies" class="iconfont">&#xe669;</i></div>' +
  30. '<span class="title">输入聊天信息</span><span class="chat-log-btn off" onclick="show_chat_log();">聊天记录<i></i></span></div>' +
  31. '<form id="msg_form"><textarea name="send_message" id="send_message" class="textarea" onkeyup="send_keyup(event);" onfocus="send_focus();" ></textarea>' +
  32. '<div class="msg-bottom"><div id="msg_count"></div><a href="JavaScript:void(0);" onclick="send_msg();" class="msg-button"><i></i>发送消息</a><div id="send_alert"></div></div></form></div></div>' +
  33. '<div id="dialog_chat_right" class="dialog-chat-right"></div><div id="dialog_chat_log" class="dialog_chat_log"></div></div>' +
  34. '<div id="dialog_clear" class="dialog_clear"></div></div>';
  35. var chat_user_list = '<div class="chat-box"><div class="chat-list"><div class="chat-list-top"><img class="avatar" src="' + user['avatar'] + '?' + Math.floor(Math.random() * 100) + '" /><h1>' + user['u_name'] + '</h1><span class="minimize-chat-list iconfont" onclick="chat_show_list();">&#xe6e6;</span></div>' +
  36. '<div id="chat_user_list" class="chat-list-content"><div><dl id="chat_user_friends"><dt onclick="chat_show_user_list(\'friends\');">' +
  37. '<span class="show"></span>我的好友</dt><dd id="chat_friends" style="display: none;"></dd></dl>' +
  38. '<dl id="chat_user_recent"><dt onclick="chat_show_user_list(\'recent\');"><span class="show"></span>最近联系人</dt><dd id="chat_recent" style="display: none;"></dd></dl></div></div>' +
  39. '<div class="bottom-bar"><a href="' + HOMESITEURL + '/Membersnsfriend/index.html" target="_blank"><i class="iconfont">&#xe76d;</i></a></div>' +
  40. '</div></div>';
  41. var ajaxurl = HOMESITEURL + '/MemberInstantMessage/get_user_list?n=99&f_id=' + user['u_id'];
  42. $.ajax({
  43. type: "GET",
  44. url: ajaxurl,
  45. dataType: "json",
  46. async: true,
  47. success: function (res) {
  48. if (res.code != 10000) {
  49. return false;
  50. }
  51. var u_list = res.result.user_list
  52. for (var i in u_list) {
  53. var user_info = u_list[i];
  54. var u_id = user_info['u_id']
  55. connect_list[u_id] = 0;
  56. connect_n++;
  57. set_user_info(u_id, "u_name", user_info['u_name']);
  58. set_user_info(u_id, "avatar", user_info['avatar']);
  59. if (user_info['friend'] == 1)
  60. friend_list[u_id] = user_info;
  61. if (user_info['recent'] == 1)
  62. recent_list[u_id] = user_info;
  63. }
  64. setTimeout("getconnect()", 1000);
  65. $("#web_chat_dialog").prepend(chat_user_list);
  66. $('#chat_user_list').perfectScrollbar();
  67. $("#chat_show_user").click(function () {
  68. chat_show_list();
  69. });
  70. }
  71. });
  72. } else {
  73. var n = send_state();
  74. if (n > 0)
  75. setTimeout("getconnect()", 2000);
  76. $("#chat_show_user").click(function () {
  77. $('div[dstype="a-barLoginBox"]').trigger("click");
  78. });
  79. }
  80. });
  81. $("#web_chat_dialog").after(audio_info);
  82. function msg_dialog_close(id) {
  83. if (dialog_show == 1) {
  84. $("#" + id).hide("slide", {direction: 'right'}, 300);
  85. }
  86. dialog_show = 0;
  87. close_chat_log(user_show);
  88. if (connect === 1) {
  89. $("#web_chat_dialog").show();
  90. }
  91. }
  92. function msg_dialog_show(id) {
  93. if (dialog_show == 0) {
  94. $("#" + id).show("slide", {direction: 'right'}, 600,
  95. function () {
  96. $("#send_message").focus();
  97. var obj_msg = obj.find("div[select_user_msg='" + user_show + "']");
  98. obj.find("#msg_list").scrollTop(obj_msg.height());
  99. });
  100. } else {
  101. $("#send_message").focus();
  102. }
  103. dialog_show = 1;
  104. if ($("#msg_count").html() == '') {
  105. $("#send_message").charCount({//输入字数控制
  106. allowed: 255,
  107. warning: 10,
  108. counterContainerID: 'msg_count',
  109. firstCounterText: '还可以输入',
  110. endCounterText: '字',
  111. errorCounterText: '已经超出'
  112. });
  113. $("#chat_show_smilies").smilies({smilies_id: "send_message"});
  114. }
  115. }
  116. function send_state() { //向服务器请求页面中的相关会员的在线状态
  117. var u_list = connect_list;
  118. var n = connect_n;
  119. switch (controller_act) {
  120. case "brand_list":
  121. case "search_index":
  122. $(".list_pic em[member_id]").each(function () {
  123. n++;
  124. var u_id = $(this).attr("member_id");
  125. if (u_id > 0 && u_id != user['u_id'])
  126. u_list[u_id] = 0;
  127. });
  128. break;
  129. default:
  130. $("[member_id]").each(function () {
  131. n++;
  132. var u_id = $(this).attr("member_id");
  133. if (u_id > 0 && u_id != user['u_id'])
  134. u_list[u_id] = 0;
  135. });
  136. break;
  137. }
  138. $('[dstype="mcard"]').each(function () {
  139. var data_str = $(this).attr('data-param');
  140. eval('var mcard_obj = ' + data_str);
  141. var u_id = mcard_obj["id"];
  142. if (u_id > 0 && u_id != user['u_id']) {
  143. n++;
  144. u_list[u_id] = 0;
  145. }
  146. });
  147. if (connect === 1) {
  148. if (n > 0) {
  149. var u_ids = Object.keys(u_list)
  150. ws.send('get_state:' + u_ids.join(','))
  151. } else {
  152. if (user['u_id'] == '') {
  153. ws.close();
  154. }
  155. }
  156. } else {
  157. return n;
  158. }
  159. }
  160. function get_state(list) {//返回会员的状态并在页面显示
  161. var u_list = list['u_state'];
  162. //店铺页面 唤起对话框
  163. if (layout == 'store' || controller_act == 'Goods_index') {
  164. var store_id = 0;
  165. var store_name = '';
  166. $("[member_id]").each(function () {
  167. var u_id = $(this).attr("member_id");
  168. if (store_id > 0) {
  169. set_user_info(u_id, "s_id", store_id);
  170. set_user_info(u_id, "s_name", store_name);
  171. }
  172. set_user_info(u_id, "online", u_list[u_id]);
  173. if ($(this).find(".chat").size() == 0) {
  174. $(this).prepend(get_chat(u_id, u_list[u_id]));
  175. if ($(this).attr("c_name")) {//店铺客服
  176. var c_name = $(this).attr("c_name");
  177. set_user_info(u_id, "c_name", c_name);
  178. $(this).find(".chat").attr("href", "JavaScript:store_chat(" + u_id + ",'" + c_name + "');");
  179. }
  180. }
  181. });
  182. } else {
  183. switch (controller_act) {
  184. case "brand_list":
  185. case "search_index":
  186. $(".list_pic em[member_id]").each(function () {
  187. var u_id = $(this).attr("member_id");
  188. if ($(this).find(".chat").size() == 0) {
  189. $(this).prepend(get_chat(u_id, u_list[u_id]));
  190. $(this).after("<p>在线客服</p>");
  191. }
  192. set_user_info(u_id, "online", u_list[u_id]);
  193. });
  194. break;
  195. default:
  196. $("[member_id]").each(function () {
  197. var u_id = $(this).attr("member_id");
  198. if ($(this).find(".chat").size() == 0) {
  199. $(this).prepend(get_chat(u_id, u_list[u_id]));
  200. }
  201. set_user_info(u_id, "online", u_list[u_id]);
  202. });
  203. break;
  204. }
  205. }
  206. if (user['u_id'] != '') {
  207. update_recent(u_list);
  208. update_friends(u_list);
  209. } else {
  210. ws.close();
  211. }
  212. }
  213. function show_obj() {//弹出框
  214. if (user_show < 1) {
  215. chat_show_list();
  216. return false;
  217. }
  218. msg_dialog_show('new_msg_dialog');
  219. }
  220. function send_focus() {
  221. $("#send_alert").html('');
  222. }
  223. function send_keyup(event) {//回车发消息
  224. var t_msg = $.trim($("#send_message").val());
  225. if (event.keyCode == 13 && t_msg.length > 0) {
  226. send_msg();
  227. }
  228. }
  229. function send_msg(type=0) {//发消息
  230. if (user_show < 1) {
  231. $("#send_alert").html('未选择聊天会员');
  232. return false;
  233. }
  234. var msg = {};
  235. msg['to_id'] = user_show;
  236. if(type==0){
  237. msg['message'] = $.trim($("#send_message").val());
  238. msg['message_type'] = 0
  239. if (msg['message'].length < 1) {
  240. $("#send_alert").html('发送内容不能为空');
  241. return false;
  242. }
  243. if (msg['message'].length > 255) {
  244. $("#send_alert").html('一次最多只能发送255字');
  245. return false;
  246. }
  247. }else{
  248. msg['message'] = chat_goods_id
  249. msg['message_type'] = 1
  250. }
  251. if (connect < 1) {
  252. $("#send_alert").html('处于离线状态,稍后再试');
  253. return false;
  254. }
  255. $.ajax({
  256. type: "POST",
  257. url: HOMESITEURL + '/MemberInstantMessage/add',
  258. dataType: "json",
  259. data: msg,
  260. async: false,
  261. success: function (res) {
  262. if (res['code'] != 10000) {
  263. $("#send_alert").html('' + res['message']);
  264. return false;
  265. } else {
  266. var t_msg = res.result.instant_message_data
  267. if (connect === 1) {
  268. $("#send_message").val('');
  269. $("#send_message").focus();
  270. $("#send_alert").html('');
  271. show_t_msg(t_msg);
  272. return true;
  273. } else {
  274. $("#send_alert").html('由于网络原因未发送成功,稍后再试');
  275. return false;
  276. }
  277. }
  278. }
  279. });
  280. }
  281. function get_msg(list) {//接收消息
  282. var msg = {};
  283. for (var k in list) {
  284. msg = list[k];
  285. var m_id = msg['instant_message_id'];
  286. var u_id = msg['instant_message_from_id'];
  287. set_user(u_id, msg['instant_message_from_name']);
  288. if (typeof msg_list[u_id][m_id] === "object") {//防止重复计数
  289. continue;
  290. }
  291. if (typeof msg['user'] === "object" && typeof msg['user']['avatar'] !== "undefined") {
  292. var user_info = msg['user'];
  293. var u_name = user_info['u_name'];
  294. set_user_info(u_id, "u_name", u_name);
  295. set_user_info(u_id, "s_id", user_info['s_id']);
  296. set_user_info(u_id, "s_name", user_info['s_name']);
  297. set_user_info(u_id, "avatar", user_info['avatar']);
  298. set_user_info(u_id, "s_avatar", user_info['s_avatar']);
  299. if (user_info['online'] > 0)
  300. set_user_info(u_id, "online", 1);
  301. }
  302. if (typeof user_list[u_id]['avatar'] === "undefined") {//当没获得会员信息时调用一次
  303. var ajaxurl = HOMESITEURL + '/MemberInstantMessage/get_info?t=member&u_id=' + u_id;
  304. $.ajax({
  305. type: "GET",
  306. url: ajaxurl,
  307. dataType: "json",
  308. async: false,
  309. success: function (res) {
  310. if (res.code != 10000) {
  311. return false
  312. }
  313. var member = res.result.user_info
  314. var u_name = member['member_name'];
  315. set_user_info(u_id, "s_id", member['store_id']);
  316. set_user_info(u_id, "s_name", member['store_name']);
  317. set_user_info(u_id, "avatar", member['member_avatar']);
  318. set_user_info(u_id, "s_avatar", member['store_avatar']);
  319. }
  320. });
  321. }
  322. msg_list[u_id][m_id] = msg;
  323. if (dialog_show == 0 || obj.find("li[select_u_id='" + u_id + "']").size() == 0) {//没有打开对话窗口时计数
  324. user_list[u_id]['new_msg']++;
  325. new_msg++;
  326. } else {
  327. if (user_show == u_id) {
  328. show_msg(u_id);//当前对话的会员消息设为已读
  329. play_audio();
  330. } else {
  331. user_list[u_id]['new_msg']++;
  332. new_msg++;
  333. }
  334. }
  335. alert_user_msg(u_id);
  336. }
  337. alert_msg();
  338. }
  339. function get_chat_log(time_from) {
  340. var obj_chat_log = $("#dialog_chat_log");
  341. if (obj_chat_log.html() == '') {
  342. var chat_log_list = '<div class="chat-log-top"><h1><i class="iconfont">&#xe71b;</i>聊天记录</h1><span class="close-chat-log iconfont" onclick="show_chat_log();">&#xe696;</span></div>' +
  343. '<div id="chat_log_list" class="chat_log_list"><div id="chat_log_msg" class="chat-log-msg"></div></div><div class="chat-log-bottom"><div id="chat_time_from" class="chat_time_from">' +
  344. '<span time_id="7" onclick="get_chat_log(7);" class="current">7天</span><span time_id="15" onclick="get_chat_log(15);">15天</span><span time_id="30" onclick="get_chat_log(30);">30天</span></div>' +
  345. '<div class="chat_log_first"><p>已到第一页</p></div><div class="chat_log_last"><p>已到最后一页</p></div>' +
  346. '<div id="chat_log_page" class="chat_log_page"><span onclick="get_chat_previous();" class="previous iconfont" title="上一页">&#xe619;</span><span onclick="get_chat_next();" class="next iconfont" title="下一页">&#xe618;</span></div></div>';
  347. obj_chat_log.append(chat_log_list);
  348. }
  349. obj_chat_log.show();
  350. chat_log['u_id'] = user_show;
  351. chat_log['now_page'] = 0;
  352. chat_log['total_page'] = 0;
  353. chat_log['time_from'] = 7;
  354. chat_log['list'] = new Array();
  355. var time_id = obj_chat_log.find("span.current").attr("time_id");
  356. if (time_from != time_id) {
  357. obj_chat_log.find("span.current").removeClass("current");
  358. obj_chat_log.find("span[time_id='" + time_from + "']").addClass("current");
  359. chat_log['time_from'] = time_from;
  360. }
  361. get_chat_msg(false);
  362. }
  363. function get_chat_next() {
  364. var now_page = chat_log['now_page'] - 1;
  365. if (now_page >= 1) {
  366. show_chat_msg(now_page);
  367. chat_log['now_page'] = now_page;
  368. } else {
  369. $('.chat_log_last').show();
  370. setTimeout("$('.chat_log_last').hide()", 2000);
  371. }
  372. }
  373. function get_chat_previous() {
  374. var now_page = chat_log['now_page'] + 1;
  375. if (chat_log['total_page'] >= now_page) {
  376. if (typeof chat_log['list'][now_page] === "undefined") {
  377. get_chat_msg(false);
  378. } else {
  379. show_chat_msg(now_page);
  380. chat_log['now_page'] = now_page;
  381. if (chat_log['total_page'] > now_page && typeof chat_log['list'][now_page + 1] === "undefined")
  382. get_chat_msg(true);
  383. }
  384. } else {
  385. $('.chat_log_first').show();
  386. setTimeout("$('.chat_log_first').hide()", 2000);
  387. }
  388. }
  389. function get_chat_msg(t) {
  390. var ajaxurl = HOMESITEURL + '/MemberInstantMessage/get_chat_log.html?f_id=' + user['u_id'] + '&t_id=' + chat_log['u_id'] + '&t=' + chat_log['time_from'];
  391. if (chat_log['now_page'] > 0)
  392. ajaxurl += '&page=' + (chat_log['now_page'] + 1);
  393. $.ajax({
  394. type: "GET",
  395. url: ajaxurl,
  396. dataType: "json",
  397. async: t,
  398. success: function (res) {
  399. if (res.code != 10000) {
  400. return false
  401. }
  402. var chat_msg = res.result
  403. var now_page = chat_log['now_page'] + 1;
  404. chat_log['list'][now_page] = chat_msg['instant_message_list'];
  405. if (t == false) {
  406. chat_log['now_page'] = now_page;
  407. show_chat_msg(now_page);
  408. }
  409. chat_log['total_page'] = chat_msg['total_page'];
  410. if (chat_log['total_page'] > 1 && chat_log['total_page'] > now_page && t == false) {
  411. get_chat_msg(true);
  412. }
  413. }
  414. });
  415. }
  416. function get_goods_list(s_id) {
  417. if (typeof store_goods[s_id] !== "undefined") {
  418. $("#chat_goods_list").html(store_goods[s_id]);
  419. $("#chat_goods_list").show();
  420. return;
  421. }
  422. var ajaxurl = HOMESITEURL + '/MemberInstantMessage/get_goods_list?s_id=' + s_id;
  423. $.ajax({
  424. type: "GET",
  425. url: ajaxurl,
  426. dataType: "json",
  427. async: true,
  428. success: function (res) {
  429. if (res.code != 10000) {
  430. return false
  431. }
  432. var list = res.result.goods_list
  433. var text_append = '<div class="title">店铺推荐</div><div class="content"><ul>';
  434. for (var k in list) {
  435. var goods = list[k];
  436. var text_goods = '<li>';
  437. text_goods += '<div class="goods-pic"><a href="' + goods['url'] + '" target="_blank">';
  438. text_goods += '<img title="' + goods['goods_name'] + '" alt="' + goods['goods_name'] + '" src="' + goods['pic'] + '"/></a></div>';
  439. text_goods += '<div class="goods-price">&yen;' + goods['goods_promotion_price'] + '</div>';
  440. text_goods += '</li>';
  441. text_append += text_goods;
  442. }
  443. text_append += '</ul></div>';
  444. store_goods[s_id] = text_append;
  445. get_goods_list(s_id);
  446. }
  447. });
  448. }
  449. function update_msg(u_id) {//更新已读
  450. var u_name = user_list[u_id]['u_name'];
  451. user_list[u_id]['new_msg'] = 0;
  452. alert_user_msg(u_id);
  453. new_msg--;
  454. alert_msg();
  455. }
  456. //店铺客服对话窗口
  457. function store_chat(u_id, c_name) {
  458. set_user_info(u_id, "c_name", c_name);//设置客服别名
  459. chat(u_id);
  460. }
  461. //打开对话窗口
  462. function chat(u_id) {
  463. if (user['u_id'] == '') {//未登录时弹出登录窗口
  464. login_dialog();
  465. return;
  466. }
  467. if (u_id == user['u_id'])
  468. return;
  469. if (1 || typeof user_list[u_id] === "undefined" || typeof user_list[u_id]['avatar'] === "undefined") {
  470. var ajaxurl = HOMESITEURL + '/MemberInstantMessage/get_info.html?t=member&u_id=' + u_id;
  471. $.ajax({
  472. type: "GET",
  473. url: ajaxurl,
  474. dataType: "json",
  475. async: false,
  476. success: function (res) {
  477. if (res.code != 10000) {
  478. return false
  479. }
  480. var member = res.result.user_info
  481. var u_name = member['member_name'];
  482. if (typeof u_name === "undefined" || u_name == '')
  483. return false;
  484. set_user_info(u_id, "u_name", u_name);
  485. set_user_info(u_id, "s_id", member['store_id']);
  486. set_user_info(u_id, "s_name", member['store_name']);
  487. set_user_info(u_id, "avatar", member['member_avatar']);
  488. set_user_info(u_id, "s_avatar", member['store_avatar']);
  489. }
  490. });
  491. }
  492. update_user(u_id);
  493. show_msg(u_id);
  494. show_obj();
  495. }
  496. //显示窗口
  497. function show_dialog() {
  498. update_dialog();
  499. show_obj();
  500. }
  501. //显示会员的对话
  502. function update_dialog() {
  503. if (new_msg < 1)
  504. return true;
  505. var select_user = 0;
  506. for (var u_id in user_list) {
  507. if (user_list[u_id]['new_msg'] > 0) {
  508. update_user(u_id);
  509. obj.find("em[unread_id='" + u_id + "']").addClass("unread");
  510. obj.find("em[unread_id='" + u_id + "']").html(user_list[u_id]['new_msg']);
  511. }
  512. }
  513. select_user = obj.find(".unread").first().attr("unread_id");
  514. if (select_user > 0)
  515. show_msg(select_user);
  516. }
  517. function show_chat_log() {
  518. if (user_show < 1) {
  519. $("#send_alert").html('未选择聊天会员');
  520. return false;
  521. }
  522. if (typeof chat_log['u_id'] === "undefined" || chat_log['u_id'] != user_show) {
  523. // $("#web_chat_dialog").hide();
  524. obj.find(".chat-log-btn").removeClass("off");
  525. obj.find(".chat-log-btn").addClass("on");
  526. get_chat_log(7);
  527. } else {
  528. close_chat_log(user_show);
  529. }
  530. }
  531. //显示会员的消息
  532. function show_msg(u_id) {
  533. var user_info = user_list[u_id];
  534. var u_name = user_info['u_name'];
  535. if (obj.find("div[select_user_msg='" + u_id + "']").size() == 0) {
  536. obj.find("#user_msg_list").prepend('<div class="msg_list" select_user_msg="' + u_id + '"></div>');
  537. }
  538. obj.find(".msg_list").hide();
  539. obj.find("div[select_user_msg='" + u_id + "']").show();
  540. obj.find("li[select_u_id]").removeClass("select_user");
  541. obj.find("li[select_u_id='" + u_id + "']").addClass("select_user");
  542. if (user_show != u_id) {
  543. close_chat_log(user_show);
  544. $("#chat_user_avatar").attr("src", user_info['avatar']);
  545. $("#chat_goods_list").hide();
  546. var add_html = '';
  547. var store_html = '';
  548. if (typeof user_info['c_name'] !== "undefined")
  549. add_html = '--' + user_info['c_name'];
  550. if (typeof user_info['s_name'] !== "undefined" && user_info['s_name'] !== "") {
  551. get_goods_list(user_info['s_id']);//异步调用店铺推荐的商品
  552. $("#chat_user_avatar").attr("src", user_info['s_avatar']);
  553. store_html = '<a target="_blank" href="' + HOMESITEURL + '/Store/index.html?store_id=' + user_info['s_id'] + '">' + user_info['s_name'] + '</a>';
  554. u_name = '客服:' + u_name;
  555. }
  556. var online_html = '<i class="offline" title="离线"></i>';
  557. if (user_info['online'] > 0) {
  558. online_html = '<i class="online" title="在线"></i>';
  559. }
  560. $("#chat_user_name").html(u_name + add_html + online_html);
  561. $("#chat_user_store").html(store_html);
  562. obj.find('#msg_list').perfectScrollbar('destroy');
  563. obj.find('#msg_list').perfectScrollbar();
  564. }
  565. user_show = u_id;
  566. var max_id = 0;
  567. for (var m_id in msg_list[u_id]) {
  568. if (obj.find("div[m_id='" + m_id + "']").size() == 0) {
  569. var msg = msg_list[u_id][m_id];
  570. show_f_msg(msg);
  571. update_msg(u_id);
  572. delete msg_list[u_id][m_id];//删除消息
  573. if (m_id > max_id)
  574. max_id = m_id;
  575. }
  576. }
  577. if(max_id){
  578. //将消息设置为已读
  579. $.getJSON(HOMESITEURL + '/MemberInstantMessage/set_message',{max_id:max_id,f_id:u_id})
  580. }
  581. var obj_msg = obj.find("div[select_user_msg='" + u_id + "']");
  582. obj.find("#msg_list").scrollTop(obj_msg.height());
  583. $("#send_message").focus();
  584. }
  585. //显示收到的消息
  586. function show_f_msg(msg) {
  587. var u_id = msg['instant_message_from_id'];
  588. var user_info = user_list[u_id];
  589. var text_append = '';
  590. var obj_msg = obj.find("div[select_user_msg='" + u_id + "']");
  591. text_append += '<div class="from_msg" m_id="' + msg['instant_message_id'] + '">';
  592. text_append += '<span class="user-avatar"><img src="' + user_info['avatar'] + '"></span>';
  593. text_append += '<dl><dt class="from-msg-time">';
  594. text_append += timetrans(msg['instant_message_add_time']) + '</dt>';
  595. text_append += '<dd class="from-msg-text">';
  596. text_append += update_chat_msg(msg) + '</dd>';
  597. text_append += '</dl>';
  598. text_append += '</div>';
  599. obj_msg.append(text_append);
  600. var n = obj_msg.find("div[m_id]").size();
  601. if (n >= msg_max && n % msg_max == 1) {
  602. obj_msg.append('<div clear_id="' + msg['instant_message_id'] + '" onclick="clear_msg(' + u_id + ',' + msg['instant_message_id'] +
  603. ');" class="clear_msg"><a href="Javascript: void(0);">清除已上历史消息</a></div>');
  604. }
  605. obj.find("#msg_list").scrollTop(obj_msg.height());
  606. }
  607. function show_t_msg(msg) {//显示发出的消息
  608. var user_info = user;
  609. var u_id = msg['instant_message_to_id'];
  610. var text_append = '';
  611. var obj_msg = obj.find("div[select_user_msg='" + u_id + "']");
  612. text_append += '<div class="to_msg" m_id="' + msg['instant_message_id'] + '">';
  613. text_append += '<span class="user-avatar"><img src="' + user_info['avatar'] + '"></span>';
  614. text_append += '<dl><dt class="to-msg-time">';
  615. text_append += timetrans(msg['instant_message_add_time']) + '</dt>';
  616. text_append += '<dd class="to-msg-text">';
  617. text_append += update_chat_msg(msg) + '</dd>';
  618. text_append += '</dl>';
  619. text_append += '</div>';
  620. obj_msg.append(text_append);
  621. var n = obj_msg.find("div[m_id]").size();
  622. if (n >= msg_max && n % msg_max == 1) {
  623. obj_msg.append('<div clear_id="' + msg['instant_message_id'] + '" onclick="clear_msg(' + u_id + ',' + msg['instant_message_id'] +
  624. ');" class="clear_msg"><a href="Javascript: void(0);">清除已上历史消息</a></div>');
  625. }
  626. obj.find("#msg_list").scrollTop(obj_msg.height());
  627. }
  628. function show_chat_msg(now_page) {
  629. var log_list = chat_log['list'][now_page];
  630. $('#chat_log_msg').html('');
  631. for (var k in log_list) {
  632. var class_html = '';
  633. var text_append = '';
  634. var msg = log_list[k];
  635. msg['u_name'] = msg['instant_message_from_name'];
  636. if (msg['instant_message_from_id'] == user['u_id']) {
  637. msg['u_name'] = '我';
  638. class_html = 'chat_user';
  639. }
  640. text_append += '<div class="chat_msg ' + class_html + '" m_id="' + msg['instant_message_id'] + '">';
  641. text_append += '<p class="user-log"><span class="user-name">' + msg['u_name'] + '</span>';
  642. text_append += '<span class="user-time">' + timetrans(msg['instant_message_add_time']) + '</span></p>';
  643. text_append += '<p class="user-msg">' + update_chat_msg(msg) + '</p>';
  644. text_append += '</div>';
  645. $('#chat_log_msg').prepend(text_append);
  646. }
  647. $('#chat_log_list').perfectScrollbar('destroy');
  648. $('#chat_log_list').perfectScrollbar();
  649. $('#chat_log_list').scrollTop($('#chat_log_msg').height());
  650. }
  651. function chat_show_user_list(chat_show) {
  652. var obj_chat = $("#chat_user_" + chat_show);
  653. if (obj_chat.find("dt span").attr("class") == 'hide') {
  654. obj_chat.find("dd[u_id]").show();
  655. obj_chat.find("dt span").attr("class", "show");
  656. } else {
  657. obj_chat.find("dd[u_id]").hide();
  658. obj_chat.find("dt span").attr("class", "hide");
  659. }
  660. }
  661. function chat_show_list() {
  662. if (user['u_id'] == '') {
  663. return;
  664. }
  665. var obj_chat = $(".chat-list");
  666. if (new_msg > 0 || obj_chat.css("display") == 'none') {
  667. obj_chat.show("slide", {direction: 'right'}, 300);
  668. } else {
  669. obj_chat.hide("slide", {direction: 'right'}, 300);
  670. }
  671. }
  672. function del_msg(msg) {//已读消息处理
  673. var max_id = msg['max_id'];//最大的消息编号
  674. var u_id = msg['f_id'];//消息发送人
  675. for (var m_id in msg_list[u_id]) {
  676. if (max_id >= m_id) {
  677. delete msg_list[u_id][m_id];
  678. if (user_list[u_id]['new_msg'] > 0)
  679. user_list[u_id]['new_msg']--;
  680. if (new_msg > 0)
  681. new_msg--;
  682. alert_user_msg(u_id);
  683. }
  684. }
  685. alert_msg();
  686. }
  687. function alert_user_msg(u_id) {
  688. if (user_list[u_id]['new_msg'] > 0) {
  689. obj.find("em[unread_id='" + u_id + "']").addClass("unread");
  690. obj.find("em[unread_id='" + u_id + "']").html(user_list[u_id]['new_msg']);
  691. $("#chat_user_recent dd[u_id='" + u_id + "'] a").addClass("msg");
  692. } else {
  693. obj.find("em[unread_id='" + u_id + "']").html("");
  694. obj.find("em[unread_id='" + u_id + "']").removeClass("unread");
  695. $("#chat_user_recent dd[u_id='" + u_id + "'] a").removeClass("msg");
  696. }
  697. }
  698. function alert_msg() {
  699. var new_n = 0;
  700. clearInterval(new_interval);
  701. if (new_msg > 0) {//消息提醒
  702. new_interval = setInterval(function () {
  703. new_n++;
  704. if (connect === 1)
  705. $(document).attr('title', '新消息(' + new_msg + ') ' + web_info['html_title']);
  706. if (new_n % 3 > 1)
  707. $(document).attr('title', web_info['html_title']);
  708. }, 500);
  709. $("#new_msg").show().html(new_msg);
  710. play_audio();
  711. } else {
  712. new_msg = 0;
  713. $("#new_msg").hide().html('');
  714. }
  715. $(document).attr('title', web_info['html_title']);
  716. }
  717. function get_chat(u_id, online) {//显示链接地址
  718. var add_html = '<a class="chat chat_online" title="在线联系" href="JavaScript:layer.msg(\'不能和自己聊天\')">在线</a>';
  719. if (u_id != user['u_id'] && u_id > 0) {
  720. var class_html = 'chat_offline';
  721. var text_html = '离线';
  722. if (online > 0) {
  723. class_html = 'chat_online';
  724. text_html = '在线';
  725. }
  726. add_html = '<a class="chat ' + class_html + '" title="在线联系" href="JavaScript:chat(' + u_id + ');">' + text_html + '</a>';
  727. }
  728. return add_html;
  729. }
  730. function clear_msg(u_id, m_id) {//清除消息处理
  731. var obj_msg = obj.find("div[select_user_msg='" + u_id + "']");
  732. obj_msg.find("div[clear_id='" + m_id + "']").prevAll().remove();
  733. obj_msg.find("div[clear_id='" + m_id + "']").remove();
  734. }
  735. function play_audio() {//提示声音
  736. if (chat_audio === 1) {
  737. var swf = document["msg_audio"];
  738. if (typeof swf.pplay === "function") {
  739. swf.load(CHAT_SITE_URL + '/msg.mp3');
  740. swf.pplay();
  741. }
  742. }
  743. }
  744. function set_user(u_id, u_name) {//初始化会员信息
  745. var user_info = new Array();
  746. user_info['u_id'] = u_id;
  747. user_info['u_name'] = u_name;
  748. user_info['new_msg'] = 0;
  749. user_info['online'] = 0;
  750. if (typeof user_list[u_id] === "undefined") {
  751. user_list[u_id] = user_info;
  752. }
  753. if (typeof msg_list[u_id] === "undefined") {
  754. msg_list[u_id] = new Array();
  755. }
  756. }
  757. function set_user_info(u_id, k, v) {//设置会员信息
  758. if (typeof user_list[u_id] === "undefined") {
  759. set_user(u_id, '');
  760. }
  761. user_list[u_id][k] = v;
  762. }
  763. function close_chat_log(u_id) {
  764. if (user_show == 0 || chat_log['u_id'] == u_id) {
  765. chat_log = {};
  766. $("#dialog_chat_log").hide();
  767. $('#chat_log_msg').html('');
  768. obj.find(".chat-log-btn").removeClass("on");
  769. obj.find(".chat-log-btn").addClass("off");
  770. if (connect === 1)
  771. $("#web_chat_dialog").show();
  772. }
  773. }
  774. function close_dialog(u_id) {
  775. obj.find("li[select_u_id='" + u_id + "']").remove();
  776. obj.find("div[select_user_msg='" + u_id + "']").hide();
  777. if (obj.find("li[select_u_id]").size() == 0) {
  778. msg_dialog_close('new_msg_dialog');
  779. } else {
  780. if (user_show == u_id)
  781. obj.find("li[select_u_id]").first().trigger("click");
  782. }
  783. if (user_show == u_id) {
  784. user_show = 0;
  785. close_chat_log(u_id);
  786. }
  787. if (obj.find("li[select_u_id]").size() < 2) {
  788. obj.find(".user-tab-bar").hide();
  789. $("#new_msg_dialog").css('width', '742px')
  790. }
  791. }
  792. function update_chat_msg(res) {
  793. if (res['instant_message_type'] == 1) {
  794. var chat_goods = res['instant_message']
  795. var msg = '<div class="dstouch-chat-product"> <a href="' + HOMESITEURL + '/goods/index?goods_id=' + chat_goods.goods_id + '" target="_blank"><div class="goods-pic"><img src="' + chat_goods.goods_image_url + '" alt=""/></div><div class="goods-info"><div class="goods-name">' + chat_goods.goods_name + '</div><div class="goods-price">¥' + chat_goods.goods_price + "</div></div></a> </div>";
  796. } else {
  797. var msg=res['instant_message']
  798. if (typeof smilies_array !== "undefined") {
  799. msg = '' + msg;
  800. for (var i in smilies_array[1]) {
  801. var s = smilies_array[1][i];
  802. var re = new RegExp("" + s[1], "g");
  803. var smilieimg = '<img width="28" height="28" title="' + s[6] + '" alt="' + s[6] + '" src="' + BASESITEROOT + '/static/plugins/js/smilies/images/' + s[2] + '">';
  804. msg = msg.replace(re, smilieimg);
  805. }
  806. }
  807. }
  808. return msg;
  809. }
  810. function update_friends(u_list) {
  811. var obj_friend = $("#chat_friends");
  812. for (var u_id in friend_list) {
  813. set_user_info(u_id, "online", u_list[u_id]);
  814. if (obj_friend.parent().find("dd[u_id='" + u_id + "']").size() == 0) {
  815. if (user_list[u_id]['online'] > 0) {
  816. obj_friend.before('<dd u_id="' + u_id + '" onclick="chat(' + u_id + ');"><span class="user-avatar avatar-1"><img alt="' + user_list[u_id]['u_name']
  817. + '" src="' + user_list[u_id]['avatar'] + '?' + Math.floor(Math.random() * 100) + '"><i class="online"></i></span><h5>' + user_list[u_id]['u_name'] + '</h5><a class="iconfont" href="javascript:void(0)">&#xe71b;</a></dd>');
  818. } else {
  819. obj_friend.after('<dd u_id="' + u_id + '" onclick="chat(' + u_id + ');"><span class="user-avatar avatar-0"><img alt="' + user_list[u_id]['u_name']
  820. + '" src="' + user_list[u_id]['avatar'] + '?' + Math.floor(Math.random() * 100) + '"><i class="offline"></i></span><h5>' + user_list[u_id]['u_name'] + '</h5><a class="iconfont" href="javascript:void(0)">&#xe71b;</a></dd>');
  821. }
  822. }
  823. }
  824. obj_friend.remove();
  825. chat_show_user_list('friends');
  826. }
  827. function update_recent(u_list) {
  828. var obj_recent = $("#chat_recent");
  829. for (var u_id in recent_list) {
  830. set_user_info(u_id, "online", u_list[u_id]);
  831. if (obj_recent.parent().find("dd[u_id='" + u_id + "']").size() == 0) {
  832. if (user_list[u_id]['online'] > 0) {
  833. obj_recent.before('<dd u_id="' + u_id + '" title="最后对话:' + recent_list[u_id]['time'] + '" onclick="chat(' + u_id + ');"><span class="user-avatar avatar-1"><img alt="' + user_list[u_id]['u_name']
  834. + '" src="' + user_list[u_id]['avatar'] + '?' + Math.floor(Math.random() * 100) + '"><i class="online"></i></span><h5>' + user_list[u_id]['u_name'] + '</h5><a class="iconfont" href="javascript:void(0)">&#xe71b;</a></dd>');
  835. } else {
  836. obj_recent.after('<dd u_id="' + u_id + '" title="最后对话:' + recent_list[u_id]['time'] + '" onclick="chat(' + u_id + ');"><span class="user-avatar avatar-0"><img alt="' + user_list[u_id]['u_name']
  837. + '" src="' + user_list[u_id]['avatar'] + '?' + Math.floor(Math.random() * 100) + '"><i class="offline"></i></span><h5>' + user_list[u_id]['u_name'] + '</h5><a class="iconfont" href="javascript:void(0)">&#xe71b;</a></dd>');
  838. }
  839. }
  840. }
  841. obj_recent.remove();
  842. }
  843. function update_user(u_id) {
  844. if ($("#dialog_chat_right").html() == '') {
  845. var text_append = '<span class="dialog-close iconfont" onclick="msg_dialog_close(\'new_msg_dialog\');">&#xe6e6;&nbsp;</span>';
  846. text_append += '<div class="user-info">';
  847. text_append += '<div class="user-avatar">';
  848. text_append += '<img id="chat_user_avatar" src=""></div>';
  849. text_append += '<div id="chat_user_store" class="store-name"></div>';
  850. text_append += '<div id="chat_user_name" class="user-name"></div>';
  851. text_append += '</div>';
  852. text_append += '<div id="chat_goods_list" class="goods-list"></div>';
  853. $("#dialog_chat_right").append(text_append + web_info['chat_goods_html']);
  854. }
  855. if (obj.find("li[select_u_id='" + u_id + "']").size() == 0) {
  856. var user_info = user_list[u_id];
  857. var u_name = user_info['u_name'];
  858. var text_append = '';
  859. var class_html = 'offline';
  860. if (user_info['online'] > 0)
  861. class_html = 'online';
  862. text_append += '<li class="user" select_u_id="' + u_id + '" onclick="show_msg(' + u_id + ');">';
  863. text_append += '<i class="' + class_html + '"></i>';
  864. text_append += '<span class="user-avatar avatar-' + user_info['online'] + '" title="' + u_name + '"><img alt="' + u_name + '" src="' + user_info['avatar'] + '"></span>';
  865. text_append += '<span class="user-name" title="' + u_name + '">';
  866. text_append += u_name + '<em></em></span>';
  867. text_append += '<em unread_id="' + u_id + '" class=""></em>';
  868. text_append += '<a class="ac-ico iconfont">&#xe64b;</a>';
  869. text_append += '</li>';
  870. obj.find("#user_list").append(text_append);
  871. obj.find("#user_list").sortable({items: 'li'});
  872. obj.find("li[select_u_id='" + u_id + "'] .ac-ico").bind("click", function () {
  873. close_dialog(u_id);
  874. return false;
  875. });
  876. if (obj.find("li[select_u_id]").size() > 1) {
  877. obj.find(".user-tab-bar").show();
  878. $("#new_msg_dialog").css('width', '942px')
  879. }
  880. }
  881. obj.find(".user-tab-bar").perfectScrollbar();
  882. }
  883. var ws
  884. var lockReconnect = false
  885. var timeOut = false
  886. function getconnect() {
  887. try {
  888. ws = new WebSocket(connect_url)
  889. init()
  890. } catch (e) {
  891. reconnect()
  892. }
  893. }
  894. function init() {
  895. ws.onopen = wsOpen
  896. ws.onmessage = wsMessage
  897. ws.onclose = wsClose
  898. ws.onerror = wsError
  899. }
  900. function reconnect() {
  901. if (lockReconnect) {
  902. return
  903. }
  904. lockReconnect = true
  905. // 没连接上会一直重连,设置延迟避免请求过多
  906. timeOut && clearTimeout(timeOut)
  907. timeOut = setTimeout(function () {
  908. getconnect()
  909. lockReconnect = false
  910. }, 4000)
  911. }
  912. function wsOpen() {
  913. connect = 1
  914. send_state();
  915. if (user['u_id'] == '')
  916. return false;//未登录时不取消息
  917. $("#web_chat_dialog").show();
  918. if ($("#new_msg_dialog").size() == 0)
  919. {
  920. $("#web_chat_dialog").after(web_info['msg_dialog']);
  921. $("#new_msg_dialog").draggable({containment: "body"});
  922. }
  923. obj = $("#new_msg_dialog");
  924. // 心跳检测重置
  925. heartCheck.start()
  926. }
  927. function wsMessage(res) {
  928. var message = JSON.parse(res.data)
  929. if (!message) {
  930. console.log(res)
  931. return
  932. }
  933. var type = message.type || ''
  934. switch (type) {
  935. // Events.php中返回的init类型的消息,将client_id发给后台进行uid绑定
  936. case 'init':
  937. var clientId = message.client_id
  938. //获取未读消息
  939. $.getJSON(HOMESITEURL + '/MemberInstantMessage/join',{client_id:clientId})
  940. break
  941. case 'leave':
  942. break
  943. case 'get_state'://用户状态
  944. get_state(message)
  945. break
  946. case 'get_msg'://未读消息
  947. get_msg(message.msg_list)
  948. break
  949. default:
  950. get_msg([message])
  951. }
  952. heartCheck.start()
  953. }
  954. function wsClose(res) {
  955. connect = 0
  956. console.log(res)
  957. $("#web_chat_dialog").hide();
  958. reconnect()
  959. }
  960. function wsError(res) {
  961. console.log(res)
  962. reconnect()
  963. }
  964. // 心跳检测
  965. var heartCheck = {
  966. timeout: 3000,
  967. timeoutObj: null,
  968. start: function () {
  969. var self = this
  970. this.timeoutObj && clearTimeout(this.timeoutObj)
  971. this.timeoutObj = setInterval(function () {
  972. // 这里发送一个心跳,后端收到后,返回一个心跳消息,
  973. ws.send('123456789')
  974. }, this.timeout)
  975. }
  976. }
  977. function timetrans(date) {
  978. var date = new Date(date * 1000);//如果date为13位不需要乘1000
  979. var Y = date.getFullYear() + '-';
  980. var M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';
  981. var D = (date.getDate() < 10 ? '0' + (date.getDate()) : date.getDate()) + ' ';
  982. var h = (date.getHours() < 10 ? '0' + date.getHours() : date.getHours()) + ':';
  983. var m = (date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes()) + ':';
  984. var s = (date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds());
  985. return Y + M + D + h + m + s;
  986. }