mirror of
https://github.com/Damillora/Yuika
synced 2024-11-25 10:37:32 +00:00
43 lines
1.5 KiB
JavaScript
43 lines
1.5 KiB
JavaScript
async function searchPosts(query) {
|
|
const apiEndpoint = window.yurikoSearchEndpoint + "/api/article/search?"
|
|
const queryString = "q="
|
|
const pageString = "&page="
|
|
let page = 1
|
|
|
|
var data = await fetch(apiEndpoint + queryString + query + pageString + page)
|
|
var search = await data.json();
|
|
var result = "";
|
|
if (search.result) {
|
|
result = search.result.map(x => {
|
|
return `
|
|
<div class="menu__search-result">
|
|
<a href="${x.url}"><h2 class="menu__search-title">${x.title}</h2></a>
|
|
<p class="menu__search-desc">${x.excerpt}</p>
|
|
</div>
|
|
`;
|
|
}).join("");
|
|
}
|
|
|
|
document.getElementById("search-count").innerHTML = search.total + " results found";
|
|
document.getElementById("search-results").innerHTML = result;
|
|
}
|
|
|
|
|
|
if (window.yurikoSearchEndpoint != undefined) {
|
|
var el = document.getElementById("search-query");
|
|
el.addEventListener("input", function (e) {
|
|
var val = el.value;
|
|
if (val !== "") {
|
|
document.getElementById("site-header").classList.add("search-enabled")
|
|
document.getElementById("nav").classList.add("hidden")
|
|
searchPosts(val);
|
|
} else {
|
|
document.getElementById("site-header").classList.remove("search-enabled")
|
|
document.getElementById("nav").classList.remove("hidden")
|
|
|
|
document.getElementById("search-count").innerHTML = ``;
|
|
document.getElementById("search-results").innerHTML = ``;
|
|
}
|
|
});
|
|
}
|