/* Author: Mihai Bazon, September 2002 * http://students.infoiasi.ro/~mishoo * * Table Of Content generator * Version: 0.4.sp * * Feel free to use this script under the terms of the GNU General Public * License, as long as you do not remove or alter this notice. */ /* modified by Troy D. Hanson, September 2006. License: GPL */ /* modified by Stuart Rackham, October 2006. License: GPL */ /* modified by Shawn Pearce, August 2009. License: GPL */ function getText(el) { var text = ""; for (var i = el.firstChild; i != null; i = i.nextSibling) { if (i.nodeType == 3 /* Node.TEXT_NODE */) // IE doesn't speak constants. text += i.data; else if (i.firstChild != null) text += getText(i); } return text; } function TocEntry(el, text, toclevel) { this.element = el; this.text = text; this.toclevel = toclevel; this.assigned = false; if (el.id != '') { this.id = el.id; } else { var a = el.firstChild; if ((a.tagName == "a" || a.tagName == "A") && a.id != "") { this.id = a.id; } else { this.id = ''; } } } function tocEntries(el, toclevels) { var result = new Array; var re = new RegExp('[hH]([2-'+(toclevels+1)+'])'); // Function that scans the DOM tree for header elements (the DOM2 // nodeIterator API would be a better technique but not supported by all // browsers). var iterate = function (el) { for (var i = el.firstChild; i != null; i = i.nextSibling) { if (i.nodeType == 1 /* Node.ELEMENT_NODE */) { var mo = re.exec(i.tagName) if (mo) result[result.length] = new TocEntry(i, getText(i), mo[1]-1); iterate(i); } } } iterate(el); return result; } // This function does the work. toclevels = 1..4. function generateToc(toclevels) { var simple_re = new RegExp('^[a-zA-Z._ -]{1,}$'); var entries = tocEntries(document.getElementsByTagName("body")[0], toclevels); var usedIds = new Array(); for (var i = 0; i < entries.length; ++i) { var entry = entries[i]; if (entry.id != "") usedIds[entry.id] = entry; } for (var i = 0; i < entries.length; ++i) { var entry = entries[i]; if (entry.id != "" || !simple_re.exec(entry.text)) continue; var n = entry.text.replace(/ /g, '_').toLowerCase(); var e = usedIds[n]; if (e) { if (e.assigned) e.id = ''; continue; } entry.assigned = true; entry.id = n; entry.element.id = entry.id; usedIds[n] = entry; } for (var i = 0; i < entries.length; ++i) { var entry = entries[i]; if (entry.id == '') { entry.id = "toc" + i; entry.element.id = entry.id; } } var toc = document.getElementById("toc"); for (var i = 0; i < entries.length; ++i) { var entry = entries[i]; var a = document.createElement("a"); a.href = "#" + entry.id; a.appendChild(document.createTextNode(entry.text)); var div = document.createElement("div"); div.appendChild(a); div.className = "toclevel" + entry.toclevel; toc.appendChild(div); } }