mirror of
https://github.com/vichan-devel/vichan.git
synced 2024-12-13 16:21:10 +01:00
cf6a733931
Chromium browsers expect capital U in setUpControl and old version of webm-settings.js has setupControl which causes a error and makes expand-video.js not work and options.js not save when this is in use. This bug is not present on FireFox which automatically fixes this for some reason. Stupid bug, stupid fix. No lines actually added or removed.
98 lines
3.4 KiB
JavaScript
98 lines
3.4 KiB
JavaScript
/* This file is dedicated to the public domain; you may do as you wish with it. */
|
|
|
|
if (typeof _ == 'undefined') {
|
|
var _ = function(a) { return a; };
|
|
}
|
|
|
|
// Default settings
|
|
var defaultSettings = {
|
|
"videoexpand": true,
|
|
"videohover": false,
|
|
"videovolume": 1.0
|
|
};
|
|
|
|
// Non-persistent settings for when localStorage is absent/disabled
|
|
var tempSettings = {};
|
|
|
|
// Scripts obtain settings by calling this function
|
|
function setting(name) {
|
|
if (localStorage) {
|
|
if (localStorage[name] === undefined) return defaultSettings[name];
|
|
return JSON.parse(localStorage[name]);
|
|
} else {
|
|
if (tempSettings[name] === undefined) return defaultSettings[name];
|
|
return tempSettings[name];
|
|
}
|
|
}
|
|
|
|
// Settings should be changed with this function
|
|
function changeSetting(name, value) {
|
|
if (localStorage) {
|
|
localStorage[name] = JSON.stringify(value);
|
|
} else {
|
|
tempSettings[name] = value;
|
|
}
|
|
}
|
|
|
|
// Create settings menu
|
|
var settingsMenu = document.createElement("div");
|
|
var prefix = "", suffix = "", style = "";
|
|
if (window.Options) {
|
|
var tab = Options.add_tab("webm", "video-camera", _("WebM"));
|
|
$(settingsMenu).appendTo(tab.content);
|
|
}
|
|
else {
|
|
prefix = '<a class="unimportant" href="javascript:void(0)">'+_('WebM Settings')+'</a>';
|
|
settingsMenu.style.textAlign = "right";
|
|
settingsMenu.style.background = "inherit";
|
|
suffix = '</div>';
|
|
style = 'display: none; text-align: left; position: absolute; right: 1em; margin-left: -999em; margin-top: -1px; padding-top: 1px; background: inherit;';
|
|
}
|
|
|
|
settingsMenu.innerHTML = prefix
|
|
+ '<div style="'+style+'">'
|
|
+ '<label><input type="checkbox" name="videoexpand">'+_('Expand videos inline')+'</label><br>'
|
|
+ '<label><input type="checkbox" name="videohover">'+_('Play videos on hover')+'</label><br>'
|
|
+ '<label><input type="range" name="videovolume" min="0" max="1" step="0.01" style="width: 4em; height: 1ex; vertical-align: middle; margin: 0px;">'+_('Default volume')+'</label><br>'
|
|
+ suffix;
|
|
|
|
function refreshSettings() {
|
|
var settingsItems = settingsMenu.getElementsByTagName("input");
|
|
for (var i = 0; i < settingsItems.length; i++) {
|
|
var control = settingsItems[i];
|
|
if (control.type == "checkbox") {
|
|
control.checked = setting(control.name);
|
|
} else if (control.type == "range") {
|
|
control.value = setting(control.name);
|
|
}
|
|
}
|
|
}
|
|
|
|
function setUpControl(control) {
|
|
if (control.addEventListener) control.addEventListener("change", function(e) {
|
|
if (control.type == "checkbox") {
|
|
changeSetting(control.name, control.checked);
|
|
} else if (control.type == "range") {
|
|
changeSetting(control.name, control.value);
|
|
}
|
|
}, false);
|
|
}
|
|
|
|
refreshSettings();
|
|
var settingsItems = settingsMenu.getElementsByTagName("input");
|
|
for (var i = 0; i < settingsItems.length; i++) {
|
|
setUpControl(settingsItems[i]);
|
|
}
|
|
|
|
if (settingsMenu.addEventListener && !window.Options) {
|
|
settingsMenu.addEventListener("mouseover", function(e) {
|
|
refreshSettings();
|
|
settingsMenu.getElementsByTagName("a")[0].style.fontWeight = "bold";
|
|
settingsMenu.getElementsByTagName("div")[0].style.display = "block";
|
|
}, false);
|
|
settingsMenu.addEventListener("mouseout", function(e) {
|
|
settingsMenu.getElementsByTagName("a")[0].style.fontWeight = "normal";
|
|
settingsMenu.getElementsByTagName("div")[0].style.display = "none";
|
|
}, false);
|
|
}
|