From de2b6b9a1b95cb6af7eb421d9a4de054e7e41315 Mon Sep 17 00:00:00 2001
From: SafEight <43656822+SafEight@users.noreply.github.com>
Date: Sat, 19 Nov 2022 21:17:55 +0000
Subject: [PATCH] feat: Replace == with <mark> (#234)

---
 layouts/partials/textprocessing.html |   52 ++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 50 insertions(+), 2 deletions(-)

diff --git a/layouts/partials/textprocessing.html b/layouts/partials/textprocessing.html
index dfb0ff2..bd2cca5 100644
--- a/layouts/partials/textprocessing.html
+++ b/layouts/partials/textprocessing.html
@@ -3,9 +3,9 @@
 {{ $page := .Page }}
 
 {{/* Escape slashes for Latex to fix line breaks */}}
-{{$latex := findRE "\\$\\$([^\\$]+)\\$\\$" $content}}
+{{$latex := findRE "(?:\\${2}([^\\$]+)\\${2})|(?:\\$([^\\$]*)\\$)" $content}}
 {{range $latex}}
-  {{$fixed := replaceRE "\\\\(?: +|\\n)" "\\\\" .}}
+  {{$fixed := replaceRE "\\\\(?: +|\\n)" "\\\\ " .}}
   {{$content = replace $content . $fixed}}
 {{end}}
 
@@ -31,15 +31,23 @@
       {{$img := printf "<img src=\"%s\" width=\"%s\" />" $path (default "auto" $width)}}
       {{$content = replace $content . $img}}
     {{else}}
+      <!-- remove link delimiters -->
       {{$inner := . | strings.TrimPrefix "[[" | strings.TrimSuffix "]]" }}
+      <!-- split from alias -->
       {{$split := split $inner "|"}}
+      <!-- separate link path -->
       {{$path := index $split 0}}
       {{$reference := split $path "#"}}
+      <!-- path with heading link (i.e. $block) removed -->
       {{$title := index $reference 0}}
+      <!-- heading link -->
       {{$block := default "" (index $reference 1)}}
       {{$block = strings.TrimRight "/" (cond (eq $block "") $block (printf "#%s" $block)) | urlize | lower}}
       {{$href := strings.TrimRight "/" ($page.GetPage $title).RelPermalink}}
+      <!-- if alias given, use alias, else title -->
       {{$display := default $title (index $split 1)}}
+      <!-- ADDED LINE TO REMOVE SUBFOLDER FROM TITLE: -->
+      {{$display := index (last 1 (split $display "/")) 0}}
       {{if not $href}}
         {{$link := printf "<a class=\"internal-link broken\">%s</a>" $display}}
         {{$content = replace $content . $link}}
@@ -55,4 +63,44 @@
 {{/* 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}}
+
+{{/* Make ==text== into <mark>text</mark> */}}
+{{$mark := findRE "(?Us)==([^\\$]+)==" $content}}
+{{range $mark}}
+  {{$fixed := printf "<mark>%s</mark>" (replace . "==" "")}}
+  {{$content = replace $content . $fixed}}
+{{end}}
+
 {{ $content | safeHTML }}

--
Gitblit v1.10.0