Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

The Surprisingly High Table Stakes of Modern Blogs #443

Closed
swyxio opened this issue Aug 21, 2022 · 4 comments
Closed

The Surprisingly High Table Stakes of Modern Blogs #443

swyxio opened this issue Aug 21, 2022 · 4 comments

Comments

@swyxio
Copy link
Owner

swyxio commented Aug 21, 2022


tags: advice, writing
category: essay
cover_image: https://user-images.githubusercontent.com/6764957/185814244-3e698a67-0827-45bd-986d-0c1d419b0fbb.png

Bottom Line Up Front: You are probably underestimating how much goes into blogging technology these days.

note: i have rolled up most of these opinions into my own swyxkit starter template.

Reader Experience

And everything should look great on mobile devices and (at least not horrible on) ultrawide monitors.

Web performance is of course a huge part of the reading experience but I've put it in the section below for even spacing reasons.

Author Experience

  • WYSIWYG writing (with keyboard shortcuts) - use a CMS? Roll your own? Markdown vs Blocks?
  • If writing in static markdown files, the ability to colocate static files (eg pdfs) next to the file (instead of dumped in a big fat "files" folder with no clue which post it belongs to), and to easily write relative links to them in the markdown that will be transformed to the write path
  • Customizable metadata (with good inference when not supplied)
    • slug
    • publish date
    • edited at date
    • canonical url
    • description
    • og:image
    • layout
  • Shortcodes/Unfurls
  • Image uploads - best workflow is to paste the image from clipboard right into the textbox and have it upload, as Github Issues does.
  • Static data entry
  • Analytics
    • Server side analytics (Netlify Analytics)
    • Google Analytics
    • Privacy preserving clientside analytics (eg Fathom)
  • Mobile authoring/editing experience

Distribution/Reach

Developer Experience

  • Plugin systems for adding every feature above in <10 lines of code (example)
  • Build times should be <1 minute
  • Type safety for data schemas
  • Fast content preview (preferably without having to run a local server)
  • Monitoring/alerting - when your site goes down or a single popular page disappears for whatever reason, who finds out first? your readers or you?

This is often tied with the debate about whether or not the blog should be Jamstack - mostly statically generated and hosted on a CDN, or traditionally mostly generated on request and cached for some amount of time.

Misc

Context

It is often said that one of the best ways of learning a new language, from Ruby to Rust, is to implement a static site generator (fun fact - it was actually my take-home interview for Netlify!). Depending on the requirements, it forces you to learn everything from filesystem access, making network requests, parallelizing code, parsing configs, using libraries, creating plugin systems, injecting javascript, writing a CLI, and deployment.

Because there are accordingly so many static site generators, most people tend to devalue them, in the "I could build this in a weekend" sort of way, and end up building their own blogging platforms every few years as a way to "stay sharp". But that's a very 90's view of blogging technology - and the requirements of a modern Blog has diverged a lot from the basics of static site generation in the past 30 years. In the end, your readers have a poorer experience and your blog may not get the reach it might deserve.

I of course am no exception to this, being maintainer of my own small blog template for the Svelte ecosystem. I am intimately familiar with the modern dev blogging platforms like Dev.to and Hashnode, and these days spend plenty of time reading the many Data Engineering Substacks, and only appreciated how much they do for us that you should not handroll (or should consider building if DIY, because it is genuinely such a good feature).

This is an appreciation I only arrived at after ~5 years of constant blogging, so I figured I should write down what I see as "table stakes", for you to appreciate when considering your next great blogging platform, without trying to sell you any particular solution.

For what its worth, I do think most people, even developers, should not handroll their own blogs and should try to use Devto/Hashnode/Substack (Wordpress is of course an option) accordingly, because most people get so caught up in being PM + Dev for their handrolled blogging software that they never get to the writing. Try to do, say, 20 straight weeks of regular blogging, to prove that you are actually going to be a blogger, before you spend a bunch of time coding up blog software you end up not using.

The most important feature of a blog is its content - if you write good content, people will overcome almost any hurdle to come and read it. Don't forget that.

{% twitter https://twitter.com/markdalgleish/status/1108433814647300097 %}

@swyxio
Copy link
Owner Author

swyxio commented Aug 21, 2022

Aaron Francis has a nice looking syntax highlighting API that seems to have a bunch of these features figured out: https://twitter.com/aarondfrancis/status/1561490579095273473?s=21&t=e9tGZTAVWD3LH-PHXsbHuw

@sheldonhull
Copy link

You know, this is why I've paused on any next steps, it's a big effort to migrate/choose, and not certain yet what route to take. My current Hugo blog works well, but maintaining over time is probably not the best use of my time as that theme is no longer actively developed.

I've considered doing what you are doing with GitHub issues, which I think is great! However, at the end of the day, despite my love for simple markdown, I've been reconsidering super[dot]so, or other alternatives despite being less powerful, because the authoring friction is reduced. Because Notion can export markdown, I feel it's a reasonable compromise to get my data back out, albeit with terrible naming :-) I'd eliminate clunky shortcodes to do special formatting, and just WYSISWG in essence.

I read that Blocks vs Markdown post in your article as well, and it was a pretty solid case! Thanks for sharing that.

control & compatibility

My main concern is most of the stuff like Super.So how difficult it can be to migrate existing content, maintain backwards compatibility, and deal with missing features that seem obvious to a development audience. RSS, Redirects for renamed posts, front-matter/slug control to help ensure metadata correctly set.

Considering I don't make money on my blog, it's perhaps not as much of an issue as I'd think. The benefits of reduced friction might make up for it. I think it's serverless, and updating content is nearly live after editing in Notion, with seconds to your website being updated. If I'm willing to give up simple text and move to block based editing, I'd probably benefit long-term in writing with such low friction.

close

Obsidian is tempting, but sorta comes back down into role your own solution, unless you use Publish, which is way to expensive for a personal dev blog. They also have a separate licensing requirement if you use on a work system at all, which is a frustrating restriction.

I'm also experimenting with Front Matter as a VSCode driven way to make things nicer to author. Still prefer blogging with Typora, but it bridges the gap from cli driven blog actions to a nice dashboard.

Gist Wish List

I wish Gists as a blogging mechanism had become more popular.
They are too hard to discover, and lack enough control.

However, GistLog/Gist oriented blogging seemed like a perfect solution for developers, if it had only been built on better.

@sheldonhull
Copy link

@sw-yx comment with headers broke your comment formatting, sorry!
Also the heart/like reaction at the bottom near my name results in a hyperlink to the api json, not to the comment on github. 👋🏻

@swyxio
Copy link
Owner Author

swyxio commented Oct 3, 2022

whoops... @sheldonhull PR welcome, not gonna take a look at it right now but appreciate the report

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants