mirror of
https://github.com/thegeeklab/hugo-geekblog.git
synced 2024-11-22 13:10:40 +00:00
Robert Kaussow
2f01b4b903
BREAKING CHANGE: The `size=profile` option was removed from the `img` shortcode. To create avatar images the new `avatar` shortcode can be used.
58 lines
2.1 KiB
HTML
58 lines
2.1 KiB
HTML
{{- $source := ($.Page.Resources.ByType "image").GetMatch (printf "%s" (.Get "name")) }}
|
|
{{- $customAlt := .Get "alt" }}
|
|
{{- $customSize := .Get "size" | lower }}
|
|
{{- $customAnchor := default "smart" (.Get "anchor") | title }}
|
|
{{- $data := newScratch }}
|
|
|
|
{{- with $source }}
|
|
{{- $caption := default .Title $customAlt }}
|
|
{{- $isSVG := (eq .MediaType.SubType "svg") }}
|
|
{{- $origin := . -}}
|
|
|
|
{{- if $isSVG }}
|
|
{{- $data.SetInMap "size" "tiny" "160" }}
|
|
{{- $data.SetInMap "size" "small" "300" }}
|
|
{{- $data.SetInMap "size" "medium" "600" }}
|
|
{{- $data.SetInMap "size" "large" "900" }}
|
|
{{- else }}
|
|
{{- $data.SetInMap "size" "tiny" (printf "160x160 %s" $customAnchor) }}
|
|
{{- $data.SetInMap "size" "small" (printf "300x300 %s" $customAnchor) }}
|
|
{{- $data.SetInMap "size" "medium" (printf "600x600 %s" $customAnchor) }}
|
|
{{- $data.SetInMap "size" "large" (printf "900x900 %s" $customAnchor) }}
|
|
{{- end -}}
|
|
|
|
<div class="flex justify-center">
|
|
<figure
|
|
class="gblog-post__figure gblog-post__figure--round">
|
|
<a class="gblog-markdown__link--raw" href="{{ .Permalink }}">
|
|
<picture>
|
|
{{- $size := $data.Get "size" }}
|
|
{{- if not $isSVG }}
|
|
{{- if ne $customSize "origin" }}
|
|
<source
|
|
{{- if $customSize }}
|
|
srcset="{{ ($origin.Fill (index $size $customSize)).Permalink }}"
|
|
{{- else }}
|
|
srcset="{{ ($origin.Fill (index $size "small")).Permalink }} 600w, {{ ($origin.Fill (index $size "medium")).Permalink }} 1200w" sizes="100vw"
|
|
{{- end }}
|
|
/>
|
|
{{- end }}
|
|
{{- end }}
|
|
<img
|
|
{{- if $isSVG }}
|
|
src="{{ $origin.Permalink }}" width="{{ index $size (default "medium" $customSize) }}"
|
|
{{- else }}
|
|
{{- if eq $customSize "origin" }}
|
|
src="{{ $origin.Permalink }}"
|
|
{{- else }}
|
|
src="{{ ($origin.Fill (index $size "large")).Permalink }}"
|
|
{{- end }}
|
|
alt="{{ $caption }}"
|
|
{{- end }}
|
|
/>
|
|
</picture>
|
|
</a>
|
|
</figure>
|
|
</div>
|
|
{{- end }}
|