PeerJS is a service which makes it easier to build a chat room using the upcoming present WebRTC's PeerConnection API. The PeerConnection API proposes to be able to send data, video etc from one user-agent to another without the need for it going through a server. PeerJS handles this handshake with a simple Socket.IO backend server.
The above demo takes just a few steps to implement. Firstly embed the Peer.JS script
<script class="pre" src="https://peer-server.herokuapp.com/peer.min.js"></script>
Next, create a unique id with Math.random() for the chat room, you could hard code this if you like, but anyway, i'm generating it like so...
window.location.hash = (window.location.hash || parseInt(Math.random()*1e4,10).toString(16));
connect with video. Call the library Peer and invoke a new session. Append the video tag (defined by the id 'myvideo'). Connect to the "room" we spoke about earlier. Then listen for new media streams from other people in the same chat room.
var session = Peer.initSession().addMedia('myvideo').connect(window.location.hash).on('media', function(e){
document.querySelector('div.demo').appendChild(e.video);
});
send data Send data to the room. createDataChannel has been proposed but is not implemented. The relay server works pretty well though
<script class="pre">
var form = document.querySelector('form.msg');
session.on('message', function(event){
form.textarea.value = event.data+"\n"+form.textarea.value;
});
form.addEventListener('submit', function(e){
e.preventDefault();
form.textarea.value = "me:" + this.input.value+"\n"+form.textarea.value;
session.send('message', {data:this.input.value});
this.input.value = '';
});
</script>
Lastly, because chatting to yourself can bring about men in white coats, i've added a link to share the page with friends (to test you can just open in a new tab).
<script class="pre">
var link = document.getElementById('chat-room-link');
link.innerHTML = window.location.href;
link.href = window.location.href;
</script>
[Optionally]. If the user-agent doesn't support WebRTC then lets so something
<script class="pre">
if(!Peer.supported){
document.querySelector('.demo').innerHTML = "This demo is not supported in your browser, for more information see http://www.webrtc.org/running-the-demos";
}
</script>