blog/themes/ficurinia/layouts/partials/js_paginator.html
2023-08-15 18:41:03 +02:00

65 lines
2.0 KiB
HTML

<script>
const tagsStr = '{{ i18n "tags" | safeJS }}'
function renderTags(tags) {
if (tags.length <= 0) return '';
let res = `| <span title=''> </span>`;
for (let tag of tags) {
// regular space
res += `<a href="/tags/${tag}">#${tag}</a>&#32;`;
}
return res;
}
function renderImage(image, link, alt) {
if (!image) return '';
return `<a href="${link}"><img src="${image}" alt="${alt}" /></a>`;
}
function renderSingleArticle(article) {
{{ if (.Site.Params.tagsInArticlePreview | default true) }}
const tags = renderTags(article.tags)
{{ else }}
const tags = ''
{{ end }}
{{ if .Site.Params.imageInArticlePreview }}
const img = renderImage(article.image, article.link, article.imageAlt)
{{ else }}
const img = ''
{{ end }}
{{ if (site.Params.articleSummary | default true) }}
const continueReadingStr = '{{ i18n "continueReading" | safeJS }}'
const summ = `<div class="articlePreview">
<p>${article.summary}</p>
<p><a href="${article.link}">${continueReadingStr} </a></p>
</div>`
{{ else }}
const summ = ''
{{ end }}
const dateStr = '{{ i18n "date" | safeJS }}'
return `
<article class="card postlistitem">
<div>
<h2>
<a href="${article.link}">${article.title}</a>
</h2>
<p class="date">
<span title='${dateStr}'> </span>
${article.date}
${tags}
</p>
${img}
${summ}
</div>
<hr />
</article>
`;
}
function renderArticles(articles) {
let rendered = articles.map(a => renderSingleArticle(a)).join('\n');
document.getElementById('postlist').innerHTML += rendered;
}
</script>