diff options
Diffstat (limited to 'webchat/public/client.js')
| -rw-r--r-- | webchat/public/client.js | 22 | 
1 files changed, 9 insertions, 13 deletions
| 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 = $('<div/>').text(params.msg).html();    safe_message = replaceURLWithHTMLLinks(safe_message);    var safe_from = $('<div/>').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 = $('<div/>').text(params.oldnick).html();    var safe_newnick = $('<div/>').text(params.newnick).html();    var safe_type = $('<div/>').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 = $('<div/>').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 = $('<div/>').text(params.nick).html();    var safe_type = $('<div/>').text(params.type).html();    $('#nicklist').append('<div class="'+safe_type+'_name">' + safe_nick + '</div>') ;    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 = $('<div/>').text(params.nick).html();    var safe_type = $('<div/>').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)      }    }); | 
