Last active
October 12, 2020 12:20
-
-
Save janglapuk/38d4cab117bddd84177bf510c827fa0c to your computer and use it in GitHub Desktop.
[Tampermonkey] Disney+ Hotstar Default Streaming Quality Setter
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ==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