chore: updated about page fec656b1
Steve · 2026-05-01 23:42 3 file(s) · +50 −70
public/blog-images/personal-site-structure.svg (added) +4 −0
1 +
<?xml version="1.0" standalone="no"?>
2 +
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
3 +
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1917.862761292351 621.700480271259" width="3835.725522584702" height="1243.400960542518"><!-- svg-source:excalidraw --><metadata></metadata><defs><style class="style-fonts">
4 +
      @font-face { font-family: "Comic Shanns"; src: url(data:font/woff2;base64,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); }</style></defs><g transform="translate(726.734523544993 20.229463210070207) rotate(0 217.79986572265625 135)"><text x="0" y="31.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">https://stevedylan.dev</text><text x="0" y="76.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">  /now</text><text x="0" y="121.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">  /cellar</text><text x="0" y="166.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">  /bookmarks</text><text x="0" y="211.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">  /library</text><text x="0" y="256.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">  /blogroll</text></g><g transform="translate(1511.863005432976 10) rotate(0 197.9998779296875 22.5)"><text x="0" y="31.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">posts.stevedylan.dev</text></g><g transform="translate(1429.1178985323145 405.09598096503714) rotate(0 217.79986572265625 22.5)"><text x="0" y="31.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">library.stevedylan.dev</text></g><g transform="translate(22.31366892063579 453.1699368758427) rotate(0 237.599853515625 22.5)"><text x="0" y="31.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">bookmarks.stevedylan.dev</text></g><g transform="translate(10 17.135252789775677) rotate(0 207.89987182617188 22.5)"><text x="0" y="31.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">cellar.stevedylan.dev</text></g><g transform="translate(736.3995900838399 566.700480271259) rotate(0 197.9998779296875 22.5)"><text x="0" y="31.5" font-family="Comic Shanns, monospace, Segoe UI Emoji" font-size="36px" fill="#d3d3d3" text-anchor="start" style="white-space: pre;" direction="ltr" dominant-baseline="alphabetic">feeds.stevedylan.dev</text></g><g stroke-linecap="round"><g transform="translate(938.8197288148826 228.87847269824647) rotate(0 235.0835083363777 87.90901682951619)"><path d="M0 0 C130.51 49.9, 261.7 99.39, 470.17 175.82 M0 0 C143.67 54.49, 286.26 108.16, 470.17 175.82" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g><g transform="translate(938.8197288148826 228.87847269824647) rotate(0 235.0835083363777 87.90901682951619)"><path d="M25 0.28 C17.52 1, 10.52 2, 0 0 M25 0.28 C18.12 0.37, 9.3 0.71, 0 0" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g><g transform="translate(938.8197288148826 228.87847269824647) rotate(0 235.0835083363777 87.90901682951619)"><path d="M18.97 16.29 C13.28 12.55, 7.96 9.08, 0 0 M18.97 16.29 C13.86 11.53, 6.88 7, 0 0" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g></g><mask></mask><g stroke-linecap="round"><g transform="translate(869.1059541551235 297.57234323772036) rotate(0 31.81690254439968 131.06406851676934)"><path d="M0 0 C14.47 60.65, 29.34 119.07, 63.63 262.13 M0 0 C23.64 90.03, 45.56 180.57, 63.63 262.13" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g><g transform="translate(869.1059541551235 297.57234323772036) rotate(0 31.81690254439968 131.06406851676934)"><path d="M13.87 20.8 C11.46 16.88, 8.7 10.17, 0 0 M13.87 20.8 C9.18 13.14, 4.56 6.88, 0 0" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g><g transform="translate(869.1059541551235 297.57234323772036) rotate(0 31.81690254439968 131.06406851676934)"><path d="M-2.74 24.85 C-1.34 20.02, -0.31 12.38, 0 0 M-2.74 24.85 C-1.77 15.96, -0.69 8.31, 0 0" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g></g><mask></mask><g stroke-linecap="round"><g transform="translate(867.3595243108193 84.34476802411473) rotate(0 313.3146615156943 -19.303074056599826)"><path d="M0 0 C161.88 -11.11, 322.73 -20.3, 626.63 -38.61 M0 0 C229.67 -13.8, 459.07 -27.56, 626.63 -38.61" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g><g transform="translate(867.3595243108193 84.34476802411473) rotate(0 313.3146615156943 -19.303074056599826)"><path d="M22.91 -10 C18.93 -9.17, 11.96 -4.73, 0 0 M22.91 -10 C15.39 -6.87, 7.12 -2.29, 0 0" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g><g transform="translate(867.3595243108193 84.34476802411473) rotate(0 313.3146615156943 -19.303074056599826)"><path d="M23.98 7.07 C19.58 3.51, 12.34 3.55, 0 0 M23.98 7.07 C16.05 3.95, 7.38 2.28, 0 0" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g></g><mask></mask><g stroke-linecap="round"><g transform="translate(749.0444847698946 133.42482948193106) rotate(0 -153.05842984263154 -43.65827102060291)"><path d="M0 0 C-99.72 -28.61, -199.05 -57.23, -306.12 -87.32 M0 0 C-62.32 -16.8, -124.6 -34.37, -306.12 -87.32" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g><g transform="translate(749.0444847698946 133.42482948193106) rotate(0 -153.05842984263154 -43.65827102060291)"><path d="M-24.94 1.75 C-17.07 1.69, -9.36 0.6, 0 0 M-24.94 1.75 C-20.08 1, -15.23 0.86, 0 0" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g><g transform="translate(749.0444847698946 133.42482948193106) rotate(0 -153.05842984263154 -43.65827102060291)"><path d="M-20.23 -14.69 C-13.75 -9.45, -7.56 -5.21, 0 0 M-20.23 -14.69 C-16.32 -12.08, -12.42 -8.88, 0 0" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g></g><mask></mask><g stroke-linecap="round"><g transform="translate(756.5074828717115 195.14859195933536) rotate(0 -125.9978804148111 128.93955742155288)"><path d="M0 0 C-75.01 75.52, -148.76 151.49, -252 257.88 M0 0 C-59.52 61.05, -120.6 122.01, -252 257.88" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g><g transform="translate(756.5074828717115 195.14859195933536) rotate(0 -125.9978804148111 128.93955742155288)"><path d="M-10.34 22.76 C-7.09 15.35, -2.75 8.1, 0 0 M-10.34 22.76 C-7.57 17.79, -6.33 11.15, 0 0" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g><g transform="translate(756.5074828717115 195.14859195933536) rotate(0 -125.9978804148111 128.93955742155288)"><path d="M-22.55 10.79 C-15.72 6.95, -7.78 3.24, 0 0 M-22.55 10.79 C-16.82 8.76, -12.65 4.98, 0 0" stroke="#d3d3d3" stroke-width="4" fill="none"></path></g></g><mask></mask></svg>
src/content/pages/about.mdx (added) +41 −0
1 +
---
2 +
title: About
3 +
---
4 +
5 +
import { Image } from "astro:assets";
6 +
import aboutImg from "../../assets/pfp.png";
7 +
import Diagram from "@/components/blog/Diagram.astro";
8 +
9 +
# About Me
10 +
11 +
My name is Steve and I'm a DX Engineer with a passion for developer tooling that advances an open web. I'm currently working at [Stablecore](https://stablecore.com) as a senior solutions engineer. I'm also working on a host of other [projects](/projects), the latest being [Andromeda](https://andromeda.build). Check out what else I've been up to recently at my [now page](/now)!
12 +
13 +
<div class="flex justify-center not-prose">
14 +
  <Image src={aboutImg} alt="Steve pfp" loading="eager" class="animate-fade-in" />
15 +
</div>
16 +
17 +
Here's some more info about me:
18 +
19 +
- Currently at the foot of a mountain in Chattanooga TN.
20 +
- Married with two boys; they mean the world to me.
21 +
- I love spending time building side projects, but I also have a plethora of random hobbies. Some of which include birdwatching, collecting vinyls/cassettes, trying Chinese loose leaf tea, or doing amateur astronomy.
22 +
- I've worn many hats over the past decade, including archery technician, bank support specialist, and engineer.
23 +
- I have a killer waffle recipe handed down through my family. If you're lucky, maybe one day you'll get to try it.
24 +
25 +
Feel free to [reach out](mailto:contact@stevedylan.dev)!
26 +
27 +
# About This Site
28 +
29 +
This website was built with [Astro](https://astro.build), and started out with the [Astro Cactus theme](https://astro.build/themes/details/astro-cactus/), but has significantly diverged as the years have gone by. Astro is an incredible framework for building personal sites/blogs and I would highly recommend it to anyone looking for a solution that needs just a bit more juice than your standard SSG.
30 +
31 +
Evidence of this is how I have structured this site. Most of the content is prerendered (static content), which other pieces are more dynamic and are rendered on the server per request using `export const prerender = false`.
32 +
33 +
<Diagram src="/blog-images/personal-site-structure.svg" alt="multiple services connecting to stevedylan.dev" />
34 +
35 +
As illustrated above, I have multiple apps running outside my website that have public facing APIs which let me fetch content from them and display it dynamically. Each request to one of these pages makes an API call to that service first and then renders the content in the sent HTML from the server (SSR). Another option at my disposal is to prerender those pages and it will make the API request at build time, but I lose the live updates. 
36 +
37 +
This architecture saves me the hassle from running everything from one massive app (ie my website) and lets me break up my services into atomic pieces. If you're interested to learn more about the small apps themselves, check them out [here](https://andromeda.build).
38 +
39 +
The site is hosted on Cloudflare Pages, but I sleep well at night knowing I could easily self host this or use another platform if I needed to.
40 +
41 +
Everything you see is also MIT opened sourced and can be explored [here](https://github.com/stevedylandev/stevedylan.dev) or through `ssh git.stevedylan.dev -t stevedylan.dev`.
src/pages/about.astro +5 −70
1 1
---
2 2
import PageLayout from "@/layouts/Base.astro";
3 -
import { Image } from "astro:assets";
4 -
import aboutImg from "../assets/pfp.png";
5 -
import { projects } from "../data/projects";
3 +
import { Content } from "../content/pages/about.mdx";
6 4
7 5
const meta = {
8 6
	title: "About",
11 9
---
12 10
13 11
<PageLayout meta={meta}>
14 -
  <div class="space-y-6">
15 -
    <h1 class="title">About Me</h1>
16 -
    <p>
17 -
      My name is Steve and I’m a DX Engineer with a passion for
18 -
      developer tooling that advances an open web. I’m currently working at
19 -
      <a
20 -
        class="style-link inline-block"
21 -
        target="_blank"
22 -
        rel="noopener noreferrer"
23 -
        aria-label="stablecore"
24 -
        href="https://stablecore.com"
25 -
      >
26 -
        Stablecore</a
27 -
      >
28 -
      as a senior solutions engineer. I'm also working on a host of other <a
29 -
        class="style-link inline-block"
30 -
        aria-label="projects"
31 -
        href="/projects">projects</a
32 -
      >, the latest being
33 -
      <a
34 -
        target="_blank"
35 -
        rel="noopener noreferrer"
36 -
        class="style-link inline-block"
37 -
        aria-label={projects[0].title}
38 -
        href={projects[0].link}
39 -
      >
40 -
        {projects[0].title}
41 -
      </a>. Check out what else I've been up to recently at my <a class="style-link inline-block" href="/now">now page</a>!
42 -
    </p>
43 -
    <div class="flex justify-center">
44 -
      <Image
45 -
        src={aboutImg}
46 -
        alt="Steve pfp"
47 -
        loading="eager"
48 -
        class="animate-fade-in"
49 -
      />
12 +
  <article class="flex-grow break-words">
13 +
    <div class="prose prose-sm prose-cactus prose-headings:font-semibold">
14 +
      <Content />
50 15
    </div>
51 -
    <p>Here's some more info about me:</p>
52 -
    <ul class="list-inside list-disc">
53 -
      <li>Currently at the foot of a mountain in Chattanooga TN.</li>
54 -
      <li>
55 -
        Married with two boys; they mean the world to me.
56 -
      </li>
57 -
      <li>
58 -
        I love spending time building side projects, but I also have a plethora of random hobbies. Some of which include birdwatching, collecting vinyls/cassettes, trying Chinese loose leaf tea, or doing amateur astronomy.
59 -
      </li>
60 -
      <li>
61 -
        I've worn many hats over the past decade, including archery technician, bank support specialist, and engineer.
62 -
      </li>
63 -
      <li>I have a killer waffle recipe handed down through my family. If you're lucky, maybe one day you'll get to try it.</li>
64 -
    </ul>
65 -
    <p>
66 -
      Feel free to
67 -
      <button
68 -
        class="style-link inline-block"
69 -
        onclick="window.location.href='mailto:contact@stevedylan.dev'"
70 -
        aria-label="email link"
71 -
      >
72 -
        reach out
73 -
      </button>!
74 -
    </p>
75 -
  </div>
76 -
  <!-- <div class="space-y-6 mt-12"> -->
77 -
  <!--   <h1 class="title">About This Site</h1> -->
78 -
  <!--   <p> -->
79 -
  <!--   The main bones of this site is made with <a href="https://astro.build" class="style-link" rel="noreferrer" target="_blank">Astro</a> and the <a href="https://astro.build/themes/details/astro-cactus/">Astro Cactus Theme</a>, although at this point it has been pretty gutted out to fit my own needs. I'm currently hosting it on Cloudflare Pages with a hybrid SSR/Static approach.  -->
80 -
  <!--   </p> -->
81 -
  <!-- </div> -->
16 +
  </article>
82 17
</PageLayout>