1
0
mirror of https://github.com/vichan-devel/vichan.git synced 2025-01-07 12:01:43 +01:00
vichan/js/webm-settings.js

100 lines
3.5 KiB
JavaScript
Raw Normal View History

2014-03-20 00:04:23 +01:00
/* This file is dedicated to the public domain; you may do as you wish with it. */
2014-04-06 22:32:48 +02:00
if (typeof _ == 'undefined') {
var _ = function(a) { return a; };
}
2014-03-10 21:24:41 +01:00
// Default settings
var defaultSettings = {
"videoexpand": true,
"videohover": false,
2015-02-21 13:49:45 +01:00
"videovolume": 1.0,
"videoloop": true
2014-03-10 21:24:41 +01:00
};
// Non-persistent settings for when localStorage is absent/disabled
var tempSettings = {};
// Scripts obtain settings by calling this function
function setting(name) {
2014-03-10 21:24:41 +01:00
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];
}
}
2014-03-05 04:53:20 +01:00
// Settings should be changed with this function
function changeSetting(name, value) {
2014-03-10 21:24:41 +01:00
if (localStorage) {
localStorage[name] = JSON.stringify(value);
} else {
tempSettings[name] = value;
}
}
// Create settings menu
2014-04-06 22:28:26 +02:00
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;';
}
2014-04-06 22:28:26 +02:00
settingsMenu.innerHTML = prefix
+ '<div style="'+style+'">'
2014-04-06 22:32:48 +02:00
+ '<label><input type="checkbox" name="videoexpand">'+_('Expand videos inline')+'</label><br>'
+ '<label><input type="checkbox" name="videohover">'+_('Play videos on hover')+'</label><br>'
2015-02-21 13:49:45 +01:00
+ '<label><input type="checkbox" name="videoloop">'+_('Loop videos by default')+'</label><br>'
2014-04-06 22:32:48 +02:00
+ '<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;
2013-11-09 10:11:22 +01:00
function refreshSettings() {
var settingsItems = settingsMenu.getElementsByTagName("input");
2013-11-09 10:11:22 +01:00
for (var i = 0; i < settingsItems.length; i++) {
2014-03-05 01:45:53 +01:00
var control = settingsItems[i];
if (control.type == "checkbox") {
control.checked = setting(control.name);
} else if (control.type == "range") {
control.value = setting(control.name);
}
2013-11-09 10:11:22 +01:00
}
}
2014-03-05 01:45:53 +01:00
function setupControl(control) {
if (control.addEventListener) control.addEventListener("change", function(e) {
if (control.type == "checkbox") {
2014-03-05 04:53:20 +01:00
changeSetting(control.name, control.checked);
2014-03-05 01:45:53 +01:00
} else if (control.type == "range") {
2014-03-05 04:53:20 +01:00
changeSetting(control.name, control.value);
2014-03-05 01:45:53 +01:00
}
}, false);
2013-11-09 10:11:22 +01:00
}
refreshSettings();
var settingsItems = settingsMenu.getElementsByTagName("input");
2013-11-09 10:11:22 +01:00
for (var i = 0; i < settingsItems.length; i++) {
2014-03-05 01:45:53 +01:00
setupControl(settingsItems[i]);
2013-11-09 10:11:22 +01:00
}
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);
}