-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathlive-reload.js
54 lines (49 loc) · 1.95 KB
/
live-reload.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
var WebSocketServer = require('ws').Server;
var Gaze = require('gaze');
var path = require('path');
var _ = require('underscore');
module.exports.watch = function (options) {
var server = options.server;
var app = options.app;
var pathPatterns = options.pathPatterns;
var wss = new WebSocketServer({server: server});
var wsIdCounter = 0;
var socketConnections = Object.create(null);
wss.on('connection', function(ws) {
var cid = "ws"+(++wsIdCounter);
socketConnections[cid]=ws;
ws.onclose = function () {
delete socketConnections[cid];
};
});
var broadcast = _.throttle(function (message) {
console.log("Broadcasting");
for (var ws in socketConnections) {
socketConnections[ws].send(message);
}
}, 300);
var isBroadcastingChange = false;
app.get("/watch.js", function (req, res) {
res.writeHead(200, {'Content-Type': 'application/javascript'});
res.end("var socket = new WebSocket('ws://'+window.location.host+'/'); \n\
socket.onmessage = function (message) { \n\
if (message.data === '.css' || message.data == '.less') { \n\
console.log('Reloading css'); \n\
var queryString = '?reload=' + new Date().getTime(); \n\
$('link[rel=\"stylesheet\"]').each(function () { \n\
if (this.href.indexOf(\"typekit\") === -1) { \n\
this.href = this.href.replace(/\\?.*|$/, queryString); \n\
} \n\
}); \n\
} else { \n\
window.location.reload(); \n\
} \n\
};");
});
// Create a watch for each folder
var gaze = new Gaze(pathPatterns);
gaze.on('all', function(event, filepath) {
console.log("File changed:", path.extname(filepath));
broadcast(path.extname(filepath));
});
};