Skip to content

Commit

Permalink
Improve style sheet switcher: <select> & cookies
Browse files Browse the repository at this point in the history
  • Loading branch information
xolox committed Jan 14, 2011
1 parent cf4d46f commit 86c27d7
Showing 1 changed file with 63 additions and 11 deletions.
74 changes: 63 additions & 11 deletions etc/styleswitcher.js
@@ -1,4 +1,4 @@
function LXSH_GetStyles() {
function LXSH_GetAllStyles() {
var elements = document.getElementsByTagName('link');
var selected = new Array();
for (var i = elements.length - 1; i >= 0; i--)
Expand All @@ -10,26 +10,78 @@ function LXSH_GetStyles() {
return selected;
}

function LXSH_GetActiveStyle() {
var elements = LXSH_GetAllStyles();
for (var i = 0; i < elements.length; i++)
if (!elements[i].disabled)
return elements[i].getAttribute('title');
}

function LXSH_ChangeStyle(newstyle) {
var head = document.getElementsByTagName('head')[0];
var elements = LXSH_GetStyles();
var elements = LXSH_GetAllStyles();
for (var i = elements.length - 1; i >= 0; i--)
elements[i].disabled = (elements[i].getAttribute('title') != newstyle);
}

function createCookie(name, value, days) {
if (days) {
var date = new Date();
date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
var expires = "; expires=" + date.toGMTString();
} else
expires = "";
document.cookie = name + "=" + value + expires + "; path=/";
}

function readCookie(name) {
var nameEQ = name + "=";
var ca = document.cookie.split(';');
for (var i = 0; i < ca.length; i++) {
var c = ca[i];
while (c.charAt(0) == ' ')
c = c.substring(1, c.length);
if (c.indexOf(nameEQ) == 0)
return c.substring(nameEQ.length, c.length);
}
return null;
}

window.onload = function() {
var styles = LXSH_GetStyles();
var styles = LXSH_GetAllStyles();
var active = readCookie('lxsh_colors');
if (active != null)
LXSH_ChangeStyle(active);
else
active = LXSH_GetActiveStyle();
var elements = document.getElementsByTagName('pre');
for (var i = elements.length - 1; i >= 0; i--)
if (elements[i].getAttribute('class').indexOf('sourcecode') >= 0)
if (elements[i].getAttribute('class').indexOf('sourcecode') >= 0) {
var select = document.createElement('select');
select.style.cssFloat = 'right';
select.style.padding = '5px';
select.onclick = function() {
var elements = select.getElementsByTagName('option');
for (var j = 0; j < elements.length; j++)
if (elements[j].selected) {
var name = elements[j].innerHTML;
LXSH_ChangeStyle(name);
createCookie('lxsh_colors', name, 365);
break;
}
}
var group = document.createElement('optgroup');
group.label = 'Colors:';
select.appendChild(group);
for (var j = styles.length - 1; j >= 0; j--) {
var option = document.createElement('option');
var name = styles[j].getAttribute('title');
var link = document.createElement('a');
link.style.padding = '3px';
link.style.cssFloat = 'right';
link.innerHTML = name;
link.title = 'Switch to the ' + name + ' color scheme';
link.href = 'javascript:LXSH_ChangeStyle("' + name + '");';
elements[i].insertBefore(link, elements[i].firstChild);
option.innerHTML = name;
option.title = 'Select the "' + name + '" color scheme';
if (name == active)
option.selected = true;
group.appendChild(option);
}
elements[i].insertBefore(select, elements[i].firstChild);
}
}

0 comments on commit 86c27d7

Please sign in to comment.