mirror of
https://github.com/McShelby/hugo-theme-relearn.git
synced 2025-01-31 00:47:13 +00:00
feat: add search support
This commit is contained in:
parent
60627a24a1
commit
c645b07402
9 changed files with 1732 additions and 7 deletions
|
@ -14,7 +14,6 @@
|
|||
<div style="left: -1000px; overflow: scroll; position: absolute; top: -1000px; border: none; box-sizing: content-box; height: 200px; margin: 0px; padding: 0px; width: 200px;">
|
||||
<div style="border: none; box-sizing: content-box; height: 200px; margin: 0px; padding: 0px; width: 200px;"></div>
|
||||
</div>
|
||||
<script src="/js/jquery-2.x.min.js"></script>
|
||||
<script src="/js/clipboard.min.js"></script>
|
||||
<script src="/js/perfect-scrollbar.min.js"></script>
|
||||
<script src="/js/perfect-scrollbar.jquery.min.js"></script>
|
||||
|
|
|
@ -13,8 +13,10 @@
|
|||
<link href="/css/hybrid.css" rel="stylesheet">
|
||||
<link href="/css/featherlight.min.css" rel="stylesheet">
|
||||
<link href="/css/perfect-scrollbar.min.css" rel="stylesheet">
|
||||
<link href="/css/horsey.css" rel="stylesheet">
|
||||
<link href="/css/theme.css" rel="stylesheet">
|
||||
<link href="/css/hugo-theme.css" rel="stylesheet">
|
||||
<script src="/js/jquery-2.x.min.js"></script>
|
||||
<style type="text/css">:root #header + #content > #left > #rlblock_left
|
||||
{display:none !important;}</style>
|
||||
{{ partial "style.html" . }}
|
||||
|
|
|
@ -3,11 +3,7 @@
|
|||
<div id="header">
|
||||
{{ partial "logo.html" . }}
|
||||
{{ if .Site.Params.search }}
|
||||
<div class="searchbox">
|
||||
<label for="search-by"><i class="fa fa-search"></i></label>
|
||||
<input id="search-by" type="text" placeholder="Search Documentation" data-search-input="/lunr.json/query">
|
||||
<span data-search-clear=""><i class="fa fa-close"></i></span>
|
||||
</div>
|
||||
{{ partial "search.html" . }}
|
||||
{{ end }}
|
||||
</div>
|
||||
</div>
|
||||
|
|
114
layouts/partials/search.html
Normal file
114
layouts/partials/search.html
Normal file
|
@ -0,0 +1,114 @@
|
|||
<div class="searchbox">
|
||||
<label for="search-by"><i class="fa fa-search"></i></label>
|
||||
<input id="search-by" type="text" placeholder="Search Documentation">
|
||||
<span data-search-clear=""><i class="fa fa-close"></i></span>
|
||||
</div>
|
||||
<script type="text/javascript" src="/js/lunr.min.js"></script>
|
||||
<script type="text/javascript" src="/js/horsey.js"></script>
|
||||
<script type="text/javascript">
|
||||
var lunrIndex,
|
||||
pagesIndex;
|
||||
|
||||
// Initialize lunrjs using our generated index file
|
||||
function initLunr() {
|
||||
// First retrieve the index file
|
||||
$.getJSON("/json/search.json")
|
||||
.done(function(index) {
|
||||
pagesIndex = index;
|
||||
console.log("index:", pagesIndex);
|
||||
|
||||
// Set up lunrjs by declaring the fields we use
|
||||
// Also provide their boost level for the ranking
|
||||
lunrIndex = lunr(function() {
|
||||
this.field("title", {
|
||||
boost: 15
|
||||
});
|
||||
this.field("tags", {
|
||||
boost: 10
|
||||
});
|
||||
this.field("content", {
|
||||
boost: 5
|
||||
});
|
||||
|
||||
// ref is the result item identifier (I chose the page URL)
|
||||
this.ref("uri");
|
||||
});
|
||||
|
||||
// Feed lunr with each file and let lunr actually index them
|
||||
pagesIndex.forEach(function(page) {
|
||||
lunrIndex.add(page);
|
||||
});
|
||||
})
|
||||
.fail(function(jqxhr, textStatus, error) {
|
||||
var err = textStatus + ", " + error;
|
||||
console.error("Error getting Hugo index flie:", err);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Trigger a search in lunr and transform the result
|
||||
*
|
||||
* @param {String} query
|
||||
* @return {Array} results
|
||||
*/
|
||||
function search(query) {
|
||||
// Find the item in our index corresponding to the lunr one to have more info
|
||||
// Lunr result:
|
||||
// {ref: "/section/page1", score: 0.2725657778206127}
|
||||
// Our result:
|
||||
// {title:"Page1", href:"/section/page1", ...}
|
||||
return lunrIndex.search(query).map(function(result) {
|
||||
return pagesIndex.filter(function(page) {
|
||||
return page.uri === result.ref;
|
||||
})[0];
|
||||
});
|
||||
}
|
||||
|
||||
// Let's get started
|
||||
initLunr();
|
||||
$( document ).ready(function() {
|
||||
horsey($("#search-by").get(0), {
|
||||
suggestions: function (value, done) {
|
||||
var query = $("#search-by").val();
|
||||
if (query.length < 3) {
|
||||
done([]);
|
||||
} else {
|
||||
var results = search(query);
|
||||
console.log(results);
|
||||
done(results);
|
||||
}
|
||||
},
|
||||
filter: function (q, suggestion) {
|
||||
return true;
|
||||
},
|
||||
set: function (value) {
|
||||
location.href=value.href;
|
||||
},
|
||||
render: function (li, suggestion) {
|
||||
var uri = suggestion.uri.substring(1,suggestion.uri.length);
|
||||
var indexOfIndex = uri.lastIndexOf("/index");
|
||||
if (indexOfIndex == -1) {
|
||||
indexOfIndex = uri.length;
|
||||
}
|
||||
var href = uri.substring(uri.indexOf("/"), indexOfIndex);
|
||||
suggestion.href = href;
|
||||
|
||||
|
||||
var query = $("#search-by").val();
|
||||
var numWords = 2;
|
||||
var text = suggestion.content.match("(?:\\s?(?:[\\w]+)\\s?){"+numWords+"}"+query+"(?:\\s?(?:[\\w]+)\\s?){"+numWords+"}");
|
||||
suggestion.context = text;
|
||||
var image = '<div>' + '» ' + suggestion.title + '</div><div style="font-size:12px">' + suggestion.context +'</div>';
|
||||
li.innerHTML = image;
|
||||
},
|
||||
limit: 10
|
||||
});
|
||||
|
||||
$("#search-by").on("horsey-selected", function (a, b){
|
||||
console.log(a);
|
||||
console.log(a);
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
</script>
|
32
static/css/horsey.css
Normal file
32
static/css/horsey.css
Normal file
|
@ -0,0 +1,32 @@
|
|||
.sey-list {
|
||||
display: none;
|
||||
position: absolute;
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
list-style-type: none;
|
||||
box-shadow: 1px 2px 6px;
|
||||
background-color: #fff;
|
||||
color: #333;
|
||||
transition: left 0.1s ease-in-out;
|
||||
}
|
||||
.sey-show {
|
||||
display: block;
|
||||
}
|
||||
.sey-hide {
|
||||
display: none;
|
||||
}
|
||||
.sey-item {
|
||||
cursor: pointer;
|
||||
overflow: hidden;
|
||||
white-space: nowrap;
|
||||
text-overflow: ellipsis;
|
||||
padding: 7px;
|
||||
}
|
||||
.sey-item:hover {
|
||||
background-color: #444;
|
||||
color: #fff;
|
||||
}
|
||||
.sey-selected {
|
||||
background-color: #333;
|
||||
color: #fff;
|
||||
}
|
|
@ -988,7 +988,6 @@ pre .copy-to-clipboard:hover {
|
|||
transform-style: preserve-3d;
|
||||
}
|
||||
|
||||
/* Add checkmark icon align to right and color*/
|
||||
#sidebar ul.topics > li > a .read-icon {
|
||||
margin-top: 9px;
|
||||
}
|
||||
|
@ -1005,4 +1004,8 @@ pre .copy-to-clipboard:hover {
|
|||
display: inline;
|
||||
}
|
||||
|
||||
#searchResults {
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
/*# sourceMappingURL=theme.css.map */
|
||||
|
|
1571
static/js/horsey.js
Normal file
1571
static/js/horsey.js
Normal file
File diff suppressed because one or more lines are too long
7
static/js/lunr.min.js
vendored
Normal file
7
static/js/lunr.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
1
static/json/search.json
Normal file
1
static/json/search.json
Normal file
|
@ -0,0 +1 @@
|
|||
[]
|
Loading…
Add table
Reference in a new issue