From 2f01b4b90327f9fbd0bf9649c39f9d5b579a809d Mon Sep 17 00:00:00 2001 From: Robert Kaussow Date: Sun, 7 Apr 2024 21:46:31 +0200 Subject: [PATCH] refactor: move profile size from img to degicated avatar shortcode (#525) BREAKING CHANGE: The `size=profile` option was removed from the `img` shortcode. To create avatar images the new `avatar` shortcode can be used. --- .../about/images/{profile.jpg => avatar.jpg} | Bin exampleSite/content/about/index.md | 6 +- .../content/posts/advanced/includes.md | 21 ++++--- .../posts/avatar-images/images/avatar.jpg | Bin 0 -> 73194 bytes .../content/posts/avatar-images/index.md | 52 ++++++++++++++++ .../content/posts/post-with-images/index.md | 20 +++--- .../content/posts/usage/getting-started.md | 1 + .../data/properties/shortcode-avatar.yaml | 18 ++++++ .../data/properties/shortcode-images.yaml | 19 ++++++ .../data/properties/shortcode-includes.yaml | 19 ++++++ layouts/shortcodes/avatar.html | 57 ++++++++++++++++++ layouts/shortcodes/img.html | 51 +++++++--------- 12 files changed, 211 insertions(+), 53 deletions(-) rename exampleSite/content/about/images/{profile.jpg => avatar.jpg} (100%) create mode 100644 exampleSite/content/posts/avatar-images/images/avatar.jpg create mode 100644 exampleSite/content/posts/avatar-images/index.md create mode 100644 exampleSite/data/properties/shortcode-avatar.yaml create mode 100644 exampleSite/data/properties/shortcode-images.yaml create mode 100644 exampleSite/data/properties/shortcode-includes.yaml create mode 100644 layouts/shortcodes/avatar.html diff --git a/exampleSite/content/about/images/profile.jpg b/exampleSite/content/about/images/avatar.jpg similarity index 100% rename from exampleSite/content/about/images/profile.jpg rename to exampleSite/content/about/images/avatar.jpg diff --git a/exampleSite/content/about/index.md b/exampleSite/content/about/index.md index 301d20a..6ff0234 100644 --- a/exampleSite/content/about/index.md +++ b/exampleSite/content/about/index.md @@ -1,8 +1,8 @@ --- title: About Me resources: - - name: profile - src: "images/profile.jpg" + - name: avatar + src: "images/avatar.jpg" params: credits: "[Angelina Litvin](https://unsplash.com/@linalitvina) on [Unsplash](https://unsplash.com/s/photos/writing)" --- @@ -11,7 +11,7 @@ resources: {{< columns size=small >}} -{{< img name=profile lazy=false size=profile >}} +{{< avatar name=avatar size=tiny >}} <---> diff --git a/exampleSite/content/posts/advanced/includes.md b/exampleSite/content/posts/advanced/includes.md index fd05ea2..e77e0ab 100644 --- a/exampleSite/content/posts/advanced/includes.md +++ b/exampleSite/content/posts/advanced/includes.md @@ -14,6 +14,8 @@ Include shortcode can include files of different types. By specifying a language {{< toc >}} +## Usage + ```tpl {{}} @@ -22,16 +24,15 @@ Include shortcode can include files of different types. By specifying a language ## Attributes -| Name | Description | default | -| -------- | ----------------------------------------------------------------------------------------------------------------------------------- | -------------------------------- | -| file | path to the included file relative to the Hugo root | undefined | -| language | language for [syntax highlighting](https://gohugo.io/content-management/syntax-highlighting/#list-of-chroma-highlighting-languages) | undefined | -| type | special include type (`html,page`) | undefined (rendered as markdown) | -| options | highlighting [options](https://gohugo.io/content-management/syntax-highlighting/#highlight-shortcode) | `linenos=table` | + + +{{< propertylist name=shortcode-includes sort=name order=asc >}} + + -## Usage +## Examples -## Markdown file (default) +### Markdown files (default) If no other options are specified, files will be rendered as Markdown using the `RenderString` [function](https://gohugo.io/functions/renderstring/). @@ -51,7 +52,7 @@ If you include markdown files that should not get a menu entry, place them outsi -## Language files +### Language files This method can be used to include source code files and keep them automatically up to date. @@ -83,7 +84,7 @@ HTML content will be filtered by the `safeHTML` filter and added to the rendered ### Pages -In some situations, it can be helpful to include Markdown files that also contain shortcodes. While the [default method](#markdown-file-default) works fine to render plain Markdown, shortcodes are not parsed. The only way to get this to work is to use Hugo pages. There are several ways to structure these include pages, so whatever you do, keep in mind that Hugo needs to be able to render and serve these files as regular pages! How it works: +In some situations, it can be helpful to include Markdown files that also contain shortcodes. While the [default method](#markdown-files-default) works fine to render plain Markdown, shortcodes are not parsed. The only way to get this to work is to use Hugo pages. There are several ways to structure these include pages, so whatever you do, keep in mind that Hugo needs to be able to render and serve these files as regular pages! How it works: 1. First you need to create a directory **within** your content directory. For this example site `_includes` is used. 2. Place your Markdown files within the `_includes` folder e.g. `/_includes/include-page.md`. Make sure to name it `*.md`. diff --git a/exampleSite/content/posts/avatar-images/images/avatar.jpg b/exampleSite/content/posts/avatar-images/images/avatar.jpg new file mode 100644 index 0000000000000000000000000000000000000000..d0fc74740b1ef67fe3ae1da0221b6c1a978f9e67 GIT binary patch literal 73194 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 literal 0 HcmV?d00001 diff --git a/exampleSite/content/posts/avatar-images/index.md b/exampleSite/content/posts/avatar-images/index.md new file mode 100644 index 0000000..f270a9d --- /dev/null +++ b/exampleSite/content/posts/avatar-images/index.md @@ -0,0 +1,52 @@ +--- +title: Avatar Images +date: 2024-04-27T21:00:00+02:00 +authors: + - john-doe +tags: + - Documentation + - Shortcodes +resources: + - name: avatar + src: "images/avatar.jpg" + title: "Avatar" +--- + +The avatar shortcode is another custom image shortcode. + + + +## Usage + +Define a resource in the page front matter. + + + +```md +--- +resources: + - name: avatar + src: "images/avatar.jpg" + title: "Avatar" +--- + +{{}} +``` + + + +## Attributes + + + +{{< propertylist name=shortcode-avatar sort=name order=asc >}} + + + +## Example + + + +{{< avatar name=avatar size="small" >}} + + diff --git a/exampleSite/content/posts/post-with-images/index.md b/exampleSite/content/posts/post-with-images/index.md index 17d02a5..83fd6a9 100644 --- a/exampleSite/content/posts/post-with-images/index.md +++ b/exampleSite/content/posts/post-with-images/index.md @@ -1,5 +1,5 @@ --- -title: Post with images +title: Advanced Images date: 2020-06-22T20:00:00+02:00 authors: - john-doe @@ -58,16 +58,6 @@ If you need more flexibility for your embedded images, you could use the `img` s -## Attributes - -| Name | Description | default | -| ------ | -------------------------------------------------------------------------------- | ----------------- | -| name | name of the image resource defined in your front matter | empty | -| alt | description for displayed image | resource `.Title` | -| size | Thumbnail size (origin\|profile\|tiny\|small\|medium\|large) | empty | -| lazy | enable or disable image lazy loading | true | -| anchor | anchor to determine the placement of the crop box (only used for `profile` size) | smart | - ## Usage Define your resources in the page front matter, custom parameter `params.credits` is optional. @@ -89,6 +79,14 @@ resources: +## Attributes + + + +{{< propertylist name=shortcode-images sort=name order=asc >}} + + + ## Example diff --git a/exampleSite/content/posts/usage/getting-started.md b/exampleSite/content/posts/usage/getting-started.md index 39a51ea..28f0f79 100644 --- a/exampleSite/content/posts/usage/getting-started.md +++ b/exampleSite/content/posts/usage/getting-started.md @@ -269,6 +269,7 @@ There are a lot more things to discover. To get the most out of the Theme we hav - [Authors](/posts/features/authors/) - [Sticky Posts](/posts/features/sticky/) - [Shortcodes](/posts/advanced/shortcodes/) + - [Avatar Images](/posts/avatar-images/) - [Advanced Images](/posts/post-with-images/) - [Includes](/posts/advanced/includes/) - [Table of Content](/posts/advanced/toc/) diff --git a/exampleSite/data/properties/shortcode-avatar.yaml b/exampleSite/data/properties/shortcode-avatar.yaml new file mode 100644 index 0000000..1224783 --- /dev/null +++ b/exampleSite/data/properties/shortcode-avatar.yaml @@ -0,0 +1,18 @@ +--- +properties: + - name: name + type: string + description: Name of the image resource defined in page front matter. + required: true + - name: alt + type: string + description: Description text for the image. + required: false + - name: size + type: string + description: Thumbnail size. Supported values are `origin|tiny|small|medium|large`. + required: false + - name: anchor + type: string + description: "[Anchor](https://gohugo.io/content-management/image-processing/#anchor) to determine the placement of the crop box." + required: false diff --git a/exampleSite/data/properties/shortcode-images.yaml b/exampleSite/data/properties/shortcode-images.yaml new file mode 100644 index 0000000..a3d3f15 --- /dev/null +++ b/exampleSite/data/properties/shortcode-images.yaml @@ -0,0 +1,19 @@ +--- +properties: + - name: name + type: string + description: Name of the image resource defined in page front matter. + required: true + - name: alt + type: string + description: Description text for the image. + required: false + - name: size + type: string + description: Thumbnail size. Supported values are `origin|tiny|small|medium|large`. + required: false + - name: lazy + type: bool + description: Enable/disable lazy loading for the image. + required: false + defaultValue: true diff --git a/exampleSite/data/properties/shortcode-includes.yaml b/exampleSite/data/properties/shortcode-includes.yaml new file mode 100644 index 0000000..d5dc58d --- /dev/null +++ b/exampleSite/data/properties/shortcode-includes.yaml @@ -0,0 +1,19 @@ +--- +properties: + - name: file + type: string + description: Path of the file (relative to the Hugo root) to include. + required: true + - name: language + type: string + description: Language for [syntax highlighting](https://gohugo.io/content-management/syntax-highlighting/#list-of-chroma-highlighting-languages). + required: false + - name: type + type: string + description: Special include type. Supported values are `html|page`. If not set the included file is rendered as markdown. + required: false + - name: options + type: bool + description: highlighting [options](https://gohugo.io/content-management/syntax-highlighting/#highlight-shortcode). + required: false + defaultValue: linenos=table diff --git a/layouts/shortcodes/avatar.html b/layouts/shortcodes/avatar.html new file mode 100644 index 0000000..59f7d14 --- /dev/null +++ b/layouts/shortcodes/avatar.html @@ -0,0 +1,57 @@ +{{- $source := ($.Page.Resources.ByType "image").GetMatch (printf "%s" (.Get "name")) }} +{{- $customAlt := .Get "alt" }} +{{- $customSize := .Get "size" | lower }} +{{- $customAnchor := default "smart" (.Get "anchor") | title }} +{{- $data := newScratch }} + +{{- with $source }} + {{- $caption := default .Title $customAlt }} + {{- $isSVG := (eq .MediaType.SubType "svg") }} + {{- $origin := . -}} + + {{- if $isSVG }} + {{- $data.SetInMap "size" "tiny" "160" }} + {{- $data.SetInMap "size" "small" "300" }} + {{- $data.SetInMap "size" "medium" "600" }} + {{- $data.SetInMap "size" "large" "900" }} + {{- else }} + {{- $data.SetInMap "size" "tiny" (printf "160x160 %s" $customAnchor) }} + {{- $data.SetInMap "size" "small" (printf "300x300 %s" $customAnchor) }} + {{- $data.SetInMap "size" "medium" (printf "600x600 %s" $customAnchor) }} + {{- $data.SetInMap "size" "large" (printf "900x900 %s" $customAnchor) }} + {{- end -}} + + +{{- end }} diff --git a/layouts/shortcodes/img.html b/layouts/shortcodes/img.html index f6dcbd8..bacde12 100644 --- a/layouts/shortcodes/img.html +++ b/layouts/shortcodes/img.html @@ -1,71 +1,64 @@ {{- $source := ($.Page.Resources.ByType "image").GetMatch (printf "%s" (.Get "name")) }} {{- $customAlt := .Get "alt" }} {{- $customSize := .Get "size" | lower }} -{{- $customAnchor := default "smart" (.Get "anchor") | title }} {{- $lazyLoad := default (default true $.Site.Params.geekblogImageLazyLoading) (.Get "lazy") }} {{- $data := newScratch }} {{- with $source }} {{- $caption := default .Title $customAlt }} {{- $isSVG := (eq .MediaType.SubType "svg") }} + {{- $origin := . }} - {{- $origin := .Permalink }} {{- if $isSVG }} - {{- $data.SetInMap "size" "profile" "180" }} {{- $data.SetInMap "size" "tiny" "320" }} {{- $data.SetInMap "size" "small" "600" }} {{- $data.SetInMap "size" "medium" "1200" }} {{- $data.SetInMap "size" "large" "1800" }} {{- else }} - {{- $data.SetInMap "size" "profile" (.Fill (printf "180x180 %s" $customAnchor)).Permalink }} - {{- $data.SetInMap "size" "tiny" (.Resize "320x").Permalink }} - {{- $data.SetInMap "size" "small" (.Resize "600x").Permalink }} - {{- $data.SetInMap "size" "medium" (.Resize "1200x").Permalink }} - {{- $data.SetInMap "size" "large" (.Resize "1800x").Permalink }} - {{- end }} - + {{- $data.SetInMap "size" "tiny" "320x"}} + {{- $data.SetInMap "size" "small" "600x" }} + {{- $data.SetInMap "size" "medium" "1200x" }} + {{- $data.SetInMap "size" "large" "1800x" }} + {{- end -}}
-
+
{{- $size := $data.Get "size" }} {{- if not $isSVG }} + {{- if ne $customSize "origin" }} + {{- end }} {{- end }} {{ $caption }} - {{- if not (eq $customSize "profile") }} - {{- with $caption }} -
- {{ . }} - {{- with $source.Params.credits }} - {{ printf " (%s)" . | $.Page.RenderString }} - {{- end }} -
- {{- end }} + {{- with $caption }} +
+ {{ . }} + {{- with $source.Params.credits }} + {{ printf " (%s)" . | $.Page.RenderString }} + {{- end }} +
{{- end }}