hugo-book-theme/assets/search.js

67 lines
1.7 KiB
JavaScript
Raw Normal View History

2019-07-16 14:34:02 +02:00
{{- $searchData := resources.Get "search-data.js" | resources.ExecuteAsTemplate "search-data.js" . | resources.Minify | resources.Fingerprint }}
(function() {
const input = document.querySelector("#book-search-input");
const results = document.querySelector("#book-search-results");
input.addEventListener("focus", init);
2019-07-17 13:42:39 +02:00
input.addEventListener("keyup", search);
2019-07-16 14:34:02 +02:00
function init() {
input.removeEventListener("focus", init); //init once
input.required = true;
loadScript("{{ "lunr.min.js" | relURL }}");
loadScript("{{ $searchData.RelPermalink }}", function() {
input.readOnly = false;
input.required = false;
search();
});
2019-07-15 18:25:21 +02:00
}
function search() {
2019-07-16 14:34:02 +02:00
while (results.firstChild) {
results.removeChild(results.firstChild);
}
if (!input.value) {
return;
2019-07-17 13:42:39 +02:00
}
2019-07-16 14:34:02 +02:00
2019-07-17 13:42:39 +02:00
const terms = lunr.tokenizer(input.value);
const searchHits = window.bookSearch.idx.query(function(query) {
query.term(terms, {
boost: 100
2019-07-16 14:34:02 +02:00
});
2019-07-17 13:42:39 +02:00
query.term(terms, {
boost: 10,
wildcard: lunr.Query.wildcard.LEADING | lunr.Query.wildcard.TRAILING
2019-07-17 13:42:39 +02:00
});
query.term(terms, {
editDistance: 2
});
});
searchHits.slice(0, 10).forEach(function(hit) {
const page = window.bookSearch.pages[hit.ref];
const li = document.createElement("li"),
a = li.appendChild(document.createElement("a"));
2019-07-17 13:42:39 +02:00
a.href = page.href;
a.textContent = page.title;
results.appendChild(li);
});
2019-07-15 18:25:21 +02:00
}
2019-07-16 14:34:02 +02:00
function loadScript(src, callback) {
const script = document.createElement("script");
script.defer = true;
script.async = false;
2019-07-16 14:34:02 +02:00
script.src = src;
script.onload = callback;
document.head.append(script);
2019-07-15 18:25:21 +02:00
}
2019-07-16 14:34:02 +02:00
})();