1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
// An inefficient, but effective bubble sort
function sort(collection, key) {
var i, j;
var count = collection.length;
var parent, child;
for (i = count - 1; i >= 0; i--) {
for (j = 1; j <= i; j++) {
if (collection[j - 1][key] > collection[j][key]) {
// Move the item both in the local array and
// in the tree
child = collection[j];
parent = child.parentNode;
collection[j] = collection[j - 1];
collection[j - 1] = child;
parent.removeChild(child);
parent.insertBefore(child, collection[j]);
}
}
}
}
// Set user properties on the nodes in the collection
// based on information found in its children. For example,
// make a property "Author" based on the content of the
// "Author" element found in the childNode list of the node.
// This makes later sorting more efficient
function collectInfo(nodes, propNames) {
var i, j, k;
var ncount = nodes.length;
var pcount = propNames.length;
for (i = 0; i < ncount; i++) {
var node = nodes[i];
var childNodes = node.childNodes;
var ccount = childNodes.length;
for (j = 0; j < ccount; j++) {
var child = childNodes[j];
if (child.nodeType == Node.ELEMENT_NODE) {
var tagName = child.tagName;
for (k = 0; k < pcount; k++) {
var prop = propNames[k];
if (prop == tagName) {
node[prop] = child.firstChild.data;
}
}
}
}
}
}
var enabled = true;
function toggleStyleSheet() {
if (enabled) {
document.styleSheets[2].disabled = true;
} else {
document.styleSheets[2].disabled = false;
}
enabled = !enabled;
}
// XXX This is a workaround for a bug where
// changing the disabled state of a stylesheet can't
// be done in an event handler. For now, we do it
// in a zero-delay timeout.
function initiateToggle() {
setTimeout(toggleStyleSheet, 0);
}
var sortableProps = ["Author", "Title", "ISBN"];
var books = [];
// We uppercase the tagName as a workaround for a bug
// that loses the original case of the tag.
var bookset = document.getElementsByTagName("Book");
// We need to create a "non-live" array to operate on. Since
// we'll be moving things around in this array, we can't use
// the read-only, live one returned by getElementsByTagName.
for (var i = 0; i < bookset.length; i++) {
books[i] = bookset[i];
}
collectInfo(books, sortableProps);
|