diff --git a/static/skin/index.css b/static/skin/index.css
index 800aca210..8443feacb 100644
--- a/static/skin/index.css
+++ b/static/skin/index.css
@@ -134,6 +134,27 @@ body {
position: relative;
}
+.tagFilterLabel {
+ width: max-content;
+ padding: 10px;
+ font-family: roboto;
+ font-size: 12px;
+ margin: 0 0 0 17px;
+ text-align: center;
+ background-color: transparent;
+ color: #909090;
+ display: none;
+}
+
+.tag__link {
+ cursor: pointer;
+ color: #909090;
+}
+
+.tag__link:hover {
+ font-weight: bolder;
+}
+
.book__list {
position: relative;
}
@@ -144,6 +165,8 @@ body {
.book__link {
text-decoration: none;
+ grid-column: 1 / 3;
+ grid-row: 1 / 3;
}
.book__wrapper {
@@ -165,6 +188,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 +278,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 +452,7 @@ body {
@media screen and (max-width: 590px) {
.kiwixNav {
- height: 257px;
+ height: 285px;
}
.kiwixHomeBody {
@@ -436,10 +464,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 a6bcdd744..83ad0e8c8 100644
--- a/static/skin/index.js
+++ b/static/skin/index.js
@@ -77,6 +77,13 @@
return queryNode != null ? queryNode.innerHTML : "";
}
+ function generateTagLink(tagValue) {
+ tagValue = tagValue.toLowerCase();
+ const humanFriendlyTagValue = humanFriendlyTitle(tagValue);
+ const tagMessage = `Filter by tag "${humanFriendlyTagValue}"`;
+ return `${humanFriendlyTagValue}`
+ }
+
function generateBookHtml(book, sort = false) {
const link = book.querySelector('link[type="text/html"]').getAttribute('href');
let iconUrl;
@@ -91,9 +98,9 @@
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, ' ');
+ const tagList = tags.split(';').filter(tag => {return !(tag.startsWith('_'))});
+ const tagFilterLinks = tagList.map((tagValue) => generateTagLink(tagValue));
+ const tagHtml = tagFilterLinks.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 = `