Setting up this site: a multi-year lesson in not reinventing the wheel
Me trying to build websites
A 3-day weekend with no big plans and an out-of-town girlfriend prompted me to come back to “the blog”. My first post was on Medium, as I was hesitant to deal with setting up my own website (again). As I mentioned in my last (and first) blog, I’ve started a few different personal homepages that have sputtered out. I used to almost view these “flameouts” as a personal failing – “Am I really not motivated enough to do the ‘bare minimum’ of making my own website’s UI?”. So I’d tell myself “I’ll come back to this later”, and then I just… wouldn’t.
But after some time in industry, I’ve realized that I just don’t like frontend that much! Don’t get me wrong, I like understanding how the frontend works, and I like being able to hack out basic UIs to add features or fix bugs for users. But fighting with React build/bundle tools and massaging CSS to align some buttons is just not how I want to spend my free time.
How I’ve been writing
That said, I also wasn’t too happy with the Medium writing UI (no built-in footnotes in 2023?). Since graduating from college, almost all of my writing has been at work, where I’ve used two classes of writing UIs:
- Cloud-based WYSIWYG (i.e. Google Docs / ClickUp docs): feature-ful editors with advanced text formatting and multimedia. Great for collaborative design docs and sharing results with the team.
- Markdown: Banging out Markdown in VSCode or GitHub/Gerritt UIs to share technical information with other people working in my repository.
Connecting the dots
One of my previous attempts at setting up a website involved building a Gatsby React app & hosting it on GitHub pages (you can see my repo’s commit history). I recall approximately the following thought process when I was going about this setup:
- Dealing with the actual web server seems difficult to figure out - maybe I’ll use this GitHub pages thing.
- Hmm, GitHub pages has some kind of built-in Markdown rendering support. Interesting.
- React is cool and I haven’t really used it much. I wanna try building a site with React, that seems fun. I’ll ignore that built-in Markdown support. I did end up building a1 Gatsby React site…but my site was basically a static “About Me” page, so there really wasn’t any need for React at all2.
Coming back a few years later, where I
a. want to start writing, and am used to writing Markdown
b. don’t want to spend my free time building a blogging platform or frontend frameworks,
the GH pages rendering from Step 2. is a whole lot more appealing.
So I decided to just follow GitHub’s docs. I hit a few speedbumps, but they were mostly due to the fact that I hadn’t done any dev on my personal laptop in a while3. Now that I’ve got my Homebrew & Ruby & Jekyll up and running, it seems to be pretty smooth sailing. Hot-reloading the blog posts is definitely a nice feature for while I’m writing.
Overall, I’m happy with this setup for blogging, and I’m optimistic that I’ll continue to write here. I’ll probably still cross-post stuff over to Medium as well just for “reach” though.
Addendum: Domain Names
The default GitHub pages URL is OK, I guess, but I kinda wanted my blog to have my own domain, even if I wasn’t gonna deal with hosting its contents or building the frontend.
So I started researching domain services. GoDaddy still has a vaguely bad rep, but I didn’t dig in enough to figure out why (maybe it was just those old ads?). I started looking at other options4, and eventually came to a list that included NameCheap. Seeing their logo dredged up an old memory – I did publish that original Gatsby/React web app, and I did host it at a custom domain from NameCheap. They actually gave me the domain for free because I was still a student (or at least had a student email), which was nice. And I didn’t remember having any qualms with their interface, so I decided to just go back to them.
I debated going with a more clever domains (lucaswrit.es was considered!), but no one had picked up my lucasjenkins.me domain in the years since I let it slip. So $42.70 later, I’m the proud owner of lucasjenkins.me for 5 years. I followed Namecheap’s docs, and now lucasjenkins.me points to my GitHub pages. Success! All that’s left to do is use GitHub’s built-in “Enforce HTTPS”, but apparently it can take some time before the DNS updates propagate and that button is enabled in the GitHub UI. But I’m calling it a day for now. If I end up writing again tomorrow, maybe I’ll come back and see if that button’s clickable.
- 
      very ugly, in retrospect. ↩ 
- 
      And after spending enough time fighting with React tooling, I kinda wonder if this is true for a lot of sites…https://htmx.org/ is very buzzy. Although in my company’s current codebase, the most painful part isn’t “React” or “Material UI” or “vanilla JS” or “fomantic-ui” on their own, it’s that we use all these different frontend frameworks. When you have to do something in a new area of the codebase, you may also have to learn a whole new framework. I only understand fomantic-ui and htmx on a very surface level, but they seem like approaches that, if used consistently, could maybe be a nicer experience (both dev and user)? ↩ 
- 
      My homebrew install was borked, and I also ran into this issue. Un-shallowing my clone took so long that I didn’t finish setting up this blog until Day 2 of the long weekend. Apparently GitHub didn’t like HomeBrew users shallow cloning and then hitting GitHub’s servers hard whenever they needed a not-shallow clone. Derrick Stollee has a great blog describing shallow vs. partial clones, which I’ve recently dug deep into at work. I thought Copia was all about building frontends and supporting various PLC vendors, but just running a Git hosting service on its own involves some interesting problems. ↩ 
- 
      porkbun.com was pretty highly recommended. ↩