The figure
shortcode requires specifying the image’s src
attribute explicitly, but it would be better if it used Page.Resources
to populate the URL (and perhaps other attributes).
I am using ugly URLs and page bundles. Because of this, my images end up in a subdirectory one level deeper than my post’s HTML file:
- content/
- foobar/
- index.md --> becomes /foobar.html
- image.png --> becomes /foobar/image.png
In my Markdown, I therefore need to use data:image/s3,"s3://crabby-images/4252a/4252ad007fe5a85dc08481222d96ee8161be73a3" alt="Alt"
instead of the more natural data:image/s3,"s3://crabby-images/2c21d/2c21dafe74b6b7c6ab10404c649fee79823d2457" alt="Alt"
. And these relative URLs get messed up if the post folder gets renamed, or if an excerpt of the post gets embedded somewhere else.
Instead, I had luck with modifying the figure
shortcode like so:
<img src="{{ with .Get "src" | $.Page.Resources.GetMatch }}{{ .RelPermalink }}{{ end }}" ...
Now I can just write {{< figure src="image.png" >}}
and it uses Page.Resource
's ability to figure out the right path for the image.