🧩🚀🛠️ヽ(`Д´)ノ
Create a Remark plugin "remark-card" and use it in my Astro website
Intro
Ever since childhood, I had dreamed of becoming a wizard──
The dream's come true this time.
But the ability is very limited; you cannot turn apples into apple pies, or someone you hate into Gudetama either. Instead, you can transform Markdown into HTMLs as you want.
By the way, Unified, a huge ecosystem of document conversion as best represented by Remark and Rehype, has many volunteers scattered around the world who are developing and maintaining a lot of the plugins.
However, none of them says, "You can summon card components on the field in Markdown with me", as far as I can see. 1
Why not create it on your own then?──Now that I feel like I can even fly.
Reader personas
- Want to create a Remark plugin on their own
- Interested in
remark-card
- Working hard on embellishing their Markdown/MDX blog
My proficiency level
As of the day I'm writing this article, my proficiency level in this field is as follows:
- Have a three-year experience as a software engineer in total (Not in a row)
- Have been around JavaScript, TypeScript for about four years
- Have never published an NPM package before
Main
Here's the Github repository.
How to use
remark-card
offers two Markdown dialects: card-grid
and card
.
The former plays a role as a wrapper for multiple cards and the latter is self-explanatory.
class
) card
The card is written in Markdown like:
This turns into...
And the final output is:
younagi.dev
card-grid
Next up, let's line up some cards in the card grid component.
This turns into:
And the final output is:
younagi.dev Part 1
younagi.dev Part 2
younagi.dev Part 3
Use it in Astro
Incidentally, the card components are already all over there in this website.
To use Remark/Rehype plugins in Astro, you need to do something in the Astro config file at the root like this:
This is actually enough to make it work, but it requires a bit more steps if you use Astro components to customize the HTML tags and styles.
In my case, twe Astro components are used: Card.astro
and CardGrid.astro
. The resultant card
and card-grid
tags generated by remark-card
will in turn be transformed into them respectively.
For more details, see the source code below.
Following the MDX's manners, pass them onto the <Content />
tag as custom components and the deal is all done. Below is an example of it:
Post-development notes
It doesn't look different from README up until this point, so let me seriously think back on the dev experience here.
- Language:
JavaScriptTypeScript- I can't help shaking like a leaf without type safety
CommonJSFollowing the ESM's manners
- Markdown syntax: Generic directives/plugins syntax
- I made up such a dialect that anyone familiar with it will get taken aback at, and was going to adopt it at first, but ended up transitioning to the more general-looking syntax
- e.g.,
:::
,::::
, etc.
- Test runner & Package manager: Bun
- It's a versatile meat bun being a JavaScript runtime, test runner, and package manager simultaneously
- Test-wise, it's compatible with Jest and thus familiar to me and easy to migrate
- Its novelty and high performance were the determining factors
I consumed the code written by forerunners as if bathing and most of it turned out to be written in the JavaScript and JSDoc combi.
It's agreeable if writing code for a product by and large 2, but this time I went with TypeScript since it's such a small project and I'm more familiar with it.
Outro
Actually, I've developed and released another Remark plugin called remark-video
soon after the remark-card
.
I was planning to make a new article about it at first, but gave up in the end.
After all, it didn't take me as much time and energy as the remark-card
and therefore there's not much to share in particular. On top of that, this article sort of made me feel a tinge of contentment somehow. 3
-
There are a lot of plugins for "Linkcard" instead. ↩
-
Not writing in TypeScript saves you the time for transpiling while ensuring you type safety with JSDoc.
Plus, JSDoc helps you make decs in its manners, which make it easier to communicate with readers on the purposes of the code. ↩ -
Frankly speaking, I just found it tedious. ↩
Thanks👏