layui.use(['jquery', 'form', 'helper'], function () { var $ = layui.jquery; var form = layui.form; var helper = layui.helper; var socket = new WebSocket(window.koogua.socketUrl); var bindUserUrl = $('input[name="bind_user_url"]').val(); var $chatContent = $('input[name=content]'); var $chatMsgList = $('#chat-msg-list'); socket.onopen = function () { console.log('socket connect success'); }; socket.onclose = function () { console.log('socket connect close'); }; socket.onerror = function () { console.log('socket connect error'); }; socket.onmessage = function (e) { var data = JSON.parse(e.data); console.log(data); if (data.type === 'ping') { socket.send('pong...'); } else if (data.type === 'bind_user') { bindUser(data.client_id); } else if (data.type === 'new_message') { showNewMessage(data); } else if (data.type === 'new_user') { showLoginMessage(data); } }; form.on('submit(chat)', function (data) { $.ajax({ type: 'POST', url: data.form.action, data: data.field, success: function (res) { showNewMessage(res); $chatContent.val(''); } }); return false; }); loadRecentChats(); refreshLiveStats(); setInterval(function () { refreshLiveStats(); }, 300000); function bindUser(clientId) { $.ajax({ type: 'POST', url: bindUserUrl, data: {client_id: clientId} }); } function showNewMessage(res) { var html = '