Skip to content

Commit

Permalink
NEXT Add Bluesky news feed to documentation (#2849)
Browse files Browse the repository at this point in the history
  • Loading branch information
endigo9740 authored Sep 9, 2024
1 parent cd9a265 commit 85e67f0
Show file tree
Hide file tree
Showing 6 changed files with 151 additions and 105 deletions.
78 changes: 15 additions & 63 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions sites/next.skeleton.dev/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
"@skeletonlabs/skeleton-react": "workspace:*",
"@skeletonlabs/skeleton-svelte": "workspace:*",
"@types/react": "^18.3.3",
"add": "^2.0.6",
"astro": "^4.12.2",
"astro-auto-import": "^0.4.2",
"astro-expressive-code": "^0.33.5",
Expand Down
5 changes: 3 additions & 2 deletions sites/next.skeleton.dev/src/components/docs/Header.astro
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,9 @@ import Navigation from '@components/docs/Navigation.astro';
const coreLinks = [
{ href: '/docs/get-started/introduction', label: 'Docs', target: '_self' },
{ href: 'https://themes.skeleton.dev/', label: 'Themes', target: '_blank' },
{ href: 'https://bsky.app/profile/skeletonlabs.bsky.social', label: 'News', target: '_blank' }
// { href: 'https://bsky.app/profile/skeletonlabs.bsky.social', label: 'News', target: '_blank' }
{ href: '/news', label: 'News', target: '_self' },
{ href: 'https://themes.skeleton.dev/', label: 'Themes', target: '_blank' }
];
---

Expand Down
21 changes: 0 additions & 21 deletions sites/next.skeleton.dev/src/pages/blog/[...slug]/index.astro

This file was deleted.

19 changes: 0 additions & 19 deletions sites/next.skeleton.dev/src/pages/blog/index.astro

This file was deleted.

132 changes: 132 additions & 0 deletions sites/next.skeleton.dev/src/pages/news/index.astro
Original file line number Diff line number Diff line change
@@ -0,0 +1,132 @@
---
import { Icon } from 'astro-icon/components';
// Components
import LayoutRoot from '@layouts/LayoutRoot.astro';
import Header from '@components/docs/Header.astro';
import Footer from '@components/docs/Footer.astro';
const layoutProps = {
classList: 'grid grid-rows-[auto_1fr_auto] gap-10'
};
// Bluesky News Feed
// https://docs.bsky.app/docs/api/app-bsky-feed-get-author-feed
interface BlueskyPost {
post: {
uri: string;
record: {
createdAt: string;
text: string;
};
embed: {
$type: string;
images: {
thumb: string;
alt: string;
}[];
external: {
uri: string;
title: string;
thumb: string;
};
};
};
}
const queryParms = new URLSearchParams({
actor: 'skeletonlabs.bsky.social',
limit: '10',
filter: 'posts_no_replies'
});
const response = await fetch(`https://public.api.bsky.app/xrpc/app.bsky.feed.getAuthorFeed?${queryParms}`, {
method: 'GET',
headers: { Accept: 'application/json' }
});
const timeline = await response.json();
// Post Text Formatter
function postTextFormatter(text: string) {
// Link text is truncated, we need to prune them here.
text = text.replaceAll('github.com/skeletonlabs...', '');
return text;
}
// Date Formatter
function dateFormatter(date: string) {
return new Date(date).toLocaleDateString();
}
---

<LayoutRoot {...layoutProps}>
<!-- Header -->
<Header />
<!-- Main -->
<main class="max-w-3xl mx-auto space-y-10 px-4">
<header class="flex justify-between items-center">
<h2 class="h2">Latest News</h2>
<a
class="btn preset-outlined-surface-200-800 hover:preset-tonal"
href="https://bsky.app/profile/skeletonlabs.bsky.social"
target="_blank"
>
<Icon name="bluesky" size={16} />
<span>Feed</span>
</a>
</header>
<div class="space-y-4">
{
timeline.feed.map((item: BlueskyPost) => {
return (
<article class="card preset-outlined-surface-200-800 p-4 xl:p-10 space-y-4">
<header class="flex justify-between items-center">
{/* Avatar */}
<img
class="w-10 rounded-full overflow-hidden"
src="https://cdn.bsky.app/img/avatar_thumbnail/plain/did:plc:whtgi5zx7ylmdw2i76vq7vq4/bafkreicyyaq6y2iqhow3vknjyvenqqpxoxls63miv5traflivi44kkp4gq@jpeg"
/>
{/* Timestamp */}
<small class="opacity-60">{dateFormatter(item.post.record.createdAt)}</small>
</header>
{/* Post */}
<p class="xl:type-scale-4">{postTextFormatter(item.post.record.text)}</p>
{/* Embeds */}
<footer class="space-y-4">
{/* Embed: GitHub */}
{item.post.embed.$type.includes('external') && (
<a class="block" href={item.post.embed.external.uri} target="_blank">
{item.post.embed.external.thumb ? (
<img
class="bg-surface-500/10 hover:bg-surface-500 p-0.5 rounded-container overflow-hidden shadow"
src={item.post.embed.external.thumb}
/>
) : (
<div class="card preset-outlined-surface-200-800 hover:preset-tonal p-4 text-surface-800-200">
{item.post.embed.external.title}
</div>
)}
</a>
)}
{/* Embed: Images */}
{item.post.embed.$type.includes('images') &&
item.post.embed.images.map((image) => {
return <img class="bg-surface-500/10 p-1 rounded-container overflow-hidden shadow" src={image.thumb} />;
})}
</footer>
</article>
);
})
}
</div>
<div class="flex justify-center">
<a class="btn preset-filled" href="https://bsky.app/profile/skeletonlabs.bsky.social" target="_blank">
<span>View More</span>
<span>&rarr;</span>
</a>
</div>
<!-- Debugging -->
<!-- <pre class="pre">{JSON.stringify(timeline.feed, null, 2)}</pre> -->
</main>
<!-- Footer -->
<Footer />
</LayoutRoot>

0 comments on commit 85e67f0

Please sign in to comment.