made the search UI sort of modal

This commit is contained in:
Eli Mellen 2019-08-07 21:24:07 -04:00
parent 6cfd5af941
commit 952e5ca5a6
3 changed files with 47 additions and 28 deletions

View File

@ -12,13 +12,6 @@
<div id="wiki">
<img src="./src/assets/loading-bars.svg" alt="Loading..." style="margin: 0 auto; display: block; padding: 3em;">
</div>
<footer>
<form id="fakeSearchForm">
<label for="searchTerm">Search</label>
<input id="searchTerm" name="search" type="search" aria-placeholder="Search">
<input type="submit" value="Search">
</form>
</footer>
<script src="./src/js/Wiki.js"></script>
</body>
</html>

View File

@ -23,29 +23,28 @@ a[href^="http"]:after {
content: " " url('');
}
footer {
.searchContainer {
padding: 3em 0 1em 0;
font-size: 0.75em;
}
footer:before {
.searchContainer:before {
display: block;
}
footer form {
.searchContainer form {
display: block;
border-radius: 7px;
margin: 0 auto;
text-align: center;
}
footer form input {
.searchContainer form input {
color: #eee;
font-size: 0.75em;
font-weight: bolder;
}
footer form input[type="search"] {
.searchContainer form input[type="search"] {
padding: 1em;
border: none;
background-color: transparent;
@ -54,7 +53,7 @@ footer form input[type="search"] {
border-radius: 7px;
}
footer form input[type="submit"] {
.searchContainer form input[type="submit"] {
margin-top: 1em;
margin-left: 0;
padding: 1em;
@ -63,16 +62,23 @@ footer form input[type="submit"] {
border-radius: 7px;
}
footer form input[type="submit"]:hover {
.searchContainer form input[type="submit"]:hover {
cursor: pointer;
opacity: 0.5;
transition-duration: 0.3s;
}
footer form label {
.searchContainer form label {
display: none;
}
.searchClose, .searchOpen {
padding: 1em 0;
margin: 0 auto;
display: block;
text-align: center;
}
@media (prefers-color-scheme: light) {
body {

View File

@ -51,18 +51,13 @@ $.ajax({
const pageData = allWikiPages(wikiData); // all wiki pages
const indexPages = findIndexPages(pageData); // top-level index pages
$("#fakeSearchForm").on("submit", (event) => {
const searchTerm = $('#searchTerm').val();
router.navigate('buscar/' + searchTerm);
event.preventDefault();
});
router
.on('/', () => {
// return all index pages
buildIndex(wikiTitle, indexPages);
})
.on('buscar/:query', (params) => {
// search results
let idx = lunr(function () {
this.ref('slug');
this.field('body');
@ -79,6 +74,7 @@ $.ajax({
});
})
.on('lista', () => {
// hierarchical display of all pages as a tree/list
console.log('WIP');
})
.on(':slug', (params) => {
@ -181,12 +177,7 @@ function buildIndex(wikiTitle, wikiIndex) {
</section>`
);
});
}
function buildBreadCrumbs(familyTree) {
familyTree.reverse().forEach((page) => {
$('#breadCrumbs').append(`/ <a href="#${page.slug}">#${page.slug}</a>&nbsp;`);
});
buildFooter();
}
function buildDetail(page, childPages, pageData) {
@ -203,9 +194,38 @@ function buildDetail(page, childPages, pageData) {
buildFooter();
}
function buildBreadCrumbs(familyTree) {
familyTree.reverse().forEach((page) => {
$('#breadCrumbs').append(`/ <a href="#${page.slug}">#${page.slug}</a>&nbsp;`);
});
}
function listPages(pages) {
$('#wiki').append(`<ul id="pageList"></ul>`);
pages.forEach((page) => {
$('#pageList').append(`<li><a href="/#${page.slug}">${page.title}</a></li>`);
});
}
function buildFooter() {
$('#wiki').append(`<a href="javascript:void(0);" id="searchButton" class="searchOpen">Search</a>`);
$('#searchButton').click((event) => {
const currentPage = window.location.hash.replace('#','');
$('#wiki').empty().html(`
<div class="searchContainer">
<form id="searchForm">
<label for="searchTerm">Search</label>
<input id="searchTerm" name="search" type="search" aria-placeholder="Search">
<input type="submit" value="Search">
</form>
<a href="${currentPage}" class="searchClose" data-navigo>Close</a>
</div>
`);
$("#searchForm").on("submit", (event) => {
const searchTerm = $('#searchTerm').val();
router.navigate('buscar/' + searchTerm);
event.preventDefault();
});
event.preventDefault();
});
}