diff --git a/static/skin/index.css b/static/skin/index.css index 800aca210..9d3633bdd 100644 --- a/static/skin/index.css +++ b/static/skin/index.css @@ -134,6 +134,24 @@ body { position: relative; } +.tagFilterLabel { + width: max-content; + padding-left: 8px; + padding-right: 8px; + margin: 0 0 0 17px; + background-color: transparent; + color: #909090; + display: none; +} + +.tag__link { + color: #909090; +} + +.tag__link:hover { + font-weight: bolder; +} + .book__list { position: relative; } @@ -144,6 +162,8 @@ body { .book__link { text-decoration: none; + grid-column: 1 / 3; + grid-row: 1 / 3; } .book__wrapper { @@ -165,6 +185,12 @@ body { transform: scale(1.07); } +.book__link__wrapper { + display: grid; + grid-template-columns: 65px 1fr; + grid-template-rows: 70px 120px 1fr 1fr; +} + .book__icon { background-image: url(''); background-repeat: no-repeat; @@ -249,7 +275,6 @@ body { text-align: end; font-size: 1.1rem; justify-content: flex-end; - color: #909090; font-family: roboto; margin-right: 10px; margin-top: 10px; @@ -424,7 +449,7 @@ body { @media screen and (max-width: 590px) { .kiwixNav { - height: 257px; + height: 285px; } .kiwixHomeBody { @@ -436,10 +461,14 @@ body { } .kiwixButton { - margin: 19px 0; + margin: 15px 0; width: 229px; } + .tagFilterLabel { + margin: 15px 0 0 0; + } + .kiwixNav__filters { grid-template-columns: 1fr; } diff --git a/static/skin/index.js b/static/skin/index.js index 267da4098..b7aca08b9 100644 --- a/static/skin/index.js +++ b/static/skin/index.js @@ -91,9 +91,16 @@ const langCode = getInnerHtml(book, 'language'); const language = languages[langCode]; const tags = getInnerHtml(book, 'tags'); - let tagHtml = tags.split(';').filter(tag => {return !(tag.split(':')[0].startsWith('_'))}) - .map((tag) => {return tag.charAt(0).toUpperCase() + tag.slice(1)}) - .join(' | ').replace(/_/g, ' '); + let tagList = tags.split(';').filter(tag => {return !(tag.split(':')[0].startsWith('_'))}) + .map((tag) => {return tag.charAt(0).toUpperCase() + tag.slice(1)}); + newParams = new URLSearchParams(window.location.search); + newParams.delete('tag'); + const currentLink = `${window.location.href.split('?')[0]}?${newParams.toString()}`; + tagList = tagList.map((tagValue) => { + tagValue = tagValue.toLowerCase().replace(/\s/g, '_'); + return `${humanFriendlyTitle(tagValue)}` + }); + let tagHtml = tagList.join(' | '); let downloadLink; let zimSize = 0; try { @@ -113,17 +120,21 @@ } const faviconAttr = iconUrl != undefined ? `style="background-image: url('${iconUrl}')"` : ''; const languageAttr = langCode != '' ? `title="${language}" aria-label="${language}"` : 'style="background-color: transparent"'; - divTag.innerHTML = ` + divTag.innerHTML = `
+ + +
${getLanguageCodeToDisplay(langCode)}
${tagHtml}
-
`; + `; return divTag; } @@ -372,6 +383,16 @@ } } + function addTagElement(tagValue) { + const tagElement = document.getElementsByClassName('tagFilterLabel')[0]; + tagElement.style.display = 'inline-block'; + tagElement.innerHTML = `🏷 ${tagValue}`; + tagElement.addEventListener('click', (e) => { + tagElement.style.display = 'none'; + resetAndFilter('tag', ''); + }); + } + window.addEventListener('resize', (event) => { if (timer) {clearTimeout(timer)} timer = setTimeout(() => { @@ -407,6 +428,7 @@ document.querySelectorAll('.filter').forEach(filter => { filter.addEventListener('change', () => {resetAndFilter(filter.name, filter.value)}); }); + if (filters) { window.history.pushState({}, null, `${window.location.href.split('?')[0]}?${params.toString()}`); } @@ -415,6 +437,9 @@ if (selectBox) { selectBox.value = value } + if (key == 'tag' && value.trim() != '') { + addTagElement(humanFriendlyTitle(value)); + } }); document.getElementById('kiwixSearchForm').onsubmit = (event) => {event.preventDefault()}; if (!window.location.search) { diff --git a/static/templates/index.html b/static/templates/index.html index 7d6573c53..f9a518aa5 100644 --- a/static/templates/index.html +++ b/static/templates/index.html @@ -58,6 +58,7 @@
+