New Features for this Blog
2019 has been a year of gatsby updates for this site. So, I wanted to end this year with the same spirit. And, I am hoping this is going to be the begining of maturity of the looks and features of this blog. In the upcoming year, I plan to focus mainly on content, specifically related to medicine, AI and proramming.
Here is a list of all the new features that I have lately added to this:
- updated codeblocks with copy and language indicator
- Medium-like highlight to share text feature
- Simplify navigation bar links
- Update footer to include social links
- Use postlist for similar posts
- Add substack subscription
- Add goatcounter for analytics
- CSS updates for blokquote, TLDR, Update components etc.
- fix edit on github links
In the following, I want to highlight some of these in little more detail:
One of the biggest updates that I made here has been in code blocks. Till now, I have been using the gatsby-remark-prismjs plugin. However, for mdx files, the recommended way is to use the prism-react-renderer library, as this also supports more advanced features like use of live code blocks via react-live. This approach additionally provides a lot of freedom to any user-defined features like copy to clipboard, language indicator etc.
Here is a partial peek at my final solution:
Notice, how I have highlighted the filename of the component and the interesting sections of the code.
The first highlighted section implements the copy to clipboard function. The second section is the actual implementation of the Code component.
Finally to complete the implementation, two more changes are needed:
codecomponents to MDXProvider in the post template file, and
- Add relevant css
If you are interested in details of the implementation for your own sites, please take a closer
look at the details of the css at
You can see my github repository for complete details of the implementation.
Finally, this implementation also supports live coding via the
react-live library. Here is a
A cool feature in Medium is the highlight menu that pops up when you select some text. This menu contains buttons that allow you to perform certain actions on the selected text like highlight and share.
You can have a look at my implementation here.
And of course, you can see it in action if you try to select and highlight some text. I only provide options for facebook, twitter and LinkedIn sharing though.
goatcounter.com is an open source, privacy aware, extremely light web analytics service that doesn't need a GDPR notice. To me this sounded like a perfect replacement for google analytics.
I ended up using
ScriptTag from the react-script-tag
and include that using
ScriptTag in the layout file. You can have a peek at my implementation in
more detail here.
And of course, you can see my public dashboard right here.
I have always wanted to provide a timely update about any new posts and updates to my regular followers. I first tried mailchimp, however, never felt satisfied with it. Looking for alternatives brought me to substack. I found this to be a modern solution that fit my needs. Now, you can see a link to my subscription to all pages, including one right below.
This was all the major changes that I made to the codebase. Other than these major changes, there are also many small changes to make the code cleaner and more generic.
Here is hoping to bring to an end to any further updates to the looks of this blog. Please look forward to content updates on major topics like medicine, deep learning and programming. Do not forget to subscribe to my newsletter below!