nikwou
February 1, 2022, 5:36am
1
The render-hook-template approach works well. However, I do not understand how to pass multiple parameters from the markdown file to the render hook. E.g., if I have markdown like:
data:image/s3,"s3://crabby-images/10cd9/10cd9b262d24733d3df253bd5ec0af2d2c75ecbc" alt="Alternate Text"
How would I pass an additional height or width parameter?
Thank you very much in advance for a short explanation.
If your content structure is like this…
content/articles/
└── article-1/
├── image.png
└── index.md
… it is called page bundle , and the image is a page resource .
If your render hook is something like this…
layouts/_default/_markup/render-image.html
{{- $u := urls.Parse .Destination -}}
{{- $alt := plainify .Text -}}
{{- $title := plainify .Title -}}
{{- $img := "" -}}
{{- if $u.IsAbs -}}
{{- with resources.GetRemote $u.String -}}
{{- with .Err -}}
{{- errorf "%s" -}}
{{- else -}}
{{- $img = . -}}
{{- end -}}
{{- else -}}
{{- errorf "Unable to get remote image" -}}
{{- end -}}
{{- else -}}
{{- with .Page.Resources.GetMatch $u.Path -}}
{{- $img = . -}}
{{- else -}}
{{- errorf "Unable to get local image" -}}
{{- end -}}
{{- end -}}
{{- with $img -}}
<img src="{{ .RelPermalink }}" width="{{ .Width }}" height="{{ .Height }}"
{{- with $alt }} alt="{{ . }}" {{- end -}}
{{- with $title }} title="{{ . }}" {{- end -}}
>
{{- end -}}
It will automatically determine the dimensions of the image whether it is local or remote.
data:image/s3,"s3://crabby-images/5f21d/5f21d3947da9db9df2eb027e47fddd6e94df75f5" alt="Alternate text"
data:image/s3,"s3://crabby-images/1a562/1a562c8c0cb9e3001b812ab28a553a1f462e0556" alt="Alternate text"
You can modify this render hook to parse the image path for a query string. For example:
data:image/s3,"s3://crabby-images/43a1a/43a1a2833c3c6fca0bc6ae52b8ba6a2769b0568b" alt="Alt text"
data:image/s3,"s3://crabby-images/e8042/e8042451a91c6e03d41272682027fb6cbf3dd29c" alt="Alt text"
Then do some conditional checking. If the dimensions are present, scale and crop using the .Fill
method.
References:
3 Likes
AakLak
February 17, 2022, 10:33am
3
Great example, thanks!
Pros/Cons of placing images in content/ vs static/?
I guess the main pros is that in content/ they are a Page Resource and therefore can be processed?
Wondering how to setup my structure.
And you’re keeping your content+assets together in one place. I think of this as “content encapsulation.”
bep
February 17, 2022, 7:34pm
5
Which for images also has the benefit that they get rendered fine on GitHub.
2 Likes