-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexport_html_add_toc.js
142 lines (107 loc) · 3.31 KB
/
export_html_add_toc.js
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
<script type = "text/javascript" >
document.addEventListener("DOMContentLoaded", function()
{
var div1 = document.createElement("div");
div1.style.cssText = "clear:both";
// create TOC list
var outline = document.createElement("div");
outline.setAttribute("id", "outline-list");
outline.style.cssText = "border:solid 1px #ccc; background:#eee; min-width:200px;padding:4px 10px;";
var ele_p = document.createElement("p");
ele_p.style.cssText = "text-align: left; margin: 0;";
outline.appendChild(ele_p);
var ele_span = document.createElement("span");
// ele_span.style.cssText = "float: left;";
var ele_text = document.createTextNode("TOC");
ele_span.appendChild(ele_text);
var ele_a = document.createElement("a");
ele_a.appendChild(document.createTextNode("[+]"));
ele_a.setAttribute("href", "#");
ele_a.setAttribute("onclick", "javascript:return openct(this);");
ele_a.setAttribute("title", "Click to Open TOC");
ele_span.appendChild(ele_a);
ele_p.appendChild(ele_span);
var ul_top = document.createElement("ul"); // 顶级
ul_top.style.cssText = "display:none;margin-left:14px;padding-left:14px;line-height:160%;";
ul_top.setAttribute("id", "outline_ol");
outline.appendChild(ul_top);
var div1 = document.createElement("div");
div1.style.cssText = "clear:both";
document.body.insertBefore(outline, document.body.childNodes[0]);
// get all the headlines
var headers = document.querySelectorAll('h1,h2,h3,h4,h5,h6');
if (headers.length < 2)
return;
var old_h = 1;
var ul_array = new Array(7);
var ul_current = null;
ul_array[1] = ul_top;
for (var i = 0; i < headers.length; i++)
{
// get H* and prepare for the ordered list
var header = headers[i];
//header.setAttribute("id", "t" + i + header.tagName);
header.setAttribute("id", header.textContent);
var h = parseInt(header.tagName.substr(1), 10);
// assert 1<=h && h <= 6
ul_current = 0;
if (h < old_h)
{
for (var j = h+1; j <= 6; j++)
{
ul_array[j] = null;
}
ul_current = h;
}
else if (h == old_h)
{
ul_current = h;
}
else if (h > old_h)
{
ul_current = old_h + 1; /* 是old_h + 1的原因: h如果是old_h + 2 或者 + 3时,
我们依然按 + 1来做 */
}
if (ul_array[ul_current] == null)
{
ul_array[ul_current] = document.createElement("ul");
if (h>1)
{
ul_array[h-1].lastChild.appendChild(ul_array[ul_current]);
}
}
var elem_li = document.createElement("li");
ul_array[ul_current].appendChild(elem_li);
var a = document.createElement("a");
// set href for the TOC item
//a.setAttribute("href", "#t" + i + header.tagName);
a.setAttribute("href", "#" + header.textContent);
// TOC item text
a.innerHTML = "h" + h + header.textContent;
elem_li.appendChild(a);
old_h = h;
}
}
);
//
function openct(e)
{
if (e.innerHTML == '[+]')
{
// createTextNode
e.setAttribute('title', 'collapse');
e.innerHTML = '[-]';
var element = document.getElementById("outline_ol");
element.style.cssText = "margin-left:14px;padding-left:14px;line-height:160%;";
}
else
{
e.setAttribute('title', 'expand');
e.innerHTML = '[+]';
var element = document.getElementById("outline_ol");
element.style.cssText = "display:none;margin-left:14px;padding-left:14px;line-height:160%;";
}
e.blur();
return false;
}
</script>