Articles

Article  · 
Importing SVG in Remix MDX

Importing SVG in Remix MDX

A decade ago, Chris Coyier from CSS-Tricks described ways to consume SVG, which can be distilled into two groups: to link and to embed.

Fast forward to 2022, the market has shifted from WordPress+PHP to React+TypeScript, but the same dilemma "to link or to embed?" still applies because, at the bottom of it, we're still dealing with the same HTML and CSS as we did a decade ago.

So what's the best way to import SVG in MDX?

Read article
Article  · 
Syntax highlighting in Remix

Syntax highlighting in Remix

Syntax highlighting is done using either highlight.js or prism.js. Once you've picked one, you'll have to set it up for code blocks: 1. within MDX and 2. outside MDX. That's how it works on all kinds of frameworks, not just Remix, although I'll post examples for Remix.

This setup is mostly a trivial task; however, there are a few niggles worth mentioning.

Read article
Article  · 
Better npm packages

Better npm packages

Maintaining npm packages is hard, and writing Open Source is already an achievement. But let's not get complacent. Here I tried to compile a list of a few ideas to improve further. I haven't implemented some of them yet. Few entries at the bottom are so novel that I think nobody in the world has either.

Read article
a thought  · 

Mastering the tooling

Don't know if you noticed but many extraordinary developers mastered their code editors to such level, that they started teaching productivity, editor plugins and, heck, in some cases, code editors themselves.

The first two quick examples that pop to my mind:

  • Wes Bos (online educator) has once published a Sublime Text Power User book
  • Steve Francia (creator of Hugo the static site generator and many famous Golang libraries) has his Vim

It does not matter what code editor you use but it's imperative to master all keyboard shortcuts and tricks of the one you picked.

Article  · 
`html-crush` bug fixed

html-crush bug fixed

One line in Babel config, env preset's loose set to true was causing a spread operator to disappear on only CommonJS builds (not ES Modules or UMD), which led to broken logic (program could not calculate opts.breakToTheLeftOf correctly any more), program inserted extra blank lines. A crazy bug, isn't it?

Read article
Article  · 
Automated vercel redirect maintenance on Eleventy

Automated vercel redirect maintenance on Eleventy

Vercel, our static website hosting service, makes it easy to set up page redirects, you can have up to 1024 redirects. It's all controlled from a single JSON file. Many things can go wrong in that file, stakes are quite high (starting with SEO) and any redirect mistakes can be hard to spot.

Here's our automated checking setup.

Read article
Article  · 
`string-strip-html` v.5 and lessons learned

string-strip-html v.5 and lessons learned

For an exported function, string-in, string-out API is awesome because it's simple. The problem happens later when you want to add more to the output, for example, a log with time spent. Or an alternative output, like locations of string indexes. Or the version from package.json.

Read article
a thought  · 

In favour of BYOD

Few arguments in favour to BYOD company policies:

  1. Passwords
  2. Notes
  3. Snippets
  4. ZSH aliases
  5. Time wasting syncing all above
  6. Money wasting on two sets of licences