forked from leftypol/leftypol
add user-options dialog functionality; port webm-settings to it; make a basic general settings applet; make it work on mobiles
This commit is contained in:
parent
ceaaae824a
commit
f7a015e7fe
5 changed files with 261 additions and 7 deletions
126
js/options.js
Normal file
126
js/options.js
Normal file
|
@ -0,0 +1,126 @@
|
|||
/*
|
||||
* options.js - allow users choose board options as they wish
|
||||
*
|
||||
* Copyright (c) 2014 Marcin Łabanowski <marcin@6irc.net>
|
||||
*
|
||||
* Usage:
|
||||
* $config['additional_javascript'][] = 'js/jquery.min.js';
|
||||
* $config['additional_javascript'][] = 'js/options.js';
|
||||
*/
|
||||
|
||||
+function(){
|
||||
|
||||
var options_button, options_handler, options_background, options_div
|
||||
, options_close, options_tablist, options_tabs, options_current_tab;
|
||||
|
||||
var Options = {};
|
||||
window.Options = Options;
|
||||
|
||||
var first_tab = function() {
|
||||
for (var i in options_tabs) {
|
||||
return i;
|
||||
}
|
||||
return false;
|
||||
};
|
||||
|
||||
Options.show = function() {
|
||||
if (!options_current_tab) {
|
||||
Options.select_tab(first_tab(), true);
|
||||
}
|
||||
options_handler.fadeIn();
|
||||
};
|
||||
Options.hide = function() {
|
||||
options_handler.fadeOut();
|
||||
};
|
||||
|
||||
options_tabs = {};
|
||||
|
||||
Options.add_tab = function(id, icon, name, content) {
|
||||
var tab = {};
|
||||
|
||||
if (typeof content == "string") {
|
||||
content = $("<div>"+content+"</div>");
|
||||
}
|
||||
|
||||
tab.id = id;
|
||||
tab.name = name;
|
||||
tab.icon = $("<div class='options_tab_icon'><i class='fa fa-"+icon+"'></i><div>"+name+"</div></div>");
|
||||
tab.content = $("<div class='options_tab'></div>").css("display", "none");
|
||||
|
||||
tab.content.appendTo(options_div);
|
||||
|
||||
tab.icon.on("click", function() {
|
||||
Options.select_tab(id);
|
||||
}).appendTo(options_tablist);
|
||||
|
||||
$("<h2>"+name+"</h2>").appendTo(tab.content);
|
||||
|
||||
if (content) {
|
||||
content.appendTo(tab.content);
|
||||
}
|
||||
|
||||
options_tabs[id] = tab;
|
||||
|
||||
return tab;
|
||||
};
|
||||
|
||||
Options.get_tab = function(id) {
|
||||
return options_tabs[id];
|
||||
};
|
||||
|
||||
Options.extend_tab = function(id, content) {
|
||||
if (typeof content == "string") {
|
||||
content = $("<div>"+content+"</div>");
|
||||
}
|
||||
|
||||
content.appendTo(options_tabs[id].content);
|
||||
|
||||
return options_tabs[id];
|
||||
};
|
||||
|
||||
Options.select_tab = function(id, quick) {
|
||||
if (options_current_tab) {
|
||||
if (options_current_tab.id == id) {
|
||||
return false;
|
||||
}
|
||||
options_current_tab.content.fadeOut();
|
||||
options_current_tab.icon.removeClass("active");
|
||||
}
|
||||
var tab = options_tabs[id];
|
||||
options_current_tab = tab;
|
||||
options_current_tab.icon.addClass("active");
|
||||
tab.content[quick? "show" : "fadeIn"]();
|
||||
|
||||
return tab;
|
||||
};
|
||||
|
||||
options_handler = $("<div id='options_handler'></div>").css("display", "none");
|
||||
options_background = $("<div id='options_background'></div>").on("click", Options.hide).appendTo(options_handler);
|
||||
options_div = $("<div id='options_div'></div>").appendTo(options_handler);
|
||||
options_close = $("<a id='options_close' href='javascript:void(0)'><i class='fa fa-times'></i></div>")
|
||||
.on("click", Options.hide).appendTo(options_div);
|
||||
options_tablist = $("<div id='options_tablist'></div>").appendTo(options_div);
|
||||
|
||||
|
||||
$(function(){
|
||||
options_button = $("<a href='javascript:void(0)' title='"+_("Options")+"'>["+_("Options")+"]</a>").css("float", "right");
|
||||
|
||||
if ($(".boardlist.compact-boardlist").length) {
|
||||
options_button.addClass("cb-item cb-fa").html("<i class='fa fa-gear'></i>");
|
||||
}
|
||||
|
||||
if ($(".boardlist:first").length) {
|
||||
options_button.appendTo($(".boardlist:first"));
|
||||
}
|
||||
else {
|
||||
options_button.prependTo($(document.body));
|
||||
}
|
||||
|
||||
options_button.on("click", Options.show);
|
||||
|
||||
options_handler.appendTo($(document.body));
|
||||
});
|
||||
|
||||
|
||||
|
||||
}();
|
Loading…
Add table
Add a link
Reference in a new issue