CyTube/www/js/player-new.js

364 lines
9.7 KiB
JavaScript
Raw Normal View History

2015-04-24 02:19:55 +00:00
(function() {
2015-05-02 16:45:35 +00:00
var Player, TYPE_MAP, VimeoPlayer, YouTubePlayer,
2015-04-24 02:40:08 +00:00
extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },
hasProp = {}.hasOwnProperty;
2015-04-24 02:19:55 +00:00
2015-05-02 16:45:35 +00:00
window.Player = Player = (function() {
2015-04-24 02:40:08 +00:00
function Player(data) {
2015-05-02 16:45:35 +00:00
if (!(this instanceof Player)) {
return new Player(data);
}
2015-04-24 03:24:43 +00:00
this.setMediaProperties(data);
2015-04-24 02:40:08 +00:00
this.paused = false;
}
Player.prototype.load = function(data) {
2015-04-24 03:24:43 +00:00
return this.setMediaProperties(data);
};
Player.prototype.setMediaProperties = function(data) {
2015-04-24 02:40:08 +00:00
this.mediaId = data.id;
2015-04-24 03:24:43 +00:00
this.mediaType = data.type;
return this.mediaLength = data.seconds;
2015-04-24 02:40:08 +00:00
};
Player.prototype.play = function() {
return this.paused = false;
};
Player.prototype.pause = function() {
return this.paused = true;
};
Player.prototype.seekTo = function(time) {};
Player.prototype.setVolume = function(volume) {};
Player.prototype.getTime = function(cb) {
return cb(0);
};
Player.prototype.isPaused = function(cb) {
return cb(this.paused);
};
Player.prototype.getVolume = function(cb) {
return cb(VOLUME);
};
return Player;
})();
2015-05-02 16:45:35 +00:00
window.VimeoPlayer = VimeoPlayer = (function(superClass) {
extend(VimeoPlayer, superClass);
2015-04-24 02:40:08 +00:00
2015-05-02 16:45:35 +00:00
function VimeoPlayer(data) {
if (!(this instanceof VimeoPlayer)) {
return new VimeoPlayer(data);
}
this.load(data);
2015-04-24 02:40:08 +00:00
}
2015-04-30 20:26:09 +00:00
2015-05-02 16:45:35 +00:00
VimeoPlayer.prototype.load = function(data) {
this.setMediaProperties(data);
return waitUntilDefined(window, '$f', (function(_this) {
return function() {
var video;
video = $('<iframe/>');
removeOld(video);
video.attr({
src: "https://player.vimeo.com/video/" + data.id + "?api=1&player_id=ytapiplayer",
webkitallowfullscreen: true,
mozallowfullscreen: true,
allowfullscreen: true
});
if (USEROPTS.wmode_transparent) {
video.attr('wmode', 'transparent');
}
return $f(video[0]).addEvent('ready', function() {
_this.vimeo = $f(video[0]);
_this.play();
_this.vimeo.addEvent('finish', function() {
if (CLIENT.leader) {
return socket.emit('playNext');
}
});
_this.vimeo.addEvent('pause', function() {
_this.paused = true;
if (CLIENT.leader) {
return sendVideoUpdate();
}
});
_this.vimeo.addEvent('play', function() {
_this.paused = false;
if (CLIENT.leader) {
return sendVideoUpdate();
}
});
return _this.setVolume(VOLUME);
});
};
})(this));
};
2015-04-30 20:26:09 +00:00
2015-05-02 16:45:35 +00:00
VimeoPlayer.prototype.play = function() {
this.paused = false;
if (this.vimeo) {
return this.vimeo.api('play');
2015-04-30 20:26:09 +00:00
}
2015-05-02 16:45:35 +00:00
};
VimeoPlayer.prototype.pause = function() {
this.paused = true;
if (this.vimeo) {
return this.vimeo.api('pause');
2015-04-30 20:26:09 +00:00
}
2015-05-02 16:45:35 +00:00
};
VimeoPlayer.prototype.seekTo = function(time) {
if (this.vimeo) {
return this.vimeo.api('seekTo', time);
2015-04-30 20:26:09 +00:00
}
2015-05-02 16:45:35 +00:00
};
2015-04-24 02:40:08 +00:00
2015-05-02 16:45:35 +00:00
VimeoPlayer.prototype.setVolume = function(volume) {
if (this.vimeo) {
return this.vimeo.api('setVolume', volume);
}
};
2015-04-24 02:40:08 +00:00
2015-05-02 16:45:35 +00:00
VimeoPlayer.prototype.getTime = function(cb) {
if (this.vimeo) {
return this.vimeo.api('getCurrentTime', function(time) {
return cb(parseFloat(time));
});
} else {
return cb(0);
}
};
2015-04-24 02:40:08 +00:00
2015-05-02 16:45:35 +00:00
VimeoPlayer.prototype.getVolume = function(cb) {
if (this.vimeo) {
return this.vimeo.api('getVolume', cb);
} else {
return cb(VOLUME);
}
2015-04-24 02:40:08 +00:00
};
2015-05-02 16:45:35 +00:00
return VimeoPlayer;
2015-04-24 02:40:08 +00:00
})(Player);
2015-05-02 16:45:35 +00:00
window.YouTubePlayer = YouTubePlayer = (function(superClass) {
2015-04-24 02:40:08 +00:00
extend(YouTubePlayer, superClass);
function YouTubePlayer(data) {
2015-05-02 16:45:35 +00:00
if (!(this instanceof YouTubePlayer)) {
return new YouTubePlayer(data);
}
2015-04-24 03:24:43 +00:00
this.setMediaProperties(data);
this.qualityRaceCondition = true;
2015-04-30 20:26:09 +00:00
this.pauseSeekRaceCondition = false;
2015-04-24 02:40:08 +00:00
waitUntilDefined(window, 'YT', (function(_this) {
return function() {
var wmode;
removeOld();
wmode = USEROPTS.wmode_transparent ? 'transparent' : 'opaque';
return _this.yt = new YT.Player('ytapiplayer', {
videoId: data.id,
playerVars: {
autohide: 1,
autoplay: 1,
controls: 1,
iv_load_policy: 3,
rel: 0,
wmode: wmode
},
events: {
onReady: _this.onReady.bind(_this),
onStateChange: _this.onStateChange.bind(_this)
}
});
};
})(this));
}
2015-04-24 03:24:43 +00:00
YouTubePlayer.prototype.load = function(data) {
2015-05-02 16:45:35 +00:00
this.setMediaProperties(data);
2015-05-02 22:37:09 +00:00
if (this.yt && this.yt.ready) {
2015-04-24 03:24:43 +00:00
this.yt.loadVideoById(data.id, data.currentTime);
this.qualityRaceCondition = true;
if (USEROPTS.default_quality) {
return this.yt.setPlaybackQuality(USEROPTS.default_quality);
}
2015-05-02 22:37:09 +00:00
} else {
return console.error('WTF? YouTubePlayer::load() called but yt is not ready');
2015-04-24 03:24:43 +00:00
}
};
2015-04-24 02:40:08 +00:00
YouTubePlayer.prototype.onReady = function() {
2015-05-02 22:37:09 +00:00
this.yt.ready = true;
2015-05-02 16:45:35 +00:00
return this.setVolume(VOLUME);
2015-04-24 02:40:08 +00:00
};
2015-04-24 03:24:43 +00:00
YouTubePlayer.prototype.onStateChange = function(ev) {
if (this.qualityRaceCondition) {
this.qualityRaceCondition = false;
2015-04-30 20:26:09 +00:00
if (USEROPTS.default_quality) {
this.yt.setPlaybackQuality(USEROPTS.default_quality);
}
2015-04-24 03:24:43 +00:00
}
if (ev.data === YT.PlayerState.PLAYING && this.pauseSeekRaceCondition) {
this.pause();
this.pauseSeekRaceCondition = false;
}
if ((ev.data === YT.PlayerState.PAUSED && !this.paused) || (ev.data === YT.PlayerState.PLAYING && this.paused)) {
this.paused = ev.data === YT.PlayerState.PAUSED;
if (CLIENT.leader) {
sendVideoUpdate();
}
}
if (ev.data === YT.PlayerState.ENDED && CLIENT.leader) {
return socket.emit('playNext');
}
};
YouTubePlayer.prototype.play = function() {
2015-04-30 20:26:09 +00:00
this.paused = false;
2015-05-02 22:37:09 +00:00
if (this.yt && this.yt.ready) {
2015-04-24 03:24:43 +00:00
return this.yt.playVideo();
}
};
YouTubePlayer.prototype.pause = function() {
2015-04-30 20:26:09 +00:00
this.paused = true;
2015-05-02 22:37:09 +00:00
if (this.yt && this.yt.ready) {
2015-04-24 03:24:43 +00:00
return this.yt.pauseVideo();
}
};
YouTubePlayer.prototype.seekTo = function(time) {
2015-05-02 22:37:09 +00:00
if (this.yt && this.yt.ready) {
2015-04-24 03:24:43 +00:00
return this.yt.seekTo(time, true);
}
};
YouTubePlayer.prototype.setVolume = function(volume) {
2015-05-02 22:37:09 +00:00
if (this.yt && this.yt.ready) {
2015-04-24 03:24:43 +00:00
if (volume > 0) {
this.yt.unMute();
}
return this.yt.setVolume(volume * 100);
}
};
YouTubePlayer.prototype.getTime = function(cb) {
2015-05-02 22:37:09 +00:00
if (this.yt && this.yt.ready) {
2015-04-24 03:24:43 +00:00
return cb(this.yt.getCurrentTime());
2015-04-30 20:26:09 +00:00
} else {
return cb(0);
2015-04-24 03:24:43 +00:00
}
};
YouTubePlayer.prototype.getVolume = function(cb) {
2015-05-02 22:37:09 +00:00
if (this.yt && this.yt.ready) {
2015-04-24 03:24:43 +00:00
if (this.yt.isMuted()) {
2015-04-30 20:26:09 +00:00
return cb(0);
2015-04-24 03:24:43 +00:00
} else {
2015-04-30 20:26:09 +00:00
return cb(this.yt.getVolume() / 100);
2015-04-24 03:24:43 +00:00
}
2015-04-30 20:26:09 +00:00
} else {
return cb(VOLUME);
2015-04-24 03:24:43 +00:00
}
};
2015-04-24 02:40:08 +00:00
return YouTubePlayer;
})(Player);
2015-04-24 02:19:55 +00:00
2015-05-02 16:45:35 +00:00
TYPE_MAP = {
yt: YouTubePlayer,
vi: VimeoPlayer
};
window.loadMediaPlayer = function(data) {
var e;
if (data.type in TYPE_MAP) {
try {
2015-05-02 22:37:09 +00:00
return window.PLAYER = TYPE_MAP[data.type](data);
2015-05-02 16:45:35 +00:00
} catch (_error) {
e = _error;
2015-05-02 22:37:09 +00:00
return console.error(e);
2015-05-02 16:45:35 +00:00
}
}
};
window.handleMediaUpdate = function(data) {
var PLAYER, waiting;
PLAYER = window.PLAYER;
if (typeof PLAYER.mediaLength === 'number' && PLAYER.mediaLength > 0 && data.currentTime > PLAYER.mediaLength) {
return;
}
waiting = data.currentTime < 0;
if (data.id && data.id !== PLAYER.mediaId) {
if (data.currentTime < 0) {
data.currentTime = 0;
}
PLAYER.load(data);
PLAYER.play();
}
if (waiting) {
2015-05-02 22:37:09 +00:00
PLAYER.seekTo(0);
2015-05-02 16:45:35 +00:00
if (PLAYER instanceof YouTubePlayer) {
PLAYER.pauseSeekRaceCondition = true;
} else {
PLAYER.pause();
}
2015-05-02 22:37:09 +00:00
return;
2015-05-02 16:45:35 +00:00
} else if (PLAYER instanceof YouTubePlayer) {
PLAYER.pauseSeekRaceCondition = false;
}
if (CLIENT.leader || !USEROPTS.synch) {
return;
}
if (data.paused && !PLAYER.paused) {
PLAYER.seekTo(data.currentTime);
PLAYER.pause();
} else if (PLAYER.paused) {
PLAYER.play();
}
return PLAYER.getTime(function(seconds) {
var accuracy, diff, time;
time = data.currentTime;
diff = (time - seconds) || time;
accuracy = USEROPTS.sync_accuracy;
if (PLAYER.mediaType === 'dm') {
accuracy = Math.max(accuracy, 5);
}
if (diff > accuracy) {
return PLAYER.seekTo(time);
} else if (diff < -accuracy) {
if (PLAYER.mediaType !== 'dm') {
time += 1;
}
return PLAYER.seekTo(time);
}
});
};
window.removeOld = function(replace) {
var old;
$('#sc_volume').remove();
if (replace == null) {
replace = $('<div/>').addClass('embed-responsive-item');
}
old = $('#ytapiplayer');
replace.insertBefore(old);
old.remove();
replace.attr('id', 'ytapiplayer');
return replace;
};
2015-04-30 20:26:09 +00:00
2015-04-24 02:19:55 +00:00
}).call(this);