var BOSH_SERVICE = 'http://alias.fr.nf/http-bind'; var connection = null; function log(msg, color) { $('#log').append($('
').css('background-color', color).text(msg)); } function rawInput(data) { log('RECV: ' + data, '#FBB6B4'); } function rawOutput(data) { log('SENT: ' + data, '#B5BBFB'); } function getRoster() { var roster = $iq({type : 'get'}).c('query', {xmlns : Strophe.NS.ROSTER}); connection.sendIQ(roster, onRoster); } function getPresence(contact) { if ( contact.hasClass("online") ) return 2; else if ( contact.hasClass("away") ) return 1; else return 0; } function jid_to_id(jid) { return Strophe.getBareJidFromJid(jid).replace("@", "-").replace(".", "-"); } function getJID(contact) { return contact.find('.roster-jid').text(); } function insertContact(contact) { var presence = getPresence(contact); var jid = getJID(contact); var contacts = $('#roster li'); if (contacts.length > 0) { var inserted = false; contacts.each(function () { var locpres = getPresence($(this)); var locjid = getJID($(this)); if (presence > locpres) { $(this).before(contact); inserted = true; return false; } else { if (jid < locjid) { $(this).before(contact); inserted = true; return false; } } }); if (!inserted) $('#roster ul').append(contact); } else $('#roster ul').append(contact); } function onRoster(iq) { var elems = iq.getElementsByTagName('query'); var query = elems[0]; Strophe.forEachChild(query, 'item', function(item) { var jid = item.getAttribute('jid'); var name = item.getAttribute('name') || jid; var id = jid_to_id(jid); var contact = $("
  • " + "
    " + name + "
    " + "
    " + jid + "
  • "); insertContact(contact); }); return true; } function onConnect(status) { var jid = $('#jid').get(0).value; if ( status == Strophe.Status.CONNECTING ) { log('Strophe is connecting.'); } else if ( status == Strophe.Status.CONNFAIL ) { log('Strophe failed to connect.'); $('#connect').get(0).value = 'connect'; } else if ( status == Strophe.Status.DISCONNECTING ) { log('Strophe is disconnecting.'); } else if ( status == Strophe.Status.DISCONNECTED ) { log('Strophe is disconnected.'); $('#connect').get(0).value = 'connect'; } else if ( status == Strophe.Status.CONNECTED ) { log('Strophe is connected.'); getRoster(); connection.send($pres().tree()); } } $(document).ready(function(){ connection = new Strophe.Connection(BOSH_SERVICE); connection.rawInput = rawInput; connection.rawOutput = rawOutput; $('#connect').bind('click', function(){ var button = $('#connect').get(0); if ( button.value == 'connect' ) { button.value = 'disconnect'; connection.connect($('#jid').get(0).value, $('#pass').get(0).value, onConnect); } else { button.value = 'connect'; connection.disconnect(); } }); $('#bottomup').click(function(){ $(this).next().slideToggle(); }); });