annotate www/8/js/chat.js @ 101:52e44ee1c791 tip master

enabled all scores in autostart script
author Rob Canning <rc@kiben.net>
date Tue, 21 Apr 2015 16:20:57 +0100
parents 9bf133b91890
children
rev   line source
rc-web@63 1 var socket = io.connect();
rc-web@63 2
rc-web@63 3 socket.on('connect', function () {
rc-web@63 4 $('#chat').addClass('connected');
rc-web@63 5 });
rc-web@63 6
rc-web@63 7 socket.on('announcement', function (msg) {
rc-web@63 8 $('#lines').append($('<p>').append($('<em>').text(msg)));
rc-web@63 9 });
rc-web@63 10
rc-web@63 11 socket.on('nicknames', function (nicknames) {
rc-web@63 12 $('#nicknames').empty().append($('<span>Online: </span>'));
rc-web@63 13 for (var i in nicknames) {
rc-web@63 14 $('#nicknames').append($('<b>').text(nicknames[i]));
rc-web@63 15 }
rc-web@63 16 });
rc-web@63 17
rc-web@63 18 socket.on('user message', message);
rc-web@63 19 socket.on('reconnect', function () {
rc-web@63 20 $('#lines').remove();
rc-web@63 21 message('System', 'Reconnected to the server');
rc-web@63 22 });
rc-web@63 23
rc-web@63 24 socket.on('reconnecting', function () {
rc-web@63 25 message('System', 'Attempting to re-connect to the server');
rc-web@63 26 });
rc-web@63 27
rc-web@63 28 socket.on('error', function (e) {
rc-web@63 29 message('System', e ? e : 'A unknown error occurred');
rc-web@63 30 });
rc-web@63 31
rc-web@63 32 function message (from, msg) {
rc-web@63 33 $('#lines').append($('<p>').append($('<b>').text(from), msg));
rc-web@63 34 }
rc-web@63 35
rc-web@63 36 // dom manipulation
rc-web@63 37 $(function () {
rc-web@63 38 $('#set-nickname').submit(function (ev) {
rc-web@63 39 socket.emit('nickname', $('#nick').val(), function (set) {
rc-web@63 40 if (!set) {
rc-web@63 41 clear();
rc-web@63 42 return $('#chat').addClass('nickname-set');
rc-web@63 43 }
rc-web@63 44 $('#nickname-err').css('visibility', 'visible');
rc-web@63 45 });
rc-web@63 46 return false;
rc-web@63 47 });
rc-web@63 48
rc-web@63 49 $('#send-message').submit(function () {
rc-web@63 50 message('me', $('#message').val());
rc-web@63 51 socket.emit('user message', $('#message').val());
rc-web@63 52 clear();
rc-web@63 53 $('#lines').get(0).scrollTop = 10000000;
rc-web@63 54 return false;
rc-web@63 55 });
rc-web@63 56
rc-web@63 57 function clear () {
rc-web@63 58 $('#message').val('').focus();
rc-web@63 59 };
rc-web@63 60 });