Cleanup rustbook.js and add 'use strict'

Mostly indentation fixes, but a little refactoring, too.
This commit is contained in:
Nick Howell 2015-09-24 21:59:43 -04:00
parent f0666b45dd
commit 5ac899c8c2

View File

@ -1,4 +1,4 @@
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT // Copyright 2014-2015 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at // file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT. // http://rust-lang.org/COPYRIGHT.
// //
@ -8,66 +8,71 @@
// option. This file may not be copied, modified, or distributed // option. This file may not be copied, modified, or distributed
// except according to those terms. // except according to those terms.
/*jslint browser: true, es5: true */
/*globals $: true, rootPath: true */
document.addEventListener("DOMContentLoaded", function(event) { document.addEventListener('DOMContentLoaded', function() {
'use strict';
document.getElementById("toggle-nav").onclick = toggleNav; document.getElementById('toggle-nav').onclick = function(e) {
var toc = document.getElementById('toc');
var pagewrapper = document.getElementById('page-wrapper');
toggleClass(toc, 'mobile-hidden');
toggleClass(pagewrapper, 'mobile-hidden');
};
function toggleNav() { function toggleClass(el, className) {
var toc = document.getElementById("toc"); // from http://youmightnotneedjquery.com/
var pagewrapper = document.getElementById("page-wrapper"); if (el.classList) {
toggleClass(toc, "mobile-hidden"); el.classList.toggle(className);
toggleClass(pagewrapper, "mobile-hidden"); } else {
} var classes = el.className.split(' ');
var existingIndex = classes.indexOf(className);
function toggleClass(el, className) { if (existingIndex >= 0) {
// from http://youmightnotneedjquery.com/ classes.splice(existingIndex, 1);
if (el.classList) { } else {
el.classList.toggle(className); classes.push(className);
} else { }
var classes = el.className.split(' ');
var existingIndex = classes.indexOf(className);
if (existingIndex >= 0) { el.className = classes.join(' ');
classes.splice(existingIndex, 1); }
} else {
classes.push(className);
}
el.className = classes.join(' ');
}
}
// The below code is used to add prev and next navigation links to the bottom
// of each of the sections.
// It works by extracting the current page based on the url and iterates over
// the menu links until it finds the menu item for the current page. We then
// create a copy of the preceding and following menu links and add the
// correct css class and insert them into the bottom of the page.
var toc = document.getElementById('toc').getElementsByTagName('a');
var href = document.location.pathname.split('/').pop();
if (href === 'index.html' || href === '') {
href = 'README.html';
}
for (var i = 0; i < toc.length; i++) {
if (toc[i].attributes.href.value.split('/').pop() === href) {
var nav = document.createElement('p');
if (i > 0) {
var prevNode = toc[i-1].cloneNode(true);
prevNode.className = 'left';
prevNode.setAttribute('rel', 'prev');
nav.appendChild(prevNode);
}
if (i < toc.length - 1) {
var nextNode = toc[i+1].cloneNode(true);
nextNode.className = 'right';
nextNode.setAttribute('rel', 'next');
nav.appendChild(nextNode);
}
document.getElementById('page').appendChild(nav);
break;
} }
}
// The below code is used to add prev and next navigation links to the
// bottom of each of the sections.
// It works by extracting the current page based on the url and iterates
// over the menu links until it finds the menu item for the current page. We
// then create a copy of the preceding and following menu links and add the
// correct css class and insert them into the bottom of the page.
var toc = document.getElementById('toc').getElementsByTagName('a');
var href = document.location.pathname.split('/').pop();
if (href === 'index.html' || href === '') {
href = 'README.html';
}
for (var i = 0; i < toc.length; i++) {
if (toc[i].attributes.href.value.split('/').pop() === href) {
var nav = document.createElement('p');
if (i > 0) {
var prevNode = toc[i-1].cloneNode(true);
prevNode.className = 'left';
prevNode.setAttribute('rel', 'prev');
nav.appendChild(prevNode);
}
if (i < toc.length - 1) {
var nextNode = toc[i+1].cloneNode(true);
nextNode.className = 'right';
nextNode.setAttribute('rel', 'next');
nav.appendChild(nextNode);
}
document.getElementById('page').appendChild(nav);
break;
}
}
}); });