// ==UserScript==
// @name Youtube Mini Player
// @namespace feifeihang.info
// @description Toggle mini player when scrolling down in Youtube
// @include https://youtu.be/*
// @include http://youtu.be/*
// @include https://www.youtube.com/*
// @include http://www.youtube.com/*
// @version 5.2.2
// @grant none
// @downloadURL none
// ==/UserScript==
(function (window, document, undefined) {
var fontAwesome = document.createElement('link');
fontAwesome.rel = 'stylesheet';
fontAwesome.href = 'https://maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css';
document.head.appendChild(fontAwesome);
var isRight = true;
// find and keep a reference of the video player.
var player;
var stylePlayer = '';
var video;
var videoSize = {
};
var controls;
var controlsWidth;
// a flag to indicate is the mini player is toggled.
var isToggled = false;
var isTogglable = true;
var originalHeight;
var s2sBtn;
var hasAddedMini = false;
var shouldToggle = false;
var urlBuffer = '';
window.setInterval(function () {
if (isToggled &&
!/^http[sS]*\:\/\/www\.youtube\.com\/watch[?]*/.test(window.location.href) &&
shouldToggle) {
turnOff();
shouldToggle = false;
}
if (!shouldToggle &&
/^http[sS]*\:\/\/www\.youtube\.com\/watch[?]*/.test(window.location.href)) {
if (window.location.href !== urlBuffer) {
isToggled = false;
urlBuffer = urlBuffer;
}
shouldToggle = true;
}
}, 500);
var intervalId = window.setInterval(function () {
if (!hasAddedMini &&
/^http[sS]*\:\/\/www\.youtube\.com\/watch[?]*/.test(window.location.href)) {
shouldToggle = true;
player = document.querySelector('#movie_player');
video = document.querySelector('#movie_player video.video-stream');
controls = document.querySelector('#movie_player .ytp-chrome-bottom');
window.addEventListener('scroll', function () {
if (!isTogglable) {
return false;
}
// when scrolling up to 1/3 original player height, turn off mini player.
if (isToggled && window.pageYOffset < originalHeight / 3) {
turnOff();
return;
}
// when scrolling down to 1/3 player height, go to mini player mode.
if (shouldToggle) {
gotoMini();
}
}, false);
// add a mini player toggle button.
var btn = document.createElement('div');
btn.className += ' yt-uix-button yt-uix-button-size-default yt-uix-button-primary';
btn.innerHTML = 'Mini: on';
btn.style = 'line-height: 26px; height: 26px; margin-left: 5px;';
btn.onclick = function () {
if (this.innerHTML === 'Mini: on') {
this.innerHTML = 'Mini: off';
isTogglable = false;
if (isToggled) {
turnOff();
}
}
else {
this.innerHTML = 'Mini: on';
gotoMini();
isTogglable = true;
}
}
var dom = document.querySelector('#yt-masthead-signin') ||
document.querySelector('#yt-masthead-user');
dom.appendChild(btn);
hasAddedMini = true;
window.clearInterval(intervalId);
}
}, 500);
function turnOff() {
player.style = stylePlayer;
video.style.width = videoSize.width;
video.style.height = videoSize.height;
video.style.left = videoSize.left;
video.style.top = videoSize.top;
controls.style.width = controlsWidth;
if (document.querySelector('.ytp-size-button')) {
document.querySelector('.ytp-size-button').style.display = 'inline-block';
}
if (s2sBtn) {
s2sBtn.remove();
}
// isRight = true;
isToggled = false;
}
function gotoMini() {
if (!isToggled &&
window.pageYOffset >= parseInt(player.offsetHeight, 10) / 3) {
originalHeight = parseInt(player.offsetHeight, 10);
stylePlayer = player.style.cssText;
videoSize = {
height: video.style.height,
width: video.style.width,
left: video.style.left,
top: video.style.top
};
controlsWidth = controls.style.width;
var top = 'top: ' + (window.innerHeight - 270) + 'px;';
var left = 'left: ' + (window.innerWidth - 430) + 'px;';
var fontString = '';
if (isRight) {
player.style = 'position: fixed; bottom: 20px; left: 20px; height: 230px;' +
'width: 400px; z-index: 9999999;' + top + left;
fontString = '';
}
else {
player.style = 'position: fixed; bottom: 20px; left: 20px; height: 230px;' +
'width: 400px; z-index: 9999999;' + top;
fontString = '';
}
video.style.height = '250px';
video.style.width = '400px';
video.style.top = '-10px';
video.style.left = '0';
controls.style.width = '350px';
// now, hide the switch size button.
if (document.querySelector('.ytp-size-button')) {
document.querySelector('.ytp-size-button').style.display = 'none';
}
// add the 'Side-to-side' button.
s2sBtn = document.createElement('button');
s2sBtn.className += ' ytp-button';
s2sBtn.style.lineHeight = '10px';
s2sBtn.innerHTML = fontString;
s2sBtn.setAttribute('title', 'Mini player side to side');
s2sBtn.onclick = function () {
if (isRight) {
player.style = 'position: fixed; bottom: 20px; left: 20px; height: 230px;' +
'width: 400px; z-index: 9999999;' + top;
fontString = '';
isRight = false;
}
else {
player.style = 'position: fixed; bottom: 20px; left: 20px; height: 230px;' +
'width: 400px; z-index: 9999999;' + top + left;
fontString = '';
isRight = true;
}
s2sBtn.innerHTML = fontString;
};
var fullscreen = document.querySelector('.ytp-fullscreen-button');
fullscreen.parentElement.insertBefore(s2sBtn, null);
isToggled = true;
}
}
}) (window, document);