fix: Replacing "internal-link broken" with link to asset (#232)
This commit is contained in:
parent
2e152a5dfc
commit
5676d90d56
@ -14,6 +14,7 @@
|
|||||||
{{$codefences := $raw | findRE "\\x60[^\\x60\\n]+\\x60"}}
|
{{$codefences := $raw | findRE "\\x60[^\\x60\\n]+\\x60"}}
|
||||||
{{$codeblocks := $raw | findRE "\\x60{3}[^\\x60]+\\x60{3}"}}
|
{{$codeblocks := $raw | findRE "\\x60{3}[^\\x60]+\\x60{3}"}}
|
||||||
{{$code := union $codefences $codeblocks}}
|
{{$code := union $codefences $codeblocks}}
|
||||||
|
|
||||||
{{range $wikilinks}}
|
{{range $wikilinks}}
|
||||||
{{$cur := .}}
|
{{$cur := .}}
|
||||||
{{$incode := false}}
|
{{$incode := false}}
|
||||||
@ -22,41 +23,56 @@
|
|||||||
{{$incode = true}}
|
{{$incode = true}}
|
||||||
{{end}}
|
{{end}}
|
||||||
{{end}}
|
{{end}}
|
||||||
|
|
||||||
{{if not $incode}}
|
{{if not $incode}}
|
||||||
{{if (hasPrefix . "!")}}
|
|
||||||
{{$inner := . | strings.TrimPrefix "![[" | strings.TrimSuffix "]]" }}
|
|
||||||
{{$split := split $inner "|"}}
|
|
||||||
{{$path := index $split 0 | relURL}}
|
|
||||||
{{$width := index $split 1}}
|
|
||||||
{{$img := printf "<img src=\"%s\" width=\"%s\" />" $path (default "auto" $width)}}
|
|
||||||
{{$content = replace $content . $img}}
|
|
||||||
{{else}}
|
|
||||||
<!-- remove link delimiters -->
|
<!-- remove link delimiters -->
|
||||||
{{$inner := . | strings.TrimPrefix "[[" | strings.TrimSuffix "]]" }}
|
{{$inner := . | strings.TrimPrefix "!" | strings.TrimPrefix "[[" | strings.TrimSuffix "]]" }}
|
||||||
<!-- split from alias -->
|
<!-- split from alias -->
|
||||||
{{$split := split $inner "|"}}
|
{{$split := split $inner "|"}}
|
||||||
<!-- separate link path -->
|
<!-- separate link path -->
|
||||||
{{$path := index $split 0}}
|
{{$path := index $split 0}}
|
||||||
|
|
||||||
{{$reference := split $path "#"}}
|
{{$reference := split $path "#"}}
|
||||||
<!-- path with heading link (i.e. $block) removed -->
|
<!-- path with heading link removed -->
|
||||||
{{$title := index $reference 0}}
|
{{$title := index $reference 0}}
|
||||||
<!-- heading link -->
|
<!-- $display is hyperlink display text -->
|
||||||
|
<!-- use alias, else title -->
|
||||||
|
{{$display := default $title (index $split 1)}}
|
||||||
|
<!-- remove subfolder from title -->
|
||||||
|
{{$display := index (last 1 (split $display "/")) 0}}
|
||||||
|
|
||||||
|
{{$curpage := $page.GetPage $title}}
|
||||||
|
{{$relpath := relURL $path}}
|
||||||
|
|
||||||
|
<!-- If path to Hugo page -->
|
||||||
|
{{if not (eq $curpage.String "nopPage") }}
|
||||||
{{$block := default "" (index $reference 1)}}
|
{{$block := default "" (index $reference 1)}}
|
||||||
{{$block = strings.TrimRight "/" (cond (eq $block "") $block (printf "#%s" $block)) | urlize | lower}}
|
{{$block = strings.TrimRight "/" (cond (eq $block "") $block (printf "#%s" $block)) | urlize | lower}}
|
||||||
{{$href := strings.TrimRight "/" ($page.GetPage $title).RelPermalink}}
|
{{$href := strings.TrimRight "/" $curpage.RelPermalink}}
|
||||||
<!-- if alias given, use alias, else title -->
|
{{$link := printf "<a href=\"%s%s\" rel=\"noopener\" class=\"internal-link\" data-src=\"%s\">%s</a>" $href $block $href $display}}
|
||||||
{{$display := default $title (index $split 1)}}
|
{{$content = replace $content . $link}}
|
||||||
<!-- ADDED LINE TO REMOVE SUBFOLDER FROM TITLE: -->
|
<!-- If path to existing file -->
|
||||||
{{$display := index (last 1 (split $display "/")) 0}}
|
{{else if fileExists $relpath}}
|
||||||
{{if not $href}}
|
{{$splitpath := split $relpath "/"}}
|
||||||
{{$link := printf "<a class=\"internal-link broken\">%s</a>" $display}}
|
{{$dirname := first (sub (len $splitpath) 1) $splitpath | path.Join | urlize}}
|
||||||
|
{{$basename := index (last 1 $splitpath) 0}}
|
||||||
|
{{$href := printf "/%s/%s" $dirname $basename}}
|
||||||
|
<!-- Embedded? -->
|
||||||
|
{{if (hasPrefix . "!")}}
|
||||||
|
{{$width := index $split 1}}
|
||||||
|
{{$link := printf "<img src=\"%s\" width=\"%s\" />" $href (default "auto" $width)}}
|
||||||
{{$content = replace $content . $link}}
|
{{$content = replace $content . $link}}
|
||||||
{{else}}
|
{{else}}
|
||||||
{{$fullhref := printf "%s%s" $href $block }}
|
{{$link := printf "<a href=\"%s\" rel=\"noopener\" class=\"internal-link\">%s</a>" $href $display}}
|
||||||
{{$link := printf "<a href=\"%s\" rel=\"noopener\" class=\"internal-link\" data-src=\"%s\">%s</a>" $fullhref $href $display}}
|
|
||||||
{{$content = replace $content . $link}}
|
{{$content = replace $content . $link}}
|
||||||
{{end}}
|
{{end}}
|
||||||
|
<!-- Broken path -->
|
||||||
|
{{else}}
|
||||||
|
{{$link := printf "<a class=\"internal-link broken\">%s</a>" $display}}
|
||||||
|
{{$content = replace $content . $link}}
|
||||||
{{end}}
|
{{end}}
|
||||||
|
|
||||||
{{end}}
|
{{end}}
|
||||||
{{end}}
|
{{end}}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user