Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/CaiJimmy/hugo-theme-stack.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJimmy Cai <jimmehcai@gmail.com>2020-09-11 18:54:16 +0300
committerJimmy Cai <jimmehcai@gmail.com>2020-09-11 18:54:16 +0300
commit2acd380e98e705801eb90e8c6dee4395e4381aa8 (patch)
tree43e5124228a68a574125ad8d4a69766d57745212
parenta2662603dfda86d2be2ba0de06809a7e7e7b4f65 (diff)
feat(helper/image): customize field used to get featured image
-rw-r--r--exampleSite/config.toml1
-rw-r--r--layouts/partials/helper/image.html15
2 files changed, 9 insertions, 7 deletions
diff --git a/exampleSite/config.toml b/exampleSite/config.toml
index 4ffe263..294742c 100644
--- a/exampleSite/config.toml
+++ b/exampleSite/config.toml
@@ -13,6 +13,7 @@ DefaultContentLanguage = "en" # Theme i18n support
[params]
mainSections = ["post"]
favicon = ""
+ featuredImageField = "image"
[params.dateFormat]
published = "Jan 02, 2006"
lastUpdated = "Jan 02, 2006 15:04 MST"
diff --git a/layouts/partials/helper/image.html b/layouts/partials/helper/image.html
index fc9925f..f73e985 100644
--- a/layouts/partials/helper/image.html
+++ b/layouts/partials/helper/image.html
@@ -1,17 +1,18 @@
{{ $result := dict "exists" false "permalink" nil "resource" nil "isDefault" false }}
-{{ $imageField := .Context.Params.image }}
+{{ $imageField := default "image" .Context.Site.Params.featuredImageField }}
+{{ $imageValue := index .Context.Params $imageField }}
-{{ if $imageField }}
+{{ if $imageValue }}
<!-- If page has `image` field set -->
{{ $result = merge $result (dict "exists" true) }}
- {{ $url := urls.Parse $imageField }}
+ {{ $url := urls.Parse $imageValue }}
{{ if or (eq $url.Scheme "http") (eq $url.Scheme "https") }}
<!-- Is a external image -->
- {{ $result = merge $result (dict "permalink" $imageField) }}
+ {{ $result = merge $result (dict "permalink" $imageValue) }}
{{ else }}
- {{ $pageResourceImage := .Context.Resources.GetMatch (printf "%s" ($imageField | safeURL)) }}
- {{ $siteResourceImage := resources.GetMatch (printf "%s" ($imageField | safeURL)) }}
+ {{ $pageResourceImage := .Context.Resources.GetMatch (printf "%s" ($imageValue | safeURL)) }}
+ {{ $siteResourceImage := resources.GetMatch (printf "%s" ($imageValue | safeURL)) }}
{{ if $pageResourceImage }}
<!-- If image is found under page bundle -->
@@ -23,7 +24,7 @@
{{ $result = merge $result (dict "resource" $siteResourceImage) }}
{{ else }}
<!-- Can not find the image -->
- {{ errorf "Failed loading image: %q" $imageField }}
+ {{ errorf "Failed loading image: %q" $imageValue }}
{{ $result = merge $result (dict "exists" false) }}
{{ end }}
{{ end }}