From b749c216ae84f02330da7396135be11259ec12d9 Mon Sep 17 00:00:00 2001 From: lassulus Date: Tue, 12 Nov 2013 04:08:38 +0100 Subject: webchat: fix nicklist --- webchat/public/client.js | 22 +++++++++------------- webchat/public/functions.js | 8 ++++++++ 2 files changed, 17 insertions(+), 13 deletions(-) (limited to 'webchat/public') diff --git a/webchat/public/client.js b/webchat/public/client.js index d7a5ecab..54ccfe34 100644 --- a/webchat/public/client.js +++ b/webchat/public/client.js @@ -3,16 +3,16 @@ settings.sock = new SockJS('/echo'); settings.waiting_callbacks = {} var transport = make_sockjs_client_transport(settings.sock) -var rpc = new RPC(transport) +settings.rpc = new RPC(transport) -rpc.register('msg', {type: 'string', nick: 'string', msg: 'string'}, function(params, callback) { +settings.rpc.register('msg', {type: 'string', nick: 'string', msg: 'string'}, function(params, callback) { var safe_message = $('
').text(params.msg).html(); safe_message = replaceURLWithHTMLLinks(safe_message); var safe_from = $('
').text(params.nick).html(); chatboxAppend(safe_from, safe_message, 'web_msg') return callback(null) }) -rpc.register('nick', {type: 'string', newnick: 'string', oldnick: 'string'}, function(params, callback) { +settings.rpc.register('nick', {type: 'string', newnick: 'string', oldnick: 'string'}, function(params, callback) { var safe_oldnick = $('
').text(params.oldnick).html(); var safe_newnick = $('
').text(params.newnick).html(); var safe_type = $('
').text(params.type).html(); @@ -25,20 +25,20 @@ rpc.register('nick', {type: 'string', newnick: 'string', oldnick: 'string'}, fun chatboxAppend(safe_oldnick, 'is now known as ' + safe_newnick, 'nick'); return callback(null) }) -rpc.register('your_nick', {nick: 'string'}, function(params, callback) { +settings.rpc.register('your_nick', {nick: 'string'}, function(params, callback) { var safe_nick = $('
').text(params.nick).html(); settings.nick = safe_nick $('#nick').html(settings.nick) return callback(null) }) -rpc.register('join', {type: 'string', nick: 'string'}, function(params, callback) { +settings.rpc.register('join', {type: 'string', nick: 'string'}, function(params, callback) { var safe_nick = $('
').text(params.nick).html(); var safe_type = $('
').text(params.type).html(); $('#nicklist').append('
' + safe_nick + '
') ; chatboxAppend(safe_nick, 'has joined'); return callback(null) }) -rpc.register('part', {type: 'string', nick: 'string'}, function(params, callback) { +settings.rpc.register('part', {type: 'string', nick: 'string'}, function(params, callback) { var safe_nick = $('
').text(params.nick).html(); var safe_type = $('
').text(params.type).html(); $(getNicklistElement(safe_nick,safe_type)).remove(); @@ -60,14 +60,10 @@ $(function() { e.stopPropagation(); e.stopImmediatePropagation(); var input = ($('#input').val()); - $('#input').val(''); + $('#input').val('') - var match = /^\/([a-z]+)(?:\s+(.*\S))?\s*$/.exec(input) - if (match) { - return rpc.send(match[1], match[2]) - } else { - return rpc.send('msg', input) - } + var command = inputParser(input) + return (commands[command.method] || commands.badcommand)(settings, command.params) } }); diff --git a/webchat/public/functions.js b/webchat/public/functions.js index 318d0865..781fafce 100644 --- a/webchat/public/functions.js +++ b/webchat/public/functions.js @@ -1,3 +1,11 @@ +function inputParser (str) { + var match = /^\/([a-z]+)(?:\s+(.*\S))?\s*$/.exec(str) + if (match) { + return { method: match[1], params: match[2] } + } else { + return { method: 'msg', params: str } + } +} function replaceURLWithHTMLLinks (text) { var exp = /(\b(https?|ftp|file):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/ig; -- cgit v1.2.3