Adding preliminar working search engine.
This commit is contained in:
parent
78f56c1342
commit
5d63629264
@ -44,6 +44,74 @@ function addListenersSearch() {
|
|||||||
if (exitSearch !== null) {
|
if (exitSearch !== null) {
|
||||||
exitSearch.addEventListener('click', onExitSearch)
|
exitSearch.addEventListener('click', onExitSearch)
|
||||||
}
|
}
|
||||||
|
const search = document.querySelector('div.search-overlay div.search input');
|
||||||
|
if (search !== null) {
|
||||||
|
search.addEventListener('change', onSearchChange);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function onSearchChange() {
|
||||||
|
const search = document.querySelector('div.search-overlay div.search input');
|
||||||
|
const searchResults = document.querySelector('div.search-overlay div.search-results');
|
||||||
|
if (search === null || searchResults === null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const query = search.value;
|
||||||
|
const url = new URL(window.location.protocol
|
||||||
|
+ "//"
|
||||||
|
+ window.location.hostname
|
||||||
|
+ ":"
|
||||||
|
+ window.location.port
|
||||||
|
+ '/search.json');
|
||||||
|
url.searchParams.set('q', query);
|
||||||
|
fetch(url).then(async (res) => {
|
||||||
|
const json = await res.json()
|
||||||
|
if (!json.ok) {
|
||||||
|
noResults(searchResults);
|
||||||
|
return
|
||||||
|
}
|
||||||
|
console.log(json.searchObjects.length)
|
||||||
|
if (json.searchObjects.length < 1) {
|
||||||
|
noResults(searchResults);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
showResults(searchResults, json.searchObjects);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
function showResults(searchResults, searchObjects) {
|
||||||
|
searchObjects.innerHTML = "";
|
||||||
|
for (let searchObject of searchObjects) {
|
||||||
|
const searchResultContainer = document.createElement('div')
|
||||||
|
searchResultContainer.classList.add('search-result')
|
||||||
|
const title = document.createElement('b')
|
||||||
|
const url = document.createElement('a')
|
||||||
|
const content = document.createElement('p')
|
||||||
|
|
||||||
|
title.innerText = searchObject.title
|
||||||
|
if (searchObject.url.match(/^\//)) {
|
||||||
|
searchObject.url = window.location.protocol
|
||||||
|
+ "//" + window.location.hostname
|
||||||
|
+ ":" + window.location.port
|
||||||
|
+ searchObject.url
|
||||||
|
}
|
||||||
|
url.href = searchObject.url
|
||||||
|
url.innerText = searchObject.url
|
||||||
|
content.innerText = searchObject.content
|
||||||
|
|
||||||
|
searchResultContainer.appendChild(title)
|
||||||
|
searchResultContainer.appendChild(document.createElement('br'))
|
||||||
|
searchResultContainer.appendChild(url)
|
||||||
|
searchResultContainer.appendChild(content)
|
||||||
|
searchResults.appendChild(searchResultContainer)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function noResults(searchResults) {
|
||||||
|
searchResults.innerHTML = ""
|
||||||
|
const p = document.createElement('p')
|
||||||
|
p.innerText = 'No se han encontrado resultados.'
|
||||||
|
searchResults.appendChild(p)
|
||||||
}
|
}
|
||||||
|
|
||||||
function onExitSearch() {
|
function onExitSearch() {
|
||||||
|
@ -15,9 +15,12 @@ body {
|
|||||||
width: 100%;
|
width: 100%;
|
||||||
background: white;
|
background: white;
|
||||||
z-index: 3;
|
z-index: 3;
|
||||||
top: 0; }
|
top: 0;
|
||||||
|
flex-direction: column; }
|
||||||
body div.search-overlay.active {
|
body div.search-overlay.active {
|
||||||
display: flex; }
|
display: flex; }
|
||||||
|
body div.search-overlay div.search-results {
|
||||||
|
margin: 7px; }
|
||||||
body div.search-overlay div.bounding-search-bar {
|
body div.search-overlay div.bounding-search-bar {
|
||||||
margin: 7px;
|
margin: 7px;
|
||||||
width: calc(100% - 20px);
|
width: calc(100% - 20px);
|
||||||
|
@ -22,9 +22,13 @@ body {
|
|||||||
background: white;
|
background: white;
|
||||||
z-index: 3;
|
z-index: 3;
|
||||||
top: 0;
|
top: 0;
|
||||||
|
flex-direction: column;
|
||||||
&.active {
|
&.active {
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
|
div.search-results {
|
||||||
|
margin: 7px;
|
||||||
|
}
|
||||||
div.bounding-search-bar {
|
div.bounding-search-bar {
|
||||||
margin: 7px;
|
margin: 7px;
|
||||||
width: calc(100% - 20px);
|
width: calc(100% - 20px);
|
||||||
|
File diff suppressed because one or more lines are too long
@ -39,6 +39,8 @@
|
|||||||
<img alt="Exit search" src="/img/exit.svg"/>
|
<img alt="Exit search" src="/img/exit.svg"/>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="search-results">
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="complete-container">
|
<div class="complete-container">
|
||||||
%= include 'page/_mobile_menu', categories => $categories
|
%= include 'page/_mobile_menu', categories => $categories
|
||||||
|
Loading…
Reference in New Issue
Block a user