Using Github Actions To Produce Example Images Of Code
what i learned
I learned to chain a lot of small tools using GitHub Actions to produce ready-to-share images of code examples for social media (namely, instagram and twitter) from my phone. The steps, generally speaking, go as follows:
- Create a new page on a Notion Database. Probably will create a specific template for this, like I do with TIL’s but it’s not necessary.
- GitHub Action: Use my
markdownify-notion
python package to write the markdown version of this page and save it on a “quarto project” folder. This let’s me use one general front-matter yaml file for all files rather than automate adding front matter to each file. I can still add specific front matter to files if I want to. (this TIL is an example of how this works - I’m writing it on Notion on my phone.) - GitHub Action: Use Quarto to render this markdown file
--to html
and save it on an “output” directory. This will execute the code in the code cells and save the output inline. - GitHub Action: Use
shot-scraper
to produce two files: a png screenshot and a pdf file. I’m usingshot-scraper
for the PDF as well rather than using quarto because it’s easier and I am not in need of customizing this pdf file at all just yet. I’m creating it and saving it essentially just because I can, it’s easy, and might find use for it later. - GitHub Action: Once there are new png or pdf files in the “output” directory, I then use
s3-credentials
to put those objects on a S3 bucket I also created usings3-credentials
. This tool is fantastic s3-credentials.readthedocs.io
This is how the final image looks like
how i learned
I wanted to checkout quarto for a while and in the last rstudio conference they announced it was finally at version 1.0 so I gave it a try. It’s fairly straightforward but the documentation is clearly aimed at helping beginners and people that may not have any programming experience so a lot of the guides and tutorials and examples are for using Quarto within an editor like Rstudio or VS Code. It was hard to find examples of how to use it programmatically on your own - even the automating examples are using their GitHub Actions and services like Quarto publishing. This is actually great in general but if you need to do something custom they may not offer yet you need to figure it out on your own. ## reference * Quarto: quarto.org
shot-scraper: shot-scraper.datasette.io/en/stable/
s3-credentials: s3-credentials.readthedocs.io/en/stable/
markdownify-notion: github.com/chekos/markdownify-notion