App-SocialCalc-Multiplayer

 view release on metacpan or  search on metacpan

socialcalc/player.js  view on Meta::CPAN

(function(){
    var socket;
    var cookieName = 'socialcalc';
    var _username = Math.random().toString();
    var _hadSnapshot = false;
    var isConnected = false;
    var mq = [];

    SocialCalc.Callbacks.broadcast = function(type, data) {
        if (!isConnected) return;
        data = data || {};
        data.user = _username;
        data.type = type;
        socket.send(data);
    }

    socket = new io.Socket(null, {});
    socket.connect();
    socket.on('connect', function () {
        isConnected = true;
        SocialCalc.Callbacks.broadcast('ask.snapshot');
        /* Wait for 30 secs for someone to send over the current snapshot before timing out. */
        setTimeout(function(){ _hadSnapshot = true }, 30000);
    });
    socket.on('message', function (obj) {
        onNewEvent(obj);
    });

    var onNewEvent = function(data) {
        if (!isConnected) return;
        if (data.user == _username) return;
        if (data.to && data.to != _username) return;
        if (typeof SocialCalc == 'undefined') return;

        var editor = SocialCalc.CurrentSpreadsheetControlObject.editor;

        switch (data.type) {
            case 'ecell': {
                var peerClass = ' ' + data.user + ' defaultPeer';
                var find = new RegExp(peerClass, 'g');

                if (data.original) {
                    var origCR = SocialCalc.coordToCr(data.original);
                    var origCell = SocialCalc.GetEditorCellElement(editor, origCR.row, origCR.col);
                    origCell.element.className = origCell.element.className.replace(find, '');
                }

                var cr = SocialCalc.coordToCr(data.ecell);
                var cell = SocialCalc.GetEditorCellElement(editor, cr.row, cr.col);
                if (cell.element.className.search(find) == -1) {
                    cell.element.className += peerClass;
                }
                break;
            }
            case 'ask.snapshot': {
                SocialCalc.Callbacks.broadcast('snapshot', {
                    to: data.user,
                    snapshot: SocialCalc.CurrentSpreadsheetControlObject.CreateSpreadsheetSave()
                });
                // FALL THROUGH
            }
            case 'ask.ecell': {
                SocialCalc.Callbacks.broadcast('ecell', {
                    to: data.user,
                    ecell: editor.ecell.coord
                });
                break;
            }
            case 'snapshot': {
                if (_hadSnapshot) break;
                _hadSnapshot = true;
                var spreadsheet = SocialCalc.CurrentSpreadsheetControlObject;
                var parts = spreadsheet.DecodeSpreadsheetSave(data.snapshot);
                if (parts) {
                    if (parts.sheet) {
                        spreadsheet.sheet.ResetSheet();
                        spreadsheet.ParseSheetSave(data.snapshot.substring(parts.sheet.start, parts.sheet.end));
                    }
                    if (parts.edit) {
                        spreadsheet.editor.LoadEditorSettings(data.snapshot.substring(parts.edit.start, parts.edit.end));
                    }
                }
                if (spreadsheet.editor.context.sheetobj.attribs.recalc=="off") {



( run in 0.878 second using v1.01-cache-2.11-cpan-39bf76dae61 )