Juha-Matti Santala
Community Builder. Dreamer. Adventurer.

Highlight Mastodon posts by hashtag with Stylus and :has

I like that Mastodon provides a way to follow hashtags. It’s a great way to find new people to follow and new things to read or watch for given topic. But I wish there was a clearer indicator for which posts are hashtagged and which are from people I follow.

This is because I put more value on those that I follow so I read them with more thought and just glance over the ones that come from a hashtag.

Now, this solution isn’t perfect because it does not separate followed accounts who used the hashtag from non-followed accounts whose post is on my feed because I follow the hashtag. But it’s a smaller issue for me personally so I haven’t bothered to do anything about it for now.

The power of custom CSS

Using Stylus Firefox extension and the power of the new :has pseudo-class, I added a visual indicator to my feed when using the browser.

Each post in Mastodon is an article and each hashtag is a link <a href="/tags/[hashtag]/">. Thanks to :has, we can now target articles that have a specific hashtag:

article:has(a[href="/tags/python" i]) {
  border: 1px solid orange;
}

Let’s walk through this selector:

  • article matches every <article> element in the page
  • :has() pseudo-class filters the articles down to ones that have at least one child element that matches what’s inside there
  • a matches every <a> element
  • [href="/tags/python"] filters those anchor tags down to ones that have href attribute that matches exactly /tags/python
  • i makes href matching case insensitive so it matches python, Python and PyThOn

In the web, it looks like this:

A Mastodon post by Python Weekly with hashtags #python and #programming and a link to a Medium blog post and text “Advanced Magic Methods in Python to Customize Classes Conveniently”

(this example is from https://mementomori.social that uses Mastodon Bird UI)

I’ve been experimenting a bit with different approaches to add the highlight because I want it to be easy to notice on a glance but not something that steals the focus. Right now, the slightly dimmed orange has been a good one but I’ll adjust it as I go and eventually find something that is spot on.

Syntax Error

Sign up for Syntax Error, a monthly newsletter that helps developers turn a stressful debugging situation into a joyful exploration.