From cfaa9504a1f11e60615863db4cdea539a7ecfdeb Mon Sep 17 00:00:00 2001 From: Christoph Cullmann Date: Thu, 11 Apr 2019 22:37:27 +0200 Subject: [PATCH] implement client side site search see https://gist.github.com/eddiewebb/735feb48f50f0ddd65ae5606a1cb41ae --- content/search.md | 9 +++ layouts/_default/index.json | 5 ++ layouts/_default/search.html | 25 ++++++++ static/search.js | 108 +++++++++++++++++++++++++++++++++++ 4 files changed, 147 insertions(+) create mode 100644 content/search.md create mode 100644 layouts/_default/index.json create mode 100644 layouts/_default/search.html create mode 100644 static/search.js diff --git a/content/search.md b/content/search.md new file mode 100644 index 0000000..dfb737b --- /dev/null +++ b/content/search.md @@ -0,0 +1,9 @@ +--- +title: "Search Results" +sitemap: + priority : 0.1 +layout: "search" +--- + +dummy page +howto for search: https://gist.github.com/eddiewebb/735feb48f50f0ddd65ae5606a1cb41ae diff --git a/layouts/_default/index.json b/layouts/_default/index.json new file mode 100644 index 0000000..c93f805 --- /dev/null +++ b/layouts/_default/index.json @@ -0,0 +1,5 @@ +{{- $.Scratch.Add "index" slice -}} +{{- range .Site.RegularPages -}} + {{- $.Scratch.Add "index" (dict "title" .Title "tags" .Params.tags "categories" .Params.categories "contents" .Plain "permalink" .Permalink) -}} +{{- end -}} +{{- $.Scratch.Get "index" | jsonify -}} diff --git a/layouts/_default/search.html b/layouts/_default/search.html new file mode 100644 index 0000000..3222588 --- /dev/null +++ b/layouts/_default/search.html @@ -0,0 +1,25 @@ +{{ define "content" }} + + + + + +
+
+ +
+
+

Matching pages

+
+
+ + + +{{ end }} diff --git a/static/search.js b/static/search.js new file mode 100644 index 0000000..add8549 --- /dev/null +++ b/static/search.js @@ -0,0 +1,108 @@ +summaryInclude=60; +var fuseOptions = { + shouldSort: true, + includeMatches: true, + threshold: 0.0, + tokenize:true, + location: 0, + distance: 100, + maxPatternLength: 32, + minMatchCharLength: 1, + keys: [ + {name:"title",weight:0.8}, + {name:"contents",weight:0.5}, + {name:"tags",weight:0.3}, + {name:"categories",weight:0.3} + ] +}; + + +var searchQuery = param("s"); +if(searchQuery){ + $("#search-query").val(searchQuery); + executeSearch(searchQuery); +}else { + $('#search-results').append("

Please enter a word or phrase above

"); +} + + + +function executeSearch(searchQuery){ + $.getJSON( "/index.json", function( data ) { + var pages = data; + var fuse = new Fuse(pages, fuseOptions); + var result = fuse.search(searchQuery); + console.log({"matches":result}); + if(result.length > 0){ + populateResults(result); + }else{ + $('#search-results').append("

No matches found

"); + } + }); +} + +function populateResults(result){ + $.each(result,function(key,value){ + var contents= value.item.contents; + var snippet = ""; + var snippetHighlights=[]; + var tags =[]; + if( fuseOptions.tokenize ){ + snippetHighlights.push(searchQuery); + }else{ + $.each(value.matches,function(matchKey,mvalue){ + if(mvalue.key == "tags" || mvalue.key == "categories" ){ + snippetHighlights.push(mvalue.value); + }else if(mvalue.key == "contents"){ + start = mvalue.indices[0][0]-summaryInclude>0?mvalue.indices[0][0]-summaryInclude:0; + end = mvalue.indices[0][1]+summaryInclude