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() {
|
2019-07-17 17:56:12 +02:00
|
|
|
input.removeEventListener("focus", init); //init once
|
|
|
|
input.required = true;
|
|
|
|
|
|
|
|
loadScript("{{ "lunr.min.js" | relURL }}");
|
2019-07-17 14:43:30 +02:00
|
|
|
loadScript("{{ $searchData.RelPermalink }}", function() {
|
|
|
|
input.readOnly = false;
|
2019-07-17 17:56:12 +02:00
|
|
|
input.required = false;
|
2019-07-17 14:43:30 +02:00
|
|
|
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);
|
|
|
|
}
|
|
|
|
|
2019-07-17 17:56:12 +02:00
|
|
|
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, {
|
2019-07-17 17:56:12 +02:00
|
|
|
boost: 100
|
2019-07-16 14:34:02 +02:00
|
|
|
});
|
2019-07-17 13:42:39 +02:00
|
|
|
query.term(terms, {
|
|
|
|
boost: 10,
|
2019-07-17 17:56:12 +02:00
|
|
|
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];
|
2019-07-17 17:56:12 +02:00
|
|
|
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;
|
2019-10-03 13:56:41 +02:00
|
|
|
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
|
|
|
})();
|