Explore My Notes

Take me to another useless website please | The Useless Web

A quirky little tool quite similar toย the Whimsical Web, only for websites that serve no purpose. A few random presses took me to a site which is just a never-ending stream of 8-bit corndogs raining down from the browser windows; another which was just a picture of a mango set against a starburst background; one which hijacked your cursor so every single click took you to a "tweet this site" widget; and one which had a cursor-controlled, semi-fluid "waving arms tube" that emitted incredibly intense flashing images if you moved your mouse too fast ๐Ÿ˜ต Useless indeed!

Stuff about webmention | fluffy

A partial response to Marty and yet further interesting thoughts on what the term "webmention"ย has come to mean, and what the technology could become.

Webmention-as-reaction is fine, but itโ€™s very difficult to get good UX with webmention-as-comments. Reply chains are difficult to follow, especially if one of the links in the chain breaks

^ that, in particular, is something I've been thinking about a lot lately with my own implementation. I think I'm coming to the conclusion that Webmentions are fine toย support, but maybe aren't a good replacement for actual native comment systems. Then again, with static sites, native comment systems create their own headaches.

Fluffy (as ever) also raises some useful points around community moderation and the potential for abuse.

Testing microformats | Microformats.io

Very useful!ย A service that can take any URL and output the parsed results as JSON, letting you quickly see your site as a machine would. Helped me catch that myย rel=me links were duplicating themselves due to a difference in capitalisation on two of them ๐Ÿ‘

What we talk about when we say "webmentions" | Marty McGuire

These are all fantastic things that are built on top of Webmention but that I often feel are conflated with Webmention.

I'm in the middle of (ahem) adding Webmention support to this site, so I found this take on some of the many things that can mean by Marty pretty interesting, particularly as someone who (on first glance) envisioned a bold-new, Webmention-driven world and rapidly discovered it's a lot more nuanced than all that. His conclusion, though, feels like a particularly useful frame of reference when thinking about the technology:

Maybe Webmention can be thought of as less of a "building block" and more like a glue. You can do so many things with glue, like combining a bunch of planks into a table, or building a parade float sculpture with papier-mรขchรฉ, or doctoring the photo in a passport!

You wouldn't call them all "glue".

Adding Lighthouse scores to my site's footer | Zach Leat

...as a performance advocate, I feel that itโ€™s important to keep myself honest and to have some transparency behind the sites I build.

Using a combination of Speedlify and Google Lighthouse tool, Zach is able to display web performance scores in his footer, bespoke for each page. He seems to be doing so client-side, though I don't fully understand the reasoning. He's using 11ty, so there's a build process involved. Zach points out that the Lighthouse score would be "stale" if pulled in during build time but that doesn't feel right. I'd expect the Lighthouse score of a static page to be constant until that page was updated, which would require another build anyway. I guess if he's doing aย lot with client-side JS that may not be the case ๐Ÿคทโ€โ™‚๏ธย I also admit that heย is the web perf specialist and I am not, so I am likely missing something.

Either way, it's a cool feature and a neat example of API-driven, Jamstack goodness ๐Ÿ‘

Preload page links on hover | instant.page

Gatsby's page-fetching is a feature I consider a double-edged sword (though I'll admit I also don't fully understand it ๐Ÿ˜…). On the one hand, I'm all for anything that decreases load time between pages on a site. On the other, pre-caching a bunch of content that the user may never need feels like an extremely wasteful practice. InstantPage takes a slightly different approach, instead triggering the page request when a link isย hoveredย (or touched on mobile). In their estimation that can reduce latency by 100s of milliseconds, so we're not talking huge wins here, but a minor UX bump. Assuming the page weight added from the client-side JS doesn't offset it, of course...

Sneak peek at Sunlit 3.0 | Manton Reece

A new product aiming to be an "Instagram replacement" and photo-blogging tool from the creator of Micro.blogโ€ฝ Colour me intrigued! ๐Ÿค” Sunlit looks very nice, will be interested to see how it develops.

Isolate parts of a music track | Stems

Another really neat music-related tool, Stems claims to be able to split tracks into their various components e.g. drums, piano, vocals, instrumentals etc. It's something I've always thoughtย should be possible, yet wouldn't have the first clue where to start, so definitely bookmarking for some experimentation.

Turn music into visual magic | Astrofox

Astrofox looks like a really clever video editor, developed specifically with the aim of creating videos for music playlists and personal tracks. Nothing too fancy, but lots of options to animate elements in time with the music tempo, and some surprisingly nuanced creative controls mean this looks really excellent. Definitely want to give it a whirl at some point.

Array functions and the rule of least power | Jesse Duffield

The various array methods in JavaScript can be thought of on a scale ofย power, or really flexibility. At the top end you've got the for loop, at the bottom the highly-specific functions .every and .some. Jesse makes the argument that you should always choose theย least powerful option and I agree. The article is also just a generally excellent overview of array manipulation in JavaScript.

Circle chart showing how each array function can effectively be nested in those more powerful, with the for loop around them all, then "for each", reduce, both map and filter at the same level, and within filter find, then every and same together.
An incredibly useful reference guide to array functions.

๐Ÿ“† 16 Jul 2020  |  ๐Ÿ”—

  • JavaScript, 
  • array, 
  • function, 
  • map, 
  • reduce, 
  • filter, 
  • find, 
  • forEach, 
  • for loop, 
  • JavaScript 

Digital garden seedlings | Maggie Appleton

Whilst falling down the rabbit-hole of digital gardening I found some of Maggie's tweets incredibly insightful and useful, yet somehow totally missed her own digital garden (and her entire related repo of topics/content/examples) ๐Ÿคฆโ€โ™‚๏ธ I love the layout (not just here, but across her whole site too) but the part that really captured my imagination was her use of emoji-tags to differentiate topics into one of seedling, budding, or evergreen. It's just a neat metaphor for a topic in the garden literally growing through tending and care: ๐ŸŒฑ -> ๐ŸŒฟ -> ๐ŸŒณ (though I feel slightly miffed that she chose not to use an actual evergreen for that category: ๐ŸŒฒ ๐Ÿ˜‚).

Selfauth | GitHub

A self-hosted, open-source IndieAuth authorisation endpoint. I still find myself running in circles as to whether IndieAuthย worries me orย excites me, but I find this project a really neat piece of work by Zegnat ๐Ÿ‘

๐Ÿ“† 07 Jul 2020  |  ๐Ÿ”—

  • Frontend, 
  • tool, 
  • IndieAuth, 
  • IndieWeb, 
  • self hosted, 
  • repository, 
  • open source