aboutsummaryrefslogtreecommitdiff
path: root/assets/search.js
diff options
context:
space:
mode:
authorAlex Shpak <alex-shpak@users.noreply.github.com>2019-07-16 14:34:02 +0200
committerAlex Shpak <alex-shpak@users.noreply.github.com>2019-08-06 11:33:42 +0200
commit1f3addcca5bad9ed12ed3e1df7ba75859c650249 (patch)
tree2e277c7fad1f89a4aafcafa89fc269e257540f09 /assets/search.js
parentdda0a0eab19457598b71f2b2b2f978b09d3f95c7 (diff)
Implement search, loading on demand
Diffstat (limited to 'assets/search.js')
-rw-r--r--assets/search.js76
1 files changed, 44 insertions, 32 deletions
diff --git a/assets/search.js b/assets/search.js
index 84e522a..63bb366 100644
--- a/assets/search.js
+++ b/assets/search.js
@@ -1,41 +1,53 @@
-addEventListener("load", function() {
- let input = document.querySelector("#book-search");
- let results = document.querySelector("#book-search-results");
-
- Promise.all([
- loadScript("{{ "lunr.min.js" | relURL }}"),
- loadScript("{{ "index.json" | relURL }}")
- ]).then(enableLunr);
-
- function enableLunr() {
- results.idx = lunr(function() {
- this.ref('href')
- this.field('title')
- this.field('content')
-
- window.lunrData.forEach(function (page) {
- this.add(page)
- }, this)
+{{- $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");
+ const dummy = document.querySelector("#book-search-dummy");
+
+ input.addEventListener("focus", init);
+
+ function init() {
+ loadScript("{{ $searchData.RelPermalink }}", function() {
+ input.disabled = false;
+ input.addEventListener("keyup", search);
+ search();
});
- input.addEventListener("keyup", search);
+ input.removeEventListener("focus", init);
}
function search() {
+ while (results.firstChild) {
+ results.removeChild(results.firstChild);
+ }
+
if (input.value) {
- var hits = results.idx.search(`${input.value}*`);
- results.innerHTML = JSON.stringify(hits);
- } else {
- results.innerHTML = '';
+ const hits = window.bookSearch.idx.search(`${input.value}*`);
+ hits.slice(0, 10).forEach(function(hit) {
+ const page = window.bookSearch.pages[hit.ref];
+ const li = dummy.querySelector("li").cloneNode(true),
+ a = li.querySelector("a");
+
+ a.href = page.href;
+ a.textContent = page.title;
+
+ results.appendChild(li);
+ });
}
}
- function loadScript(src) {
- return new Promise(function(resolve, reject) {
- let script = document.createElement('script');
- script.src = src;
- script.onload = () => resolve(script);
-
- document.head.append(script);
- });
+ function newLi(href, title) {
+
+
+ return li;
+ }
+
+ function loadScript(src, callback) {
+ const script = document.createElement("script");
+ script.defer = true;
+ script.src = src;
+ script.onload = callback;
+
+ document.head.append(script);
}
-});
+})();