-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdoc-search.html
executable file
·143 lines (126 loc) · 5.15 KB
/
doc-search.html
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
143
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1">
<title>Search</title>
<link rel="preload stylesheet" as="style" href="https://cdnjs.cloudflare.com/ajax/libs/10up-sanitize.css/11.0.1/sanitize.min.css" integrity="sha256-PK9q560IAAa6WVRRh76LtCaI8pjTJ2z11v0miyNNjrs=" crossorigin>
<link rel="preload stylesheet" as="style" href="https://cdnjs.cloudflare.com/ajax/libs/10up-sanitize.css/11.0.1/typography.min.css" integrity="sha256-7l/o7C8jubJiy74VsKTidCy1yBkRtiUGbVkYBylBqUg=" crossorigin>
<style>
body {margin: 0 1em;}
footer,
#search-status {
font: 14px normal;
color: grey;
}
footer {text-align: right;}
a {
color: #058;
text-decoration: none;
transition: color .3s ease-in-out;
}
a:hover {color: #e82;}
li {padding-top: 10px;}
</style>
<base target="_parent">
</head>
<body>
<noscript>
JavaScript is not supported/enabled in your browser. The search feature won't work.
</noscript>
<main>
<h3 id="search-status"></h3>
<ul id="search-results"></ul>
</main>
<footer>
<p>Search results provided by <a href="https://lunrjs.com">Lunr.js</a></p>
</footer>
<script src="index.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/lunr.js/2.3.8/lunr.min.js" integrity="sha512-HiJdkRySzXhiUcX2VweXaiy8yeY212ep/j51zR/z5IPCX4ZUOxaf6naJ/0dQL/2l+ZL+B9in/u4nT8QJZ/3mig==" crossorigin></script>
<script>
'use strict';
const lunr_index = build_index();
search(decodeURIComponent(new URL(window.location).hash.substring(1)));
function set_status(message) {
document.getElementById('search-status').textContent = message;
}
async function build_index() {
return lunr(function () {
this.ref('i');
this.field('name', {boost: 10});
this.field('ref', {boost: 5});
this.field('doc');
this.metadataWhitelist = ['position'];
INDEX.forEach((doc, i) => {
const parts = doc.ref.split('.');
doc['name'] = parts[parts.length - 1];
doc['i'] = i;
this.add(doc);
}, this);
});
}
function search(query) {
_search(query).catch(err => {
set_status("Something went wrong. See development console for details.");
throw err;
});
}
async function _search(query) {
if (!query) {
set_status('No query provided, so there is nothing to search.');
return;
}
const fuzziness = 1;
if (fuzziness) {
query = query.split(/\s+/)
.map(str => str.includes('~') ? str : str + '~' + fuzziness).join(' ');
}
const results = (await lunr_index).search(query);
if (!results.length) {
set_status('No results match your query.');
return;
}
set_status(
'Search for "' + encodeURIComponent(query) + '" yielded ' + results.length + ' ' +
(results.length === 1 ? 'result' : 'results') + ':');
results.forEach(function (result) {
const dobj = INDEX[parseInt(result.ref)];
const docstring = dobj.doc;
// PANDA-docs specific change: remove pandare/ from start of URL
const url = URLS[dobj.url].replace("pandare/", "") + '#' + dobj.ref;
console.log(url)
const pretty_name = dobj.ref + (dobj.func ? '()' : '');
let text = '';
if (docstring) {
text = Object.values(result.matchData.metadata)
.filter(({doc}) => doc !== undefined)
.map(({doc: {position}}) => {
return position.map(([start, length]) => {
const PAD_CHARS = 30;
const end = start + length;
return [
start,
(start - PAD_CHARS > 0 ? '…' : '') +
docstring.substring(start - PAD_CHARS, start) +
'<mark>' + docstring.slice(start, end) + '</mark>' +
docstring.substring(end, end + PAD_CHARS) +
(end + PAD_CHARS < docstring.length ? '…' : '')
];
});
})
.flat()
.sort(([pos1,], [pos2,]) => pos1 - pos2)
.map(([, text]) => text)
.join('')
.replace(/……/g, '…');
}
if (text)
text = '<div>' + text + '</div>';
text = '<a href="' + url + '"><code>' + pretty_name + '</code></a>' + text;
const li = document.createElement('li');
li.innerHTML = text;
document.getElementById('search-results').appendChild(li);
});
}
</script>
</body>