You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
40 lines
1.5 KiB
40 lines
1.5 KiB
{{ $source := ($.Page.Resources.ByType "image").GetMatch (printf "*%s*" (.Get "name")) }} |
|
{{ $customAlt := .Get "alt" }} |
|
{{ $customSize := .Get "size" }} |
|
{{ $lazyLoad := default (default true $.Site.Params.GeekblogImageLazyLoading) (.Get "lazy") }} |
|
|
|
{{ with $source }} |
|
{{ $caption := default .Title $customAlt }} |
|
|
|
{{ $tiny := (.Resize "320x").RelPermalink }} |
|
{{ $small := (.Resize "600x").RelPermalink }} |
|
{{ $medium := (.Resize "1200x").RelPermalink }} |
|
{{ $large := (.Resize "1800x").RelPermalink }} |
|
|
|
{{ $size := dict "tiny" $tiny "small" $small "medium" $medium "large" $large }} |
|
|
|
<div class="flex justify-center"> |
|
<figure class="gblog-post__figure"> |
|
<a class="gblog-post__link--raw" href="{{ .RelPermalink }}"> |
|
<img |
|
{{ if $lazyLoad }}loading="lazy"{{ end }} |
|
{{ with $customSize }} |
|
src="{{ index $size $customSize }}" alt="{{ $caption }}" |
|
{{ else }} |
|
srcset="{{ $size.tiny }} 320w, |
|
{{ $size.small }} 600w, |
|
{{ $size.medium }} 1200w, |
|
{{ $size.large }} 2x" |
|
sizes="(max-width: 320px) 320w, |
|
(max-width: 600px) 600w, |
|
(max-width: 1200px) 1200w, |
|
2x" |
|
src="{{ $size.large }}" alt="{{ $caption }}" |
|
{{ end }}/> |
|
</a> |
|
{{ with $caption }} |
|
<figcaption>{{ . }}{{ with $source.Params.credits }} ({{ . | $.Page.RenderString }}){{ end }}</figcaption> |
|
{{ end }} |
|
</figure> |
|
</div> |
|
{{ end }}
|
|
|