| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 | {{ $page := . }}{{ $featured := (.Resources.ByType "image").GetMatch "*featured*" }}{{ $anchor := $page.Params.image.focal_point | default "Smart" }}{{/* Set default titles for node pages */}}{{ $title := .Title }}{{ if and (not $title) .IsNode }}  {{ if eq .Type "post" }}    {{ $title = i18n "posts" }}  {{ else if eq .Type "event" }}    {{ $title = i18n "talks" }}  {{ else if eq .Type "publication" }}    {{ $title = i18n "publications" }}  {{end}}{{end}}{{/* Header image */}}{{ if and .Params.header.image (not (and $featured (not .Params.image.preview_only))) }}<div class="article-header">  {{- $img := "" -}}  {{ $alt := (.Params.header.caption | default "") | plainify }}  {{ $destination := .Params.header.image }}  {{ $is_remote := strings.HasPrefix $destination "http" }}  {{- if not $is_remote -}}    {{- $img = (.Page.Resources.ByType "image").GetMatch $destination -}}    {{- if not $img -}}      {{- $img = resources.Get (path.Join "media" $destination) -}}    {{- end -}}  {{- end -}}  {{ if $img }}    <img src="{{$img.RelPermalink}}" width="{{$img.Width}}" height="{{$img.Height}}" class="article-banner" alt="{{$alt}}">  {{ else }}    <img src="{{ .Params.header.image }}" class="article-banner" alt="{{$alt}}">  {{ end }}  {{ with .Params.header.caption }}<span class="article-header-caption">{{ . | markdownify | emojify }}</span>{{ end }}</div>{{end}}{{/* Featured image layout */}}{{ if and $featured (not .Params.image.preview_only) }}{{/* Fit image within max size. */}}{{ $image := $featured }}{{/* Determine image placement. */}}{{ $placement := .Params.image.placement | default 1 }}{{/* Default to full column width. */}}{{ $image_container := "" }}{{ if eq $placement 2}}  {{ $image_container = "container" }}  {{ if gt $featured.Width 1200 }}    {{ $image = $featured.Resize "1200x" }}  {{ end }}{{else if eq $placement 3}}  {{ $image_container = "container-fluid" }}  {{ $image := $featured.Fit "2560x2560" }}{{else}}  {{ $image_container = "article-container" }}  {{ if gt $featured.Width 720 }}    {{ $image = $featured.Resize "720x" }}  {{ end }}{{end}}<div class="article-container pt-3">  <h1>{{ $title }}</h1>  {{ with $page.Params.subtitle }}  <p class="page-subtitle">{{ . | markdownify | emojify }}</p>  {{end}}  {{ partial "page_metadata" (dict "page" $page "is_list" 0 "share" true) }}  {{ partial "page_links_div.html" $page }}</div>{{/* Featured image */}}<div class="article-header {{$image_container}} featured-image-wrapper mt-4 mb-4" style="max-width: {{$image.Width}}px; max-height: {{$image.Height}}px;">  <div style="position: relative">    <img src="{{ $image.RelPermalink }}" width="{{ $image.Width }}" height="{{ $image.Height }}" alt="{{ with $.Params.image.alt_text }}{{.}}{{ end }}" class="featured-image">    {{ with $.Params.image.caption }}<span class="article-header-caption">{{ . | markdownify | emojify }}</span>{{ end }}  </div></div>{{else}}  {{/* Case when page has no image */}}  {{/* Wider container for nodes */}}  {{ $ctnr := "article-container" }}  {{ if $page.IsNode }}    {{ $ctnr = "universal-wrapper" }}  {{end}}<div class="{{$ctnr}} pt-3">  <h1>{{ $title }}</h1>  {{ with $page.Params.subtitle }}  <p class="page-subtitle">{{ . | markdownify | emojify }}</p>  {{end}}  {{ if not .IsNode }}    {{ partial "page_metadata" (dict "page" $page "is_list" 0 "share" true) }}    {{ partial "page_links_div.html" $page }}  {{end}}</div>{{end}}
 |