From 25ba1159ad5cabfe79c80a40ead158c389a68bef Mon Sep 17 00:00:00 2001
From: Youssif Shaaban Alsager <ysh-alsager@hotmail.com>
Date: Wed, 24 Aug 2022 03:32:40 +0000
Subject: [PATCH] feat: Add internationalization (i18n) support (#182)
---
layouts/partials/textprocessing.html | 45 ++++++++++++++++++++++++++++++++++++++++-----
1 files changed, 40 insertions(+), 5 deletions(-)
diff --git a/layouts/partials/textprocessing.html b/layouts/partials/textprocessing.html
index 2312aa4..1cb2583 100644
--- a/layouts/partials/textprocessing.html
+++ b/layouts/partials/textprocessing.html
@@ -27,10 +27,8 @@
{{$inner := . | strings.TrimPrefix "![[" | strings.TrimSuffix "]]" }}
{{$split := split $inner "|"}}
{{$path := index $split 0 | relURL}}
- {{$reference := split $path "#"}}
- {{$title := index $reference 0}}
- {{$display := default $title (index $split 1)}}
- {{$img := printf "<img src=\"%s\" title=\"%s\">" $path $display}}
+ {{$width := index $split 1}}
+ {{$img := printf "<img src=\"%s\" width=\"%s\" />" $path (default "auto" $width)}}
{{$content = replace $content . $img}}
{{else}}
{{$inner := . | strings.TrimPrefix "[[" | strings.TrimSuffix "]]" }}
@@ -39,7 +37,7 @@
{{$reference := split $path "#"}}
{{$title := index $reference 0}}
{{$block := default "" (index $reference 1)}}
- {{$block = strings.TrimRight "/" (cond (eq $block "") $block (printf "#%s" $block))}}
+ {{$block = strings.TrimRight "/" (cond (eq $block "") $block (printf "#%s" $block)) | urlize | lower}}
{{$href := strings.TrimRight "/" ($page.GetPage $title).RelPermalink}}
{{$display := default $title (index $split 1)}}
{{if not $href}}
@@ -53,4 +51,41 @@
{{end}}
{{end}}
{{end}}
+
+{{/* Add jumpable anchors */}}
+{{ $content = $content | replaceRE "(<h[1-9] id=\"([^\"]+)\">)(.+)(</h[1-9]>)" `<a href="#${2}">${1}<span class="hanchor" ariaLabel="Anchor"># </span>${3}${4}</a>` }}
+
+{{/* Callouts */}}
+{{if $.Site.Data.config.enableCallouts}}
+ {{ $content = $content | replaceRE "<blockquote>" "<blockquote class=callout>" }}
+ {{ $blockquoteclasses := findRE `\[!.+\]` $content }}
+ {{ $blockquoteclasses1 := findRE "<blockquote.*?>(.|\n)*?</blockquote>" $content }}
+ {{ $blockquotetags := findRE `blockquote class=callout` $content }}
+ {{ $counter := 0 }}
+ {{ $counter1 := 0 }}
+ {{ $finder := index $blockquoteclasses1 $counter }}
+ {{range $blockquotetags}}
+ {{ $finder = index $blockquoteclasses1 $counter }}
+ {{ if (in $finder "[!") }}
+ {{ $inner := index $blockquoteclasses $counter1 }}
+ {{ if (in $finder "]-") }}
+ {{ $inner = $inner | replaceRE `\[!([a-zA-Z]+)\]` `callout-collapsible callout-collapsed ${1}`}}
+ {{ else if (in $finder "]+") }}
+ {{ $inner = $inner | replaceRE `\[!([a-zA-Z]+)\]` `callout-collapsible ${1}`}}
+ {{ else}}
+ {{ $inner = $inner | replaceRE `\[!([a-zA-Z]+)\]` `${1}` }}
+ {{ end }}
+ {{ $inner = printf "blockquote class=\"%s-callout\"" $inner | lower}}
+ {{ $content = replace $content . $inner 1}}
+ {{ $counter1 = add $counter1 1 }}
+ {{ else }}
+ {{ $inner := print "blockquote" }}
+ {{ $content = replace $content . $inner 1}}
+ {{ end }}
+ {{ $counter = add $counter 1 }}
+ {{end}}
+ {{ $content = $content | replaceRE `\[![a-zA-Z]+\][-\+]?` "" }}
+ {{ $content = $content | replaceRE "blockquote class=callout" "blockquote" }}
+{{end}}
+
{{ $content | safeHTML }}
--
Gitblit v1.10.0