Skip to content

Instantly share code, notes, and snippets.

@janglapuk
Last active October 12, 2020 12:20
Show Gist options
  • Save janglapuk/38d4cab117bddd84177bf510c827fa0c to your computer and use it in GitHub Desktop.
Save janglapuk/38d4cab117bddd84177bf510c827fa0c to your computer and use it in GitHub Desktop.
[Tampermonkey] Disney+ Hotstar Default Streaming Quality Setter
// ==UserScript==
// @name Disney+ Hotstar Default Streaming Quality Setter
// @namespace http://github.com/janglapuk
// @version 0.5
// @description Set Disney+ Hotstar default streaming quality and fullscreen options
// @author janglapuk
// @match https://www.hotstar.com/*
// @grant none
// @updateURL https://gist.githubusercontent.com/janglapuk/38d4cab117bddd84177bf510c827fa0c/raw/hotstar-default-quality-setter.user.js
// @downloadURL https://gist.githubusercontent.com/janglapuk/38d4cab117bddd84177bf510c827fa0c/raw/hotstar-default-quality-setter.user.js
// @require https://code.jquery.com/jquery-3.5.1.min.js
// @require https://gist.githubusercontent.com/BrockA/2625891/raw/waitForKeyElements.js
// @require https://cdn.jsdelivr.net/npm/sweetalert2@10
// @require https://cdnjs.cloudflare.com/ajax/libs/screenfull.js/5.0.2/screenfull.min.js
// ==/UserScript==
(function() {
'use strict';
var defaultFallbackQuality = "medium";
var defaultFallbackFullscreen = false;
function getSavedQuality() {
var currentSaved;
try {
currentSaved = JSON.parse(localStorage.getItem("hotstar-saved-state")) || undefined;
} catch(e) {
console.warn("[Disney+ Hotstar Quality Setter] Session Saved State not parsed :: ", e);
}
if(currentSaved === undefined) {
return {'quality': defaultFallbackQuality, 'fullscreen': defaultFallbackFullscreen};
}
return currentSaved;
}
function setDefaultFullscreen(defaultFullscreen) {
var currentSaved = getSavedQuality();
currentSaved.fullscreen = defaultFullscreen;
localStorage.setItem("hotstar-saved-state", JSON.stringify(currentSaved));
}
function getPlayerState() {
var currentState = undefined;
try {
currentState = JSON.parse(sessionStorage.getItem("vjs-player-state")) || undefined;
} catch(e) {
console.warn("[Disney+ Hotstar Quality Setter] Session Store Player state not parsed :: ", e);
}
return currentState;
}
function setDefaultQuality(defaultQuality) {
var currentState = getPlayerState();
if(currentState === undefined) {
currentState = {"quality": defaultQuality};
} else {
currentState.quality = defaultQuality;
}
var currentSaved = getSavedQuality();
sessionStorage.setItem("vjs-player-state", JSON.stringify(currentState));
currentSaved.quality = defaultQuality;
localStorage.setItem("hotstar-saved-state", JSON.stringify(currentSaved));
console.info("[Disney+ Hotstar Quality Setter] Default state set to: " + JSON.stringify(currentState));
}
jQuery(document).ready(function() {
var currentSaved = getSavedQuality();
setDefaultQuality(currentSaved.quality);
waitForKeyElements('.bottom-right-panel', function() {
var $wrapper = jQuery('<div/>').addClass('skin-lock-wrapper');
(function() {
var $control = jQuery('<div/>').addClass('default-quality-control player-control');
var $img = jQuery('<img/>');
$img.css('width', '26px');
$img.css('height', '26px');
$img.attr('src', '');
var inputOptions = {
"AUTO": "Auto",
"low": "Low quality",
"medium": "Medium quality",
"high": "High quality",
};
$img.on('click', async function() {
var currentSaved = getSavedQuality();
const { value: quality } = await Swal.fire({
title: 'Select Default Streaming Quality',
input: 'radio',
showCancelButton: true,
width: 400,
icon: 'error',
iconHtml: '<img src="" />',
inputValue: currentSaved.quality,
inputOptions: inputOptions,
inputValidator: (value) => {
if (!value) {
return 'You need to choose something!'
}
}
});
if(quality !== undefined) {
setDefaultQuality(quality);
document.location.reload();
}
});
$wrapper.append(
$control.append(
$img
)
).insertBefore('.bottom-right-panel > .skin-lock-wrapper:last');
})();
(function() {
var $control = jQuery('<div/>').addClass('default-fullscreen-control player-control');
var $img = jQuery('<img/>');
$img.css('width', '22px');
$img.css('height', '22px');
$img.attr('src', '');
$img.on('click', async function() {
var currentSaved = getSavedQuality();
const { value: alwaysFullscreen } = await Swal.fire({
title: 'Fullscreen Option',
input: 'checkbox',
showCancelButton: true,
width: 400,
icon: 'error',
iconHtml: '<img src="" />',
inputValue: currentSaved.fullscreen,
inputPlaceholder: 'Always fullscreen on watching',
});
if(alwaysFullscreen !== undefined) {
setDefaultFullscreen(Boolean(alwaysFullscreen));
document.location.reload();
}
});
$wrapper.append(
$control.append(
$img
)
).insertBefore('.bottom-right-panel > .skin-lock-wrapper:last');
})();
});
waitForKeyElements('.skin-lock-wrapper > .fullscreen.player-control', function() {
var currentSaved = getSavedQuality();
if(currentSaved.fullscreen) {
screenfull.toggle(jQuery('.player-base')[0]);
}
});
waitForKeyElements('.player-base', function() {
jQuery('.player-base').dblclick(function() {
screenfull.toggle(jQuery('.player-base')[0]);
});
});
});
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment