refactor: cleanup and unify the featured image metadata integration (#345)

uci-hugo-doc
Robert Kaussow 2022-02-15 22:27:43 +01:00 committed by GitHub
parent 055ab6c4e3
commit 95c38f6193
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 54 additions and 67 deletions

View File

@ -1,28 +1,20 @@
{{- if not (eq .Kind "home") }} {{- if not (eq .Kind "home") }}
<meta property="og:title" content="{{ partial "utils/title" . }}" /> <meta
property="og:title"
{{ partial "utils/title" . | printf "content=%q" | safeHTMLAttr }}
/>
{{- end }} {{- end }}
{{- with .Site.Title }} {{- with .Site.Title }}
<meta property="og:site_name" content="{{ . }}" /> <meta property="og:site_name" {{ . | printf "content=%q" | safeHTMLAttr }} />
{{- end }}
{{- with partial "utils/featured" . }}
<meta property="og:image" content="{{ . }}" />
{{- end }} {{- end }}
{{- with partial "utils/description" . }} {{- with partial "utils/description" . }}
<meta property="og:description" content="{{ trim (. | plainify) "\n" | safeHTML }}" /> <meta property="og:description" content="{{ . | plainify | htmlUnescape | chomp }}" />
{{- end }} {{- end }}
<meta property="og:type" content="{{ if .IsPage }}article{{ else }}website{{ end }}" /> <meta property="og:type" content="{{ if .IsPage }}article{{ else }}website{{ end }}" />
<meta property="og:url" content="{{ .Permalink }}" /> <meta property="og:url" content="{{ .Permalink }}" />
{{- with $.Params.images }}
{{- range first 6 . }}<meta property="og:image" content="{{ . | absURL }}" />{{ end -}}
{{- else }}
{{- $featured := ($.Resources.ByType "image").GetMatch "{*feature*,*cover*,*thumbnail*}" -}}
{{- with $featured }}
<meta property="og:image" content="{{ $featured.Permalink }}" />
{{- else }}
{{- with $.Site.Params.images }}
<meta property="og:image" content="{{ index . 0 | absURL }}" />
{{- end }}
{{- end }}
{{- end }}
{{- with .Params.audio }} {{- with .Params.audio }}
<meta property="og:audio" content="{{ . }}" /> <meta property="og:audio" content="{{ . }}" />
{{- end }} {{- end }}

View File

@ -1,19 +1,17 @@
{{- if .IsHome -}} {{- if eq .Kind "home" }}
{{- $thumbnail := default (default "brand.svg" .Site.Params.logo) (index (default slice .Site.Params.images) 0) | absURL }}
<script type="application/ld+json"> <script type="application/ld+json">
{ {
"@context": "http://schema.org", "@context": "http://schema.org",
"@type": "WebSite", "@type": "WebSite",
"name": "{{ .Site.Title }}", "name": {{ .Site.Title }},
"url": "{{ .Site.BaseURL }}", "url": {{ .Site.BaseURL }},
{{- with partial "utils/description" . }} {{- with partial "utils/description" . }}
"description": "{{ trim (. | plainify) "\n" | safeHTML }}", "description": "{{ . | plainify | htmlUnescape | chomp }}",
{{- end }} {{- end }}
"thumbnailUrl": "{{ $thumbnail }}" {{- with partial "utils/featured" . }}
{{- with .Site.Params.GeekdocContentLicense }}, "thumbnailUrl": {{ . }},
"license": "{{ .name }}"
{{- end }} {{- end }}
"inLanguage": {{ .Lang }}
} }
</script> </script>
{{- else if .IsPage }} {{- else if .IsPage }}
@ -22,18 +20,28 @@
"@context": "http://schema.org", "@context": "http://schema.org",
"@type": "TechArticle", "@type": "TechArticle",
"articleSection": "{{ .Section | humanize | title }}", "articleSection": "{{ .Section | humanize | title }}",
"name": "{{ (partial "utils/title" .) | safeJS }}", "name": {{ partial "utils/title" . }},
"headline": "{{ (partial "utils/title" .) | safeJS }}", "url" : {{ .Permalink }},
"alternativeHeadline": "{{ .Params.lead }}", "headline": {{ partial "utils/title" . }},
{{- with partial "utils/description" . }} {{- with .Params.lead }}
"description": "{{ trim (. | plainify) "\n" | safeHTML }}", "alternativeHeadline": {{ . }},
{{- end }} {{- end }}
"inLanguage": {{ .Site.Language.Lang }}, {{- with partial "utils/description" . }}
"description": "{{ . | plainify | htmlUnescape | chomp }}",
{{- end }}
{{- with partial "utils/featured" . }}
"thumbnailUrl": {{ . }},
{{- end }}
"wordCount" : "{{ .WordCount }}",
"inLanguage": {{ .Lang }},
"isFamilyFriendly": "true", "isFamilyFriendly": "true",
"mainEntityOfPage": { "mainEntityOfPage": {
"@type": "WebPage", "@type": "WebPage",
"@id": "{{ .Permalink }}" "@id": {{ .Permalink }}
}, },
{{- with $tags := .Params.tags }}
"keywords" : [ {{ range $i, $tag := $tags }}{{ if $i }}, {{ end }}"{{ $tag }}" {{ end }}],
{{- end }}
"copyrightHolder" : "{{ .Site.Title }}", "copyrightHolder" : "{{ .Site.Title }}",
"copyrightYear" : "{{ .Date.Format "2006" }}", "copyrightYear" : "{{ .Date.Format "2006" }}",
"dateCreated": "{{ .Date.Format "2006-01-02T15:04:05.00Z" | safeJS }}", "dateCreated": "{{ .Date.Format "2006-01-02T15:04:05.00Z" | safeJS }}",
@ -45,23 +53,11 @@
"url": {{ .Site.BaseURL }}, "url": {{ .Site.BaseURL }},
"logo": { "logo": {
"@type": "ImageObject", "@type": "ImageObject",
"url": "{{ (default "brand.svg" .Site.Params.logo) | absURL }}", "url": {{ (default "brand.svg" .Site.Params.logo) | absURL }},
"width":"32", "width":"32",
"height":"32" "height":"32"
} }
}, }
{{- with $images := $.Resources.ByType "image" }}
"image": [ {{ range $i, $image := $images }}{{ if $i }}, {{ end }}"{{ $image.Permalink | absURL }}" {{ end }}],
{{- else }}
{{- with $images := .Params.images }}
"image": [ {{ range $i, $image := $images }}{{ if $i }}, {{ end }}"{{ $image | absURL }}" {{ end }}],
{{- end }}
{{- end }}
"url" : "{{ .Permalink }}",
"wordCount" : "{{ .WordCount }}",
{{- with $tags := .Params.tags }}
"genre" : [ {{ range $i, $tag := $tags }}{{ if $i }}, {{ end }}"{{ $tag }}" {{ end }}]
{{- end }}
} }
</script> </script>
{{- end }} {{- end }}

View File

@ -1,27 +1,14 @@
{{- with $.Params.images -}} {{- with partial "utils/featured" . }}
<meta name="twitter:card" content="summary_large_image" /> <meta name="twitter:card" content="summary_large_image" />
<meta name="twitter:image" content="{{ index . 0 | absURL }}" />
{{- else }} {{- else }}
{{- $images := $.Resources.ByType "image" -}} <meta name="twitter:card" content="summary" />
{{- $featured := $images.GetMatch "*feature*" -}} {{- end }}
{{- if not $featured }} <meta name="twitter:title" {{ partial "utils/title" . | printf "content=%q" | safeHTMLAttr }} />
{{- $featured = $images.GetMatch "{*cover*,*thumbnail*}" -}} {{- with partial "utils/featured" . }}
{{- end }} <meta property="twitter:image" content="{{ . }}" />
{{- with $featured }}
<meta name="twitter:card" content="summary_large_image" />
<meta name="twitter:image" content="{{ $featured.Permalink }}" />
{{- else }}
{{- with $.Site.Params.images }}
<meta name="twitter:card" content="summary_large_image" />
<meta name="twitter:image" content="{{ index . 0 | absURL }}" />
{{- else }}
<meta name="twitter:card" content="summary" />
{{- end }}
{{- end }}
{{- end }} {{- end }}
<meta name="twitter:title" content="{{ partial "utils/title" . }}" />
{{- with partial "utils/description" . }} {{- with partial "utils/description" . }}
<meta name="twitter:description" content="{{ trim (. | plainify) "\n" | safeHTML }}" /> <meta name="twitter:description" content="{{ . | plainify | htmlUnescape | chomp }}" />
{{- end }} {{- end }}
{{- with .Site.Social.twitter -}} {{- with .Site.Social.twitter -}}
<meta name="twitter:site" content="@{{ . }}" /> <meta name="twitter:site" content="@{{ . }}" />

View File

@ -0,0 +1,12 @@
{{ $img := "" }}
{{ with $source := ($.Resources.ByType "image").GetMatch "{*feature*,*cover*,*thumbnail*}" }}
{{ $featured := .Fill (printf "1200x630 %s" (default "Smart" .Params.anchor)) }}
{{ $img = $featured.Permalink }}
{{ else }}
{{ with default $.Site.Params.images $.Params.images }}
{{ $img = index . 0 | absURL }}
{{ end }}
{{ end }}
{{ return $img }}