feat: Implement RSS Feed #12

Merged
aniva merged 6 commits from post/rss into main 2024-10-11 01:36:24 -07:00
4 changed files with 16 additions and 7 deletions
Showing only changes of commit f1cf008405 - Show all commits

View File

@ -38,7 +38,7 @@ export async function getPosts(tag: string | null = null) : Promise<Post[]> {
return posts;
}
export async function getTags() : Promise<Set<string>> {
export async function getTags() : Promise<Map<string, number>> {
const allPostFiles = import.meta.glob('$content/post/*.md');
const iterablePostFiles = Object.entries(allPostFiles);
@ -48,5 +48,7 @@ export async function getTags() : Promise<Set<string>> {
return metadata.tags;
})
);
return new Set(allPosts.flat());
return allPosts.flat().reduce((acc: Map<string, number>, curr: string) => {
return acc[curr] ? ++acc[curr] : acc[curr] = 1, acc
}, new Map());
}

View File

@ -12,15 +12,22 @@
<h1>Tags</h1>
<hr class="separator" />
<div id="catalog" class="content">
{#each allTags as tag}
<a class="tag" href="/tag/{tag}">{tag}</a>
<div id="tags">
{#each Object.entries(allTags) as [tag, occ]}
<div class="tag">
<a href="/tag/{tag}">{tag}</a>
({occ})
</div>
{/each}
</div>
<hr class="separator" />
<style>
#tags {
display: inline-block;
}
.tag {
display: inline-block;
margin-left: 1em;
margin-right: 1em;
}

View File

@ -2,6 +2,6 @@ import type { PageLoad } from './$types';
import { getTags } from '$lib/posts';
export const load: PageLoad = async (_) => {
const allTags = await getTags();
let allTags = await getTags();
return { allTags };
};

View File

@ -10,7 +10,7 @@
<title>{name} | {siteMetadata.blogName}</title>
</svelte:head>
<h1>{name}</h1>
<h1>{name} ({posts.length})</h1>
<hr class="separator" />
<ul id="catalog" class="content">