2020-10-22 13:12:26 +02:00
|
|
|
{{- with .cxt}} {{/* Apply proper context from dict */}}
|
2020-12-29 16:44:03 +05:30
|
|
|
{{- if (and .Params.cover.image (not $.isHidden)) }}
|
2020-10-22 13:12:26 +02:00
|
|
|
<figure class="entry-cover">
|
2024-11-09 20:21:33 +05:30
|
|
|
{{- $loading := cond $.IsSingle "eager" "lazy" }}
|
2023-12-16 13:09:19 +05:30
|
|
|
{{- $addLink := (and site.Params.cover.linkFullImages $.IsSingle) }}
|
2024-11-09 20:29:08 +05:30
|
|
|
{{- $prod := (hugo.IsProduction | or (eq site.Params.env "production")) }}
|
|
|
|
{{- $alt := (.Params.cover.alt | default .Params.cover.caption | plainify) }}
|
|
|
|
{{- $responsiveImages := (.Params.cover.responsiveImages | default site.Params.cover.responsiveImages) | default true }}
|
|
|
|
|
|
|
|
{{- $pageBundleCover := (.Resources.ByType "image").GetMatch (printf "*%s*" (.Params.cover.image)) }}
|
2023-04-28 16:43:57 +02:00
|
|
|
{{- $globalResourcesCover := (resources.ByType "image").GetMatch (printf "*%s*" (.Params.cover.image)) }}
|
|
|
|
{{- $cover := (or $pageBundleCover $globalResourcesCover)}}
|
2024-11-09 20:52:28 +05:30
|
|
|
{{/* We are not using the .Param.cover.relative to decide the location of image */}}
|
|
|
|
{{/* If we have the image in pageBundle or globalResources we can process the image */}}
|
2024-11-09 20:25:03 +05:30
|
|
|
|
2024-11-09 20:29:08 +05:30
|
|
|
{{- $sizes := (slice "360" "480" "720" "1080" "1500") }}
|
|
|
|
{{- $processableFormats := (slice "jpg" "jpeg" "png" "tif" "bmp" "gif") -}}
|
|
|
|
{{- if hugo.IsExtended -}}
|
|
|
|
{{- $processableFormats = $processableFormats | append "webp" -}}
|
|
|
|
{{- end -}}
|
|
|
|
|
2024-11-09 20:47:29 +05:30
|
|
|
{{- $imgdl := (.Params.cover.image) | absURL }}
|
|
|
|
{{- if $cover -}}
|
|
|
|
{{- $imgdl = $cover.Permalink }}
|
|
|
|
{{- end -}}
|
|
|
|
|
2024-11-09 20:25:03 +05:30
|
|
|
{{- if $addLink }}
|
2024-11-09 20:47:29 +05:30
|
|
|
<a href="{{ $imgdl }}" target="_blank" rel="noopener noreferrer">
|
2024-11-09 20:25:03 +05:30
|
|
|
{{- end }}
|
|
|
|
|
2024-11-09 20:52:28 +05:30
|
|
|
{{- if $cover -}}
|
|
|
|
{{/* i.e it is present in page bundle */}}
|
2021-09-02 20:54:50 +05:30
|
|
|
{{- if (and (in $processableFormats $cover.MediaType.SubType) ($responsiveImages) (eq $prod true)) }}
|
2024-11-09 20:48:49 +05:30
|
|
|
<img loading="{{$loading}}"
|
|
|
|
srcset='{{- range $size := $sizes -}}
|
|
|
|
{{- if (ge $cover.Width $size) }}
|
|
|
|
{{- printf "%s %s" (($cover.Resize (printf "%sx" $size)).Permalink) (printf "%sw," $size) }}
|
|
|
|
{{- end }}
|
|
|
|
{{- end }}
|
|
|
|
{{- printf "%s %dw" ($cover.Permalink) ($cover.Width) }}'
|
|
|
|
src="{{ $cover.Permalink }}"
|
|
|
|
sizes="(min-width: 768px) 720px, 100vw"
|
|
|
|
width="{{ $cover.Width }}" height="{{ $cover.Height }}"
|
|
|
|
alt="{{ $alt }}">
|
2020-10-22 13:12:26 +02:00
|
|
|
{{- else }}{{/* Unprocessable image or responsive images disabled */}}
|
2024-11-09 20:48:49 +05:30
|
|
|
<img loading="{{ $loading }}" src="{{ $imgdl }}" alt="{{ $alt }}">
|
2020-10-22 13:12:26 +02:00
|
|
|
{{- end }}
|
2024-11-09 20:52:28 +05:30
|
|
|
{{- else }}
|
|
|
|
{{/* For absolute urls and external links, no img processing here */}}
|
2024-11-09 20:47:29 +05:30
|
|
|
<img loading="{{ $loading }}" src="{{ $imgdl }}" alt="{{ $alt }}">
|
2020-10-22 13:12:26 +02:00
|
|
|
{{- end }}
|
2024-11-09 20:25:03 +05:30
|
|
|
|
|
|
|
{{- if $addLink }}
|
|
|
|
</a>
|
|
|
|
{{ end -}}
|
|
|
|
|
2020-10-22 13:12:26 +02:00
|
|
|
{{/* Display Caption */}}
|
2023-12-16 13:09:19 +05:30
|
|
|
{{- if $.IsSingle }}
|
2024-11-09 20:25:03 +05:30
|
|
|
{{- with .Params.cover.caption }}
|
2024-11-09 21:04:36 +05:30
|
|
|
<figcaption>{{ . | markdownify }}</figcaption>
|
2024-11-09 20:25:03 +05:30
|
|
|
{{- end }}
|
2020-10-22 13:12:26 +02:00
|
|
|
{{- end }}
|
|
|
|
</figure>
|
|
|
|
{{- end }}{{/* End image */}}
|
2021-03-30 18:07:36 +05:30
|
|
|
{{- end -}}{{/* End context */ -}}
|