Building a website with Stitch and Next
I've rebuilt my blog three times this year and moved all posts to Medium because I can't decide what I want / what's easiest for me. Medium was cool, but I wanted to use my own domain, and Medium recently killed that.
The first iteration was with Prismic and React. It was a grand project with a blog, my goals, and my playground. I soon realized that it was probably too ambitious, especially the goals. I work a lot, and it's difficult to keep everything updated, so I decided to shutter that for the next rebuild.
Iteration 1.5 was to refactor the Prismic / React site with TypeScript and easy-peasy
instead of JS and Redux.
The second iteration followed almost immediately, where I got rid of Prismic in favor of a custom static site generator with Markdown posts. It was nice, gave me way more control over my content, and worked beautifully. However, it wasn't flexible enough.
The third and current iteration came when I decided to play around with MongoDB Stitch. Over the last year and a half, I've used Azure Functions a lot. I've written about that in another post.
While we misused functions for that project, it made a lot of sense for a minimal blog app. So I set out to build the whole thing.
Functions
I've been a MongoDB Atlas customer for a long time, and I've always wanted to try out Stitch but didn't know what to build with it. This gave me the perfect opportunity to try it out.
I wrote 9 functions to cover CRUD for posts and projects. It had a bit of a learning curve because the documentation isn't fantastic. But the result was quite nice. Check out the code on GitHub.
Setting up
The setup was fairly simple, although a little time-consuming. Everything has a provision/setup delay in MongoDB cloud, and Stitch wasn't an exception.
- Create a Stitch app and connect it to your cluster
- Setup rules to allow access to your blog database
- Create a service for the blog functions
- Add your functions to the service
I considered creating separate functions that my service functions could call, but then I ended up with two sets of functions doing basically the same thing. I decided just to put all my code in my service functions.
Authentication
While my posts and projects are public, updating and deleting them require authentication, so only I can modify them. Each service function gives you a lot of control (but not enough) over how you want to authenticate. I created auth secrets for dangerous functions to prevent malicious actors from updating my blog. That was very simple.
Blog
While my Prismic / React app was sufficient, it lacked server-side rendering and thus SEO. For this rebuild, I decided to go with Next.js to have both. Check out the code on GitHub. I used jsx-styled
for my component styling, my first experience with the package. I can't say I'm too happy with it, but that's another story.
It's deployed to multiple regions to make it faster in different parts of the world, something I didn't have with Render. They will only have servers in the US, which causes a 2+ second delay for my requests. Luckily, the progressive web app made it faster. But now it's live rendered for dynamic pages and static pages for, well, static pages.
Admin
This was the tricky part. Or rather, the part that prevented me from taking this approach. The reason I chose Prismic in the first place. I didn't want to build my own CMS. Why reinvent the wheel with a lot of effort if I can use another service. While Prismic's editor was fantastic, it didn't allow me the flexibility I desired.
I decided to bite the bullet and build a CMS using React. Check out the code on GitHub. Take it for a spin, if you want.
It's nice and minimal, although a bit rudimentary. I decided not to use a store, so some changes do not reflect throughout the app. It looks amazing on my desktop screen but not so much on my 15" MacBook Pro. It's not responsive either, but that's by design.
It uses Markdown and a side-by-side preview to see what the content looks like as I write.
I'm quite happy with the new setup. One issue I have is with images. Since they're stored in the blog repo, I need to make sure I've added all the assets, pushed, and deployed them before publishing a new post. It's not the end of the world, and the work required to upload and host assets separately would be a hassle; I can live with it for now.
Another change could be to host the admin on Now instead of Render. Not entirely sure why I chose to host them separately. Convenience, perhaps?