hugo-geekblog/layouts/shortcodes/img.html

43 lines
1.4 KiB
HTML
Raw Normal View History

{{ $source := ($.Page.Resources.ByType "image").GetMatch (printf "%s" (.Get "name")) }}
2020-07-27 18:17:55 +00:00
{{ $customAlt := .Get "alt" }}
{{ $customSize := .Get "size" }}
{{ $lazyLoad := default (default true $.Site.Params.GeekblogImageLazyLoading) (.Get "lazy") }}
2020-07-27 18:17:55 +00:00
{{ with $source }}
{{ $caption := default .Title $customAlt }}
2020-07-27 18:17:55 +00:00
{{ $tiny := (.Resize "320x").Permalink }}
{{ $small := (.Resize "600x").Permalink }}
{{ $medium := (.Resize "1200x").Permalink }}
{{ $large := (.Resize "1800x").Permalink }}
2020-07-27 18:17:55 +00:00
{{ $size := dict "tiny" $tiny "small" $small "medium" $medium "large" $large }}
2020-07-27 18:17:55 +00:00
<div class="flex justify-center">
<figure class="gblog-post__figure">
<a class="gblog-markdown__link--raw" href="{{ .Permalink }}">
<picture>
<source
{{ with $customSize }}
srcset="{{ index $size $customSize }}"
{{ else }}
srcset="{{ $size.small }} 600w, {{ $size.medium }} 1200w" sizes="100vw"
{{ end }}
/>
<img
{{ if $lazyLoad }}loading="lazy"{{ end }}
src="{{ $size.large }}"
alt="{{ $caption }}"
/>
</picture>
</a>
{{ with $caption }}
<figcaption>
{{ . }}{{ with $source.Params.credits }} ({{ . | $.Page.RenderString }}){{ end }}
</figcaption>
{{ end }}
</figure>
</div>
2020-07-27 18:17:55 +00:00
{{ end }}