feat: order blog entrys by date and direct link if source is available
This commit is contained in:
@@ -3,23 +3,30 @@
|
|||||||
import type { SvelteComponent } from 'svelte';
|
import type { SvelteComponent } from 'svelte';
|
||||||
import './style-entries.css';
|
import './style-entries.css';
|
||||||
|
|
||||||
const blog_entries: [string, SvelteComponent][] = Object.entries(
|
let blog_entries: [string, SvelteComponent][] = Object.entries(
|
||||||
import.meta.glob('/src/routes/blogs/**/+page.svx', { eager: true })
|
import.meta.glob('/src/routes/blogs/**/+page.svx', { eager: true })
|
||||||
).map(([key, value]) => [
|
).map(([key, value]) => [
|
||||||
key.split('/src/routes').pop()?.split('/+page.svx').slice(0, -1).pop() as string,
|
key.split('/src/routes').pop()?.split('/+page.svx').slice(0, -1).pop() as string,
|
||||||
value as MDsveXComponent
|
value as MDsveXComponent
|
||||||
]);
|
]).map(([link,val])=>
|
||||||
|
typeof val.metadata?.src !== 'undefined' ? [val.metadata?.src, val] : [link,val]
|
||||||
|
).map(([link,val])=>{
|
||||||
|
if(val.metadata)
|
||||||
|
val.metadata.date = Date.parse(val.metadata?.date);
|
||||||
|
return [link,val];
|
||||||
|
}
|
||||||
|
).sort(([link1,a],[link2,b])=>b.metadata?.date-a.metadata?.date);
|
||||||
console.log(blog_entries);
|
console.log(blog_entries);
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<main>
|
<main>
|
||||||
<div class="start">
|
<div class="start">
|
||||||
<h1>Welcome to SvelteKit</h1>
|
<h1>Welcome to SvelteKit</h1>
|
||||||
<p>
|
<p>
|
||||||
Visit <a href="https://svelte.dev/docs/kit">svelte.dev/docs/kit</a> to read the documentation
|
Visit <a href="https://svelte.dev/docs/kit">svelte.dev/docs/kit</a> to read the documentation
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
{#each blog_entries as [href, page]}
|
{#each blog_entries as [href, page]}
|
||||||
<a {href}>
|
<a {href}>
|
||||||
<div class="blog-entry">
|
<div class="blog-entry">
|
||||||
<div>
|
<div>
|
||||||
@@ -32,7 +39,7 @@
|
|||||||
</a>
|
</a>
|
||||||
<br />
|
<br />
|
||||||
<!-- svelte:component this={page.default} /-->
|
<!-- svelte:component this={page.default} /-->
|
||||||
{/each}
|
{/each}
|
||||||
</main>
|
</main>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
|||||||
Reference in New Issue
Block a user