2013-03-24 02:28:20 +00:00
|
|
|
/*
|
|
|
|
The MIT License (MIT)
|
|
|
|
Copyright (c) 2013 Calvin Montgomery
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*/
|
2013-02-16 17:19:59 +00:00
|
|
|
|
2013-02-16 05:02:42 +00:00
|
|
|
// Wrapped in a function so I can ensure that the socket
|
|
|
|
// is defined before these statements are run
|
|
|
|
function initCallbacks() {
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("disconnect", function() {
|
|
|
|
$("<div/>").addClass("alert").addClass("alert-error")
|
|
|
|
.insertAfter($(".row")[0])[0]
|
2013-02-16 05:02:42 +00:00
|
|
|
.innerHTML = "<h3>Disconnected from server</h3>";
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("channelNotRegistered", function() {
|
2013-03-17 17:14:34 +00:00
|
|
|
showChannelRegistration();
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("announcement", function(data) {
|
2013-03-20 18:35:06 +00:00
|
|
|
showAnnouncement(data.title, data.text);
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("registerChannel", function(data) {
|
2013-03-17 17:14:34 +00:00
|
|
|
if(data.success) {
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#chregnotice").remove();
|
2013-03-17 17:14:34 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
alert(data.error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("rank", function(data) {
|
2013-02-16 05:02:42 +00:00
|
|
|
RANK = data.rank;
|
2013-03-25 18:54:18 +00:00
|
|
|
handleRankChange();
|
2013-02-16 05:02:42 +00:00
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("login", function(data) {
|
2013-02-16 05:02:42 +00:00
|
|
|
if(!data.success)
|
|
|
|
alert(data.error);
|
|
|
|
else {
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#welcome")[0].innerHTML = "Welcome, " + uname;
|
|
|
|
$("#loginform").css("display", "none");
|
|
|
|
$("#logoutform").css("display", "");
|
|
|
|
$("#loggedin").css("display", "");
|
2013-02-16 05:02:42 +00:00
|
|
|
if(pw != "") {
|
2013-03-24 17:23:48 +00:00
|
|
|
createCookie("sync_uname", uname, 1);
|
|
|
|
createCookie("sync_pw", pw, 1);
|
2013-02-16 05:02:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("register", function(data) {
|
2013-02-16 05:02:42 +00:00
|
|
|
if(data.error) {
|
|
|
|
alert(data.error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("channelOpts", function(opts) {
|
|
|
|
$("#opt_qopen_allow_qnext").prop("checked", opts.qopen_allow_qnext);
|
|
|
|
$("#opt_qopen_allow_move").prop("checked", opts.qopen_allow_move);
|
|
|
|
$("#opt_qopen_allow_delete").prop("checked", opts.qopen_allow_delete);
|
|
|
|
$("#opt_qopen_allow_playnext").prop("checked", opts.qopen_allow_playnext);
|
|
|
|
$("#opt_pagetitle").attr("placeholder", opts.pagetitle);
|
2013-03-22 20:04:04 +00:00
|
|
|
document.title = opts.pagetitle;
|
2013-03-30 05:49:41 +00:00
|
|
|
PAGETITLE = opts.pagetitle;
|
2013-03-28 23:51:08 +00:00
|
|
|
$("#opt_customcss").attr("placeholder", opts.customcss);
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#customCss").remove();
|
2013-03-23 22:15:19 +00:00
|
|
|
if(opts.customcss != "") {
|
2013-03-24 17:23:48 +00:00
|
|
|
$("<link/>").attr("rel", "stylesheet")
|
2013-03-23 22:15:19 +00:00
|
|
|
.attr("href", opts.customcss)
|
|
|
|
.attr("id", "customCss")
|
2013-03-24 17:23:48 +00:00
|
|
|
.insertAfter($("link[href='./assets/css/ytsync.css']"));
|
2013-03-23 22:15:19 +00:00
|
|
|
}
|
|
|
|
|
2013-03-22 20:04:04 +00:00
|
|
|
CHANNELOPTS = opts;
|
|
|
|
if(opts.qopen_allow_qnext)
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#queue_next").attr("disabled", false);
|
2013-03-22 20:04:04 +00:00
|
|
|
if(opts.qopen_allow_playnext)
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#play_next").attr("disabled", false);
|
2013-03-28 23:51:08 +00:00
|
|
|
else if(RANK < Rank.Moderator && !LEADER)
|
|
|
|
$("#play_next").attr("disabled", true);
|
2013-03-22 20:04:04 +00:00
|
|
|
rebuildPlaylist();
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("banlist", function(data) {
|
2013-03-24 03:45:10 +00:00
|
|
|
updateBanlist(data.entries);
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("usercount", function(data) {
|
|
|
|
$("#usercount").text(data.count + " connected users");
|
2013-03-07 01:38:16 +00:00
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("chatMsg", function(data) {
|
2013-03-05 20:07:21 +00:00
|
|
|
var div = formatChatMessage(data);
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#messagebuffer")[0].appendChild(div);
|
2013-02-16 05:02:42 +00:00
|
|
|
// Cap chatbox at most recent 100 messages
|
2013-03-24 17:23:48 +00:00
|
|
|
if($("#messagebuffer").children().length > 100) {
|
|
|
|
$($("#messagebufer").children()[0]).remove();
|
2013-02-16 05:02:42 +00:00
|
|
|
}
|
2013-03-30 05:55:25 +00:00
|
|
|
if(SCROLLCHAT)
|
|
|
|
$("#messagebuffer").scrollTop($("#messagebuffer").prop("scrollHeight"));
|
2013-02-16 05:02:42 +00:00
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("playlist", function(data) {
|
|
|
|
var ul = $("#queue")[0];
|
2013-02-16 05:02:42 +00:00
|
|
|
var n = ul.children.length;
|
|
|
|
for(var i = 0; i < n; i++) {
|
|
|
|
ul.removeChild(ul.children[0]);
|
|
|
|
}
|
|
|
|
for(var i = 0; i < data.pl.length; i++) {
|
|
|
|
var li = makeQueueEntry(data.pl[i]);
|
2013-03-25 18:54:18 +00:00
|
|
|
if(RANK >= Rank.Moderator || OPENQUEUE || LEADER)
|
2013-02-16 05:02:42 +00:00
|
|
|
addQueueButtons(li);
|
|
|
|
$(li).appendTo(ul);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("queue", function(data) {
|
2013-02-16 05:02:42 +00:00
|
|
|
var li = makeQueueEntry(data.media);
|
2013-03-25 18:54:18 +00:00
|
|
|
if(RANK >= Rank.Moderator || OPENQUEUE || LEADER)
|
2013-02-16 05:02:42 +00:00
|
|
|
addQueueButtons(li);
|
2013-03-24 17:23:48 +00:00
|
|
|
$(li).css("display", "none");
|
2013-02-16 05:02:42 +00:00
|
|
|
var idx = data.pos;
|
2013-03-24 17:23:48 +00:00
|
|
|
var ul = $("#queue")[0];
|
2013-02-16 05:02:42 +00:00
|
|
|
$(li).appendTo(ul);
|
|
|
|
if(idx < ul.children.length - 1)
|
|
|
|
moveVideo(ul.children.length - 1, idx);
|
2013-03-24 17:23:48 +00:00
|
|
|
$(li).show("blind");
|
2013-02-16 05:02:42 +00:00
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("unqueue", function(data) {
|
|
|
|
var li = $("#queue").children()[data.pos];
|
|
|
|
//$(li).hide("blind", function() {
|
2013-02-16 05:02:42 +00:00
|
|
|
$(li).remove();
|
2013-03-17 14:54:01 +00:00
|
|
|
//});
|
2013-02-16 05:02:42 +00:00
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("moveVideo", function(data) {
|
2013-02-16 05:02:42 +00:00
|
|
|
moveVideo(data.src, data.dest);
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("queueLock", function(data) {
|
2013-03-16 20:39:58 +00:00
|
|
|
OPENQUEUE = !data.locked;
|
|
|
|
if(OPENQUEUE) {
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#playlist_controls").css("display", "");
|
2013-03-16 20:39:58 +00:00
|
|
|
if(RANK < Rank.Moderator) {
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#qlockbtn").css("display", "none");
|
2013-03-22 20:04:04 +00:00
|
|
|
rebuildPlaylist();
|
|
|
|
if(!CHANNELOPTS.qopen_allow_qnext)
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#queue_next").attr("disabled", true);
|
2013-03-22 20:04:04 +00:00
|
|
|
if(!CHANNELOPTS.qopen_allow_playnext)
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#play_next").attr("disabled", true);
|
2013-03-16 20:39:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else if(RANK < Rank.Moderator) {
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#playlist_controls").css("display", "none");
|
2013-03-16 20:39:58 +00:00
|
|
|
}
|
2013-03-22 20:04:04 +00:00
|
|
|
if(OPENQUEUE) {
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#qlockbtn").removeClass("btn-danger")
|
|
|
|
.addClass("btn-success")
|
|
|
|
.text("Lock Queue");
|
2013-03-22 20:04:04 +00:00
|
|
|
}
|
|
|
|
else {
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#qlockbtn").removeClass("btn-success")
|
|
|
|
.addClass("btn-danger")
|
|
|
|
.text("Unlock Queue");
|
2013-03-16 20:39:58 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("updatePlaylistIdx", function(data) {
|
2013-03-29 20:05:08 +00:00
|
|
|
if(data.old != undefined) {
|
|
|
|
console.log("unhighlight", data.old);
|
|
|
|
var liold = $("#queue").children()[data.old];
|
|
|
|
$(liold).removeClass("alert alert-info");
|
|
|
|
}
|
2013-03-24 17:23:48 +00:00
|
|
|
var linew = $("#queue").children()[data.idx];
|
2013-02-16 05:02:42 +00:00
|
|
|
$(linew).addClass("alert alert-info");
|
2013-03-29 20:05:08 +00:00
|
|
|
POSITION = data.idx;
|
2013-02-16 05:02:42 +00:00
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("mediaUpdate", function(data) {
|
|
|
|
$("#currenttitle").text("Currently Playing: " + data.title);
|
2013-03-25 18:54:18 +00:00
|
|
|
if(data.type != "sc" && MEDIATYPE == "sc")
|
|
|
|
fixSoundcloudShit();
|
2013-02-16 05:02:42 +00:00
|
|
|
if(data.type == "yt")
|
|
|
|
updateYT(data);
|
|
|
|
else if(data.type == "tw")
|
|
|
|
loadTwitch(data.id);
|
2013-03-16 22:17:36 +00:00
|
|
|
else if(data.type == "li")
|
|
|
|
loadLivestream(data.id);
|
2013-02-16 05:02:42 +00:00
|
|
|
else if(data.type == "sc")
|
|
|
|
updateSC(data);
|
|
|
|
else if(data.type == "vi")
|
|
|
|
updateVI(data);
|
2013-03-23 18:17:39 +00:00
|
|
|
else if(data.type == "dm")
|
|
|
|
updateDM(data);
|
2013-02-16 05:02:42 +00:00
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("userlist", function(data) {
|
2013-02-16 05:02:42 +00:00
|
|
|
for(var i = 0; i < data.length; i++) {
|
|
|
|
addUser(data[i].name, data[i].rank, data[i].leader);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("addUser", function(data) {
|
2013-02-16 05:02:42 +00:00
|
|
|
addUser(data.name, data.rank, data.leader);
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("updateUser", function(data) {
|
2013-02-16 05:02:42 +00:00
|
|
|
if(data.name == uname) {
|
|
|
|
LEADER = data.leader;
|
2013-03-25 18:54:18 +00:00
|
|
|
handleRankChange();
|
2013-02-16 05:02:42 +00:00
|
|
|
if(LEADER) {
|
2013-03-25 18:54:18 +00:00
|
|
|
// I'm a leader! Set up sync function
|
2013-02-16 05:02:42 +00:00
|
|
|
sendVideoUpdate = function() {
|
|
|
|
if(MEDIATYPE == "yt") {
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.emit("mediaUpdate", {
|
2013-02-16 05:02:42 +00:00
|
|
|
id: parseYTURL(PLAYER.getVideoUrl()),
|
|
|
|
seconds: PLAYER.getCurrentTime(),
|
|
|
|
paused: PLAYER.getPlayerState() == YT.PlayerState.PAUSED,
|
|
|
|
type: "yt"
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else if(MEDIATYPE == "sc") {
|
|
|
|
PLAYER.getPosition(function(pos) {
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.emit("mediaUpdate", {
|
2013-02-16 05:02:42 +00:00
|
|
|
id: PLAYER.mediaId,
|
|
|
|
seconds: pos / 1000,
|
|
|
|
paused: false,
|
|
|
|
type: "sc"
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else if(MEDIATYPE == "vi") {
|
2013-03-24 17:23:48 +00:00
|
|
|
PLAYER.api("getCurrentTime", function(data) {
|
|
|
|
socket.emit("mediaUpdate", {
|
2013-02-16 05:02:42 +00:00
|
|
|
id: PLAYER.videoid,
|
2013-03-05 23:06:25 +00:00
|
|
|
seconds: data,
|
2013-02-16 05:02:42 +00:00
|
|
|
paused: false,
|
|
|
|
type: "vi"
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
2013-03-23 18:17:39 +00:00
|
|
|
else if(MEDIATYPE == "dm") {
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.emit("mediaUpdate", {
|
2013-03-23 18:17:39 +00:00
|
|
|
id: PLAYER.mediaId,
|
|
|
|
seconds: PLAYER.currentTime,
|
|
|
|
paused: PLAYER.paused,
|
|
|
|
type: "dm"
|
|
|
|
});
|
|
|
|
}
|
2013-02-16 05:02:42 +00:00
|
|
|
};
|
|
|
|
}
|
2013-03-25 18:54:18 +00:00
|
|
|
// I'm not a leader. Don"t send syncs to the server
|
2013-02-16 05:02:42 +00:00
|
|
|
else {
|
|
|
|
sendVideoUpdate = function() { }
|
|
|
|
}
|
2013-02-16 22:33:38 +00:00
|
|
|
|
2013-02-16 05:02:42 +00:00
|
|
|
}
|
2013-03-24 17:23:48 +00:00
|
|
|
var users = $("#userlist").children();
|
2013-02-16 05:02:42 +00:00
|
|
|
for(var i = 0; i < users.length; i++) {
|
2013-03-17 16:50:39 +00:00
|
|
|
var name = users[i].children[1].innerHTML;
|
2013-02-16 05:02:42 +00:00
|
|
|
// Reformat user
|
|
|
|
if(name == data.name) {
|
|
|
|
fmtUserlistItem(users[i], data.rank, data.leader);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("userLeave", function(data) {
|
|
|
|
var users = $("#userlist").children();
|
2013-02-16 05:02:42 +00:00
|
|
|
for(var i = 0; i < users.length; i++) {
|
2013-03-17 14:42:22 +00:00
|
|
|
var name = users[i].children[1].innerHTML;
|
2013-02-16 05:02:42 +00:00
|
|
|
if(name == data.name) {
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#userlist")[0].removeChild(users[i]);
|
2013-02-16 05:02:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("librarySearchResults", function(data) {
|
|
|
|
var n = $("#library").children().length;
|
2013-02-16 05:02:42 +00:00
|
|
|
for(var i = 0; i < n; i++) {
|
2013-03-24 17:23:48 +00:00
|
|
|
$("#library")[0].removeChild($("#library").children()[0]);
|
2013-02-16 05:02:42 +00:00
|
|
|
}
|
2013-03-24 17:23:48 +00:00
|
|
|
var ul = $("#library")[0];
|
2013-02-16 05:02:42 +00:00
|
|
|
for(var i = 0; i < data.results.length; i++) {
|
|
|
|
var li = makeQueueEntry(data.results[i]);
|
2013-03-25 18:54:18 +00:00
|
|
|
if(RANK >= Rank.Moderator || OPENQUEUE || LEADER)
|
2013-02-16 05:02:42 +00:00
|
|
|
addLibraryButtons(li, data.results[i].id);
|
|
|
|
$(li).appendTo(ul);
|
|
|
|
}
|
|
|
|
});
|
2013-03-16 21:49:58 +00:00
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("newPoll", function(data) {
|
2013-03-16 21:49:58 +00:00
|
|
|
addPoll(data);
|
2013-03-30 05:55:25 +00:00
|
|
|
if(SCROLLCHAT) {
|
|
|
|
$("#messagebuffer").scrollTop($("#messagebuffer").prop("scrollHeight"));
|
|
|
|
}
|
2013-03-16 21:49:58 +00:00
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("updatePoll", function(data) {
|
2013-03-16 21:49:58 +00:00
|
|
|
updatePoll(data);
|
|
|
|
});
|
|
|
|
|
2013-03-24 17:23:48 +00:00
|
|
|
socket.on("closePoll", function() {
|
2013-03-16 21:49:58 +00:00
|
|
|
closePoll();
|
|
|
|
});
|
2013-02-16 05:02:42 +00:00
|
|
|
}
|