parent
b16bc6fc2e
commit
c1a7e83d75
|
@ -8,6 +8,6 @@
|
||||||
if (data.socketId !== socketId) { return; }
|
if (data.socketId !== socketId) { return; }
|
||||||
if( window.location.host === 'localhost:1947' ) return;
|
if( window.location.host === 'localhost:1947' ) return;
|
||||||
|
|
||||||
Reveal.slide(data.indexh, data.indexv, data.indexf, 'remote');
|
Reveal.setState(data.state);
|
||||||
});
|
});
|
||||||
}());
|
}());
|
||||||
|
|
|
@ -1,32 +1,32 @@
|
||||||
|
var http = require('http');
|
||||||
var express = require('express');
|
var express = require('express');
|
||||||
var fs = require('fs');
|
var fs = require('fs');
|
||||||
var io = require('socket.io');
|
var io = require('socket.io');
|
||||||
var crypto = require('crypto');
|
var crypto = require('crypto');
|
||||||
|
|
||||||
var app = express.createServer();
|
var app = express();
|
||||||
var staticDir = express.static;
|
var staticDir = express.static;
|
||||||
|
var server = http.createServer(app);
|
||||||
|
|
||||||
io = io.listen(app);
|
io = io(server);
|
||||||
|
|
||||||
var opts = {
|
var opts = {
|
||||||
port: process.env.PORT || 1948,
|
port: process.env.PORT || 1948,
|
||||||
baseDir : __dirname + '/../../'
|
baseDir : __dirname + '/../../'
|
||||||
};
|
};
|
||||||
|
|
||||||
io.sockets.on('connection', function(socket) {
|
io.on( 'connection', function( socket ) {
|
||||||
socket.on('slidechanged', function(slideData) {
|
socket.on('multiplex-statechanged', function(data) {
|
||||||
if (typeof slideData.secret == 'undefined' || slideData.secret == null || slideData.secret === '') return;
|
if (typeof data.secret == 'undefined' || data.secret == null || data.secret === '') return;
|
||||||
if (createHash(slideData.secret) === slideData.socketId) {
|
if (createHash(data.secret) === data.socketId) {
|
||||||
slideData.secret = null;
|
data.secret = null;
|
||||||
socket.broadcast.emit(slideData.socketId, slideData);
|
socket.broadcast.emit(data.socketId, data);
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
app.configure(function() {
|
[ 'css', 'js', 'plugin', 'lib' ].forEach(function(dir) {
|
||||||
[ 'css', 'js', 'plugin', 'lib' ].forEach(function(dir) {
|
app.use('/' + dir, staticDir(opts.baseDir + dir));
|
||||||
app.use('/' + dir, staticDir(opts.baseDir + dir));
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
app.get("/", function(req, res) {
|
app.get("/", function(req, res) {
|
||||||
|
@ -47,7 +47,7 @@ var createHash = function(secret) {
|
||||||
};
|
};
|
||||||
|
|
||||||
// Actually listen
|
// Actually listen
|
||||||
app.listen(opts.port || null);
|
server.listen( opts.port || null );
|
||||||
|
|
||||||
var brown = '\033[33m',
|
var brown = '\033[33m',
|
||||||
green = '\033[32m',
|
green = '\033[32m',
|
||||||
|
|
|
@ -1,51 +1,31 @@
|
||||||
(function() {
|
(function() {
|
||||||
|
|
||||||
// Don't emit events from inside of notes windows
|
// Don't emit events from inside of notes windows
|
||||||
if ( window.location.search.match( /receiver/gi ) ) { return; }
|
if ( window.location.search.match( /receiver/gi ) ) { return; }
|
||||||
|
|
||||||
var multiplex = Reveal.getConfig().multiplex;
|
var multiplex = Reveal.getConfig().multiplex;
|
||||||
|
|
||||||
var socket = io.connect(multiplex.url);
|
var socket = io.connect( multiplex.url );
|
||||||
|
|
||||||
var notify = function( slideElement, indexh, indexv, origin ) {
|
function post() {
|
||||||
if( typeof origin === 'undefined' && origin !== 'remote' ) {
|
|
||||||
var nextindexh;
|
|
||||||
var nextindexv;
|
|
||||||
|
|
||||||
var fragmentindex = Reveal.getIndices().f;
|
var messageData = {
|
||||||
if (typeof fragmentindex == 'undefined') {
|
state: Reveal.getState(),
|
||||||
fragmentindex = 0;
|
secret: multiplex.secret,
|
||||||
}
|
socketId: multiplex.id
|
||||||
|
};
|
||||||
|
|
||||||
if (slideElement.nextElementSibling && slideElement.parentNode.nodeName == 'SECTION') {
|
socket.emit( 'multiplex-statechanged', messageData );
|
||||||
nextindexh = indexh;
|
|
||||||
nextindexv = indexv + 1;
|
|
||||||
} else {
|
|
||||||
nextindexh = indexh + 1;
|
|
||||||
nextindexv = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
var slideData = {
|
|
||||||
indexh : indexh,
|
|
||||||
indexv : indexv,
|
|
||||||
indexf : fragmentindex,
|
|
||||||
nextindexh : nextindexh,
|
|
||||||
nextindexv : nextindexv,
|
|
||||||
secret: multiplex.secret,
|
|
||||||
socketId : multiplex.id
|
|
||||||
};
|
|
||||||
|
|
||||||
socket.emit('slidechanged', slideData);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Reveal.addEventListener( 'slidechanged', function( event ) {
|
|
||||||
notify( event.currentSlide, event.indexh, event.indexv, event.origin );
|
|
||||||
} );
|
|
||||||
|
|
||||||
var fragmentNotify = function( event ) {
|
|
||||||
notify( Reveal.getCurrentSlide(), Reveal.getIndices().h, Reveal.getIndices().v, event.origin );
|
|
||||||
};
|
};
|
||||||
|
|
||||||
Reveal.addEventListener( 'fragmentshown', fragmentNotify );
|
// Monitor events that trigger a change in state
|
||||||
Reveal.addEventListener( 'fragmenthidden', fragmentNotify );
|
Reveal.addEventListener( 'slidechanged', post );
|
||||||
|
Reveal.addEventListener( 'fragmentshown', post );
|
||||||
|
Reveal.addEventListener( 'fragmenthidden', post );
|
||||||
|
Reveal.addEventListener( 'overviewhidden', post );
|
||||||
|
Reveal.addEventListener( 'overviewshown', post );
|
||||||
|
Reveal.addEventListener( 'paused', post );
|
||||||
|
Reveal.addEventListener( 'resumed', post );
|
||||||
|
|
||||||
}());
|
}());
|
Loading…
Reference in New Issue