add search by title
This commit is contained in:
parent
10ae1fcf36
commit
67f79b8474
8
assets/css/search.css
Normal file
8
assets/css/search.css
Normal file
|
@ -0,0 +1,8 @@
|
|||
#search {
|
||||
height: 50px;
|
||||
width: 100%;
|
||||
padding: 8px;
|
||||
border: 2px solid;
|
||||
line-height: 1.6;
|
||||
font-size: 1.25rem;
|
||||
}
|
21
assets/js/search.js
Normal file
21
assets/js/search.js
Normal file
|
@ -0,0 +1,21 @@
|
|||
(function () {
|
||||
function onEvent() {
|
||||
var filter = search.value.toUpperCase();
|
||||
var list = document.getElementById("list");
|
||||
var listItems = list.getElementsByTagName("li");
|
||||
for (i = 0; i < listItems.length; i++) {
|
||||
var item = listItems[i];
|
||||
var text = item.innerText.toUpperCase();
|
||||
if (text.indexOf(filter) > -1) {
|
||||
item.style.display = "";
|
||||
} else {
|
||||
item.style.display = "none";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
var search = document.getElementById("search");
|
||||
if (search) {
|
||||
search.addEventListener("keyup", onEvent);
|
||||
}
|
||||
})();
|
|
@ -26,6 +26,7 @@ params:
|
|||
katex: true
|
||||
darkThemeAsDefault: false
|
||||
hideHeaderLinks: false
|
||||
search: true
|
||||
# A list of custom css files can be provided, which must be placed inside
|
||||
# 'static/'.
|
||||
# This is useful to override just specific css classes, instead of copying
|
||||
|
|
|
@ -1,12 +1,25 @@
|
|||
{{ define "main" }}
|
||||
<main id="main">
|
||||
<main id="main">
|
||||
<h1>{{ .Title }}</h1>
|
||||
<ul class="patterns-list">
|
||||
{{ if site.Params.search }}
|
||||
<input
|
||||
id="search"
|
||||
type="text"
|
||||
placeholder="Search by title..."
|
||||
aria-label="Search by title"
|
||||
/>
|
||||
{{ end }}
|
||||
<ul class="patterns-list" id="list">
|
||||
{{ range .Pages.ByPublishDate.Reverse }}
|
||||
<li>
|
||||
<h2>
|
||||
<a href="{{ .Permalink }}">
|
||||
<svg class="bookmark" aria-hidden="true" viewBox="0 0 40 50" focusable="false">
|
||||
<svg
|
||||
class="bookmark"
|
||||
aria-hidden="true"
|
||||
viewBox="0 0 40 50"
|
||||
focusable="false"
|
||||
>
|
||||
<use xlink:href="#bookmark"></use>
|
||||
</svg>
|
||||
{{ .Title }}
|
||||
|
@ -15,5 +28,5 @@
|
|||
</li>
|
||||
{{ end }}
|
||||
</ul>
|
||||
</main>
|
||||
</main>
|
||||
{{ end }}
|
||||
|
|
|
@ -3,3 +3,10 @@
|
|||
{{ $templateDomScripts := resources.Get "js/template-dom-scripts.js" }}
|
||||
{{ $domScripts := $templateDomScripts | resources.ExecuteAsTemplate "js/dom-scripts.js" . }}
|
||||
<script src="{{ $domScripts.Permalink }}"></script>
|
||||
|
||||
{{ if site.Params.search }}
|
||||
{{ $searchJs := resources.Get "js/search.js" | fingerprint }}
|
||||
<script src="{{ $searchJs.RelPermalink }}"></script>
|
||||
{{ $searchCss := resources.Get "css/search.css" | fingerprint }}
|
||||
<link rel="stylesheet" href="{{ $searchCss.RelPermalink }}"></link>
|
||||
{{ end }}
|
||||
|
|
Loading…
Reference in New Issue
Block a user