Historia:
Continuando con el proyecto de chat privado con nodeJs ahora veremos como hacer los métodos del lado del servidor.
Desde este lado nos encargaremos de hacer que los clientes se conecten entre si poniendo un intermediario a la conversación.
En este caso los archivos a modificar son, index.html, app.js y control.js, agregando las siguientes lineas.
Código:
index.html
<!-- pantalla login --> <div class="login" id="login"> <input type="text" id="user" placeholder="UserName"> <button id="btnLogin">Aceptar</button> </div>
<!-- plantilla de usuarios --> <div class="contentUser" id="cntUsersActivos" hidden> <div class="title-users" id="ttlUsersActivos">Usuarios Activos</div> <ul id="usersActivos"></ul> </div>
Este fragmento se va directo al body del index, dando pie a un input el cual contendra el usuario y un boton que mandara la petición al app.js para asignar un nombre al socket que se acaba de conectar. La acción la agregamos al.
control.js
var btnLogin = document.getElementById('btnLogin'); btnLogin.onclick=function(){ var usr = document.getElementById('user'); if((usr.value.trim()).length>0){ socket.emit('connectUser',usr.value); window.datos={ user:usr.value, clave: socket.id }; window.document.title = usr.value; } }
Obtenemos el elemento btnLogin y le asignamos la función click, mediante la cual le decimos que obtenga del input su valor y lo mande a la función ('conectUser') que se encuentra en app.js ademas de crear una variable global en window llamada [" datos "] con los parametros user y clave, por ultimo se cambia el titulo de la ventana dandole el nombre del usuario que se a conectado.
Ademas de agregar el evento click al botón, hay que agregar la función de la recepción de usuarios del lado del cliente, es decir, la parte que agrega usuarios a nuestra lista.
control.js
var lg = document.getElementById('login'); socket.on('isLogin',function(value){ if(typeof window.datos != 'undefined'){ lg.setAttribute('hidden',''); var userActivos = document.getElementById('usersActivos'); userActivos.parentNode.removeAttribute('hidden'); userActivos.innerHTML = ""; for(var i = 0; i<value.length; i ++ ){ if(value[i].clave!=window.datos.clave){ var liUser = document.createElement('LI'); var divUser = document.createElement('DIV'); divUser.textContent=value[i].user; divUser.setAttribute('clave',value[i].clave); liUser.setAttribute('clave',value[i].clave); liUser.appendChild(divUser); userActivos.appendChild(liUser); } } } });
socket.on( 'isLogin') se encarga de escuchar del lado del cliente, las emisiones del servidor, app.js, en este caso leemos cada uno de los usuarios agregandolos o eliminandolos de nuestra lista.
Ahora bien, del lado del app es necesario explicar lo siguiente. crearemos un arreglo llamado users en el cual se agrega el usuario que se acaba de conectar, modificando la funcion de disconnect, preguntamos por el id que se esta desconectando, para asi eliminar el usuario correspondiente del lado del cliente.
app.js
var users = []; io.on('connection',function(socket){ socket.on('disconnect',function(){ var keys = Object.keys(users); var existe = false; for( var i = 0;i < keys.length; i ++ ){ if( users[keys[i]] == socket.id ){ delete users[keys[i]]; existe = true; } } if(existe){ var nKeys = Object.keys(users); var arrRtn = []; for( var i = 0;i < nKeys.length; i ++ ){ arrRtn.push({'user':nKeys[i], 'clave': users[nKeys[i]]}); } io.emit('isLogin',arrRtn); } }); socket.on('connectUser',function(user){ var existe = false; var keys = Object.keys(users); var arrRtn=[]; for( var i = 0;i < keys.length; i ++ ){ arrRtn.push({'user':keys[i], 'clave': users[keys[i]]}); if( users[keys[i]] == socket.id ){ existe = true; } } if(!existe){ users[user]=socket.id; arrRtn.push({'user':user, 'clave': socket.id}); } io.emit('isLogin',arrRtn); }); });
Agregamos la función connectUser pasando como parámetro al usuario recién conectado, primero preguntamos si el usuario nuevo existe, de ser así no se hace nada, de lo contrario si no existe se agrega al arreglo y finalmente se envía al cliente en el arreglo de usuarios.
Por ahora es todo, espero sus comentarios.
Unete a mi blog, para asi poder estar al tanto de la siguiente entrada.
No hay comentarios:
Publicar un comentario