Compare commits

...

1 Commits

Author SHA1 Message Date
8482118f66 Start working on a pages feature. 2024-12-11 21:03:30 -05:00
9 changed files with 58 additions and 7 deletions

BIN
bun.lockb

Binary file not shown.

View File

@ -3,6 +3,7 @@ title = "davesmithhayes.com"
[owner] [owner]
name = "Dave Smith-Hayes" name = "Dave Smith-Hayes"
email = "me@davesmithhayes.com" email = "me@davesmithhayes.com"
mastadonUrl = "https://hachyderm.io/@davesh"
[site] [site]
description = "Personal website of Dave Smith-Hayes - a father, developer, and musician." description = "Personal website of Dave Smith-Hayes - a father, developer, and musician."

View File

@ -1,4 +1,4 @@
header, footer, main { header, footer, nav, main {
max-width: 800px; max-width: 800px;
margin: 0 auto; margin: 0 auto;
padding: 1em; padding: 1em;
@ -20,6 +20,21 @@ header .home-link a:visited {
color: #00e; color: #00e;
} }
nav {
border-bottom: 1px solid #ccc;
}
nav ul {
margin: 0;
padding: 0;
}
nav ul li {
display: inline-block;
margin-left: 1em;
}
nav ul li:first-child {
margin-left: 0;
}
footer { footer {
border-top: 1px solid #ccc; border-top: 1px solid #ccc;
} }

View File

@ -3,6 +3,7 @@ import { Home } from "@blog/templates/Pages/Home";
import { PostMeta } from "@blog/models/PostMeta"; import { PostMeta } from "@blog/models/PostMeta";
import { Post } from '@blog/models/Post'; import { Post } from '@blog/models/Post';
import { PostService } from '@blog/services/post-file'; import { PostService } from '@blog/services/post-file';
import { getSiteConfig } from '@blog/services/config';
type Posts = { type Posts = {
postService: PostService postService: PostService
@ -11,6 +12,7 @@ type Posts = {
const app = new Hono<{ Variables: Posts }>(); const app = new Hono<{ Variables: Posts }>();
app.get("/", async (c) => { app.get("/", async (c) => {
const config = await getSiteConfig();
const postService: PostService = c.get('postService'); const postService: PostService = c.get('postService');
const isDev: boolean = process.env.DEPLOY_MODE == 'development'; const isDev: boolean = process.env.DEPLOY_MODE == 'development';
@ -22,8 +24,8 @@ app.get("/", async (c) => {
return c.render(<Home posts={postList} />, { return c.render(<Home posts={postList} />, {
meta: { meta: {
description: "The blog for Dave Smith-Hayes, a dad and developer.", description: config.site.description,
mastodonUrl: "https://hachyderm.io/@davesh" mastodonUrl: config.owner.mastodonUrl,
}, },
}); });
}); });

View File

@ -6,6 +6,7 @@ export type SiteConfig = {
owner: { owner: {
name: string; name: string;
email: string; email: string;
mastodonUrl?: string;
}; };
site: { site: {
description: string; description: string;
@ -13,7 +14,7 @@ export type SiteConfig = {
repo: string; repo: string;
language: string; language: string;
copyright: string; copyright: string;
} };
} }
export async function getSiteConfig(): Promise<SiteConfig> { export async function getSiteConfig(): Promise<SiteConfig> {

View File

@ -22,11 +22,13 @@ export async function getFeed(postService: PostService): Feed {
} }
}); });
const fullSlug = (slug) => config.site.url + "/posts/" + slug;
postService.getPublishedPosts().map((post: Post) => { postService.getPublishedPosts().map((post: Post) => {
feed.addItem({ feed.addItem({
title: post.meta.title, title: post.meta.title,
id: post.meta.slug, id: fullSlug(post.meta.slug),
link: post.meta.slug, link: fullSlug(post.meta.slug),
description: post.meta.description, description: post.meta.description,
content: post.html, content: post.html,
author: { author: {

View File

@ -1,6 +1,7 @@
import { Style } from 'hono/css'; import { Style } from 'hono/css';
import { SiteMeta } from '@blog/models/SiteMeta'; import { SiteMeta } from '@blog/models/SiteMeta';
import { MetaTags } from '@blog/templates/components/MetaTags'; import { MetaTags } from '@blog/templates/components/MetaTags';
import { Navigation } from '@blog/templates/components/Navigation';
function getPageTitle(title: string|undefined): string { function getPageTitle(title: string|undefined): string {
if (!title) { if (!title) {
@ -25,6 +26,9 @@ export function Page({ children, meta }: { children: any, meta: SiteMeta }) {
<a href="/">davesmithhayes.com</a> <a href="/">davesmithhayes.com</a>
</div> </div>
</header> </header>
<nav>
<Navigation />
</nav>
<main> <main>
{children} {children}
</main> </main>

View File

@ -4,7 +4,6 @@ import { PostMeta } from '@blog/models/PostMeta';
export function Home({ posts }: { posts: PostMeta[] }) { export function Home({ posts }: { posts: PostMeta[] }) {
return ( return (
<div class="main"> <div class="main">
<h1>Posts</h1>
{posts.length ? <PostList posts={posts} /> : <div>No posts.</div>} {posts.length ? <PostList posts={posts} /> : <div>No posts.</div>}
</div> </div>
); );

View File

@ -0,0 +1,27 @@
type SitemapUrl = {
name: string;
path: string;
};
export function Navigation() {
const navigation: SitemapUrl[] = [
{
name: "Home",
path: "/",
},
{
name: "About",
path: "/about"
},
{
name: "RSS",
path: "/feed/rss.xml"
}
];
return (
<ul>
{navigation.map(n => <li><a href={n.path}>{n.name}</a></li>)}
</ul>
);
}