diff --git a/layouts/partials/shortcodes/link.html b/layouts/partials/shortcodes/link.html
index 465757dfdc..a4369078c3 100644
--- a/layouts/partials/shortcodes/link.html
+++ b/layouts/partials/shortcodes/link.html
@@ -7,45 +7,66 @@
{{- if strings.HasPrefix $url "HAHAHUGOSHORTCODE" }}
{{- warnf "%q: WARNING you must call the ref / relref shortcode with '%% %%' instead of '< >' to work correctly for the anchor target attribute" $page.File.Filename }}
{{- end }}
+{{- $attributes := dict }}
{{- $title := .title | default "" }}
{{- $title = trim $title " " }}
+{{- $attributes = $attributes | merge (dict "title" $title) }}
{{- $content := .content }}
{{- $target := .target | default "" }}
-{{- if and (eq (len $target) 0) (or (strings.HasPrefix $url "http://") (strings.HasPrefix $url "https://") ) }}
+{{- $u := urls.Parse $url }}
+{{- $href := $u.String }}
+{{- $path := $u.Path }}
+{{- if $u.IsAbs }}
{{- $target = "_blank" }}
{{- if isset $page.Site.Params "externallinktarget" }}
{{- $target = $page.Site.Params.externalLinkTarget }}
{{- end }}
-{{- else }}
- {{- $url = urls.Parse $url }}
- {{- if and $url.Path (not (path.Ext $url.Path)) }}
- {{- /* ignore old style links with given extension */}}
- {{- $found := false }}
- {{- $fragment := "" }}
- {{- with $url.Fragment }}
- {{- $fragment = printf "#%s" . }}
- {{- end }}
- {{- $path := printf "%s/" (strings.TrimPrefix "/" (strings.TrimSuffix "/" $url.Path)) }}
- {{- with $page.Page.GetPage (strings.TrimSuffix "/" $path | default "/") }}
- {{- $url = printf "%s%s" (partial "relLangPrettyUglyURL.hugo" (dict "to" .)) $fragment }}
- {{- $found = true }}
- {{- else }}
- {{- /* is it a link into another translation? */}}
+ {{- $attributes = $attributes | merge (dict "target" $target) }}
+{{- else if $path }}
+ {{- $linkPage := "" }}
+ {{- with or
+ ($page.Page.GetPage $path)
+ ($page.Page.Resources.Get $path)
+ (resources.Get $path)
+ }}
+ {{- $linkPage = . }}
+ {{- else }}
+ {{- /* is it a link into another translation? */}}
+ {{- if strings.HasPrefix $path "/" }}
{{- range $page.Sites }}
{{- $lang := .Language.Lang }}
- {{- $prefix := printf "%s/" $lang }}
- {{- if strings.HasPrefix $path $prefix }}
- {{- $path = strings.TrimPrefix $prefix $path | default "/" }}
- {{- with .GetPage (strings.TrimSuffix "/" $path | default "/") }}
- {{- $url = printf "%s%s" (partial "relLangPrettyUglyURL.hugo" (dict "to" .)) $fragment }}
- {{- $found = true }}
+ {{- $prefix := printf "/%s" $lang }}
+ {{- $suffix := strings.TrimPrefix $prefix $path | default "/" }}
+ {{- if and (strings.HasPrefix $path $prefix) (strings.HasPrefix $suffix "/") }}
+ {{- with or
+ (.GetPage $suffix)
+ (.Resources.Get $suffix)
+ (resources.Get $suffix)
+ }}
+ {{- $linkPage = . }}
+ {{- break }}
{{- end }}
{{- end }}
{{- end }}
{{- end }}
- {{- if not $found }}
- {{- warnf "%q: no page was found for link '%s'" $page.File.Filename $url.Path }}
- {{- end }}
{{- end }}
-{{- end -}}
-{{ $content | safeHTML }}
\ No newline at end of file
+ {{- with $linkPage }}
+ {{- $href = partial "relLangPrettyUglyURL.hugo" (dict "to" .) }}
+ {{- with $u.RawQuery }}
+ {{- $href = printf "%s?%s" $href . }}
+ {{- end }}
+ {{- with $u.Fragment }}
+ {{- $href = printf "%s#%s" $href . }}
+ {{- end }}
+ {{- else }}
+ {{- warnf "%q: no page was found for link '%s'" $page.File.Filename $u.Path }}
+ {{- end }}
+{{- end }}
+{{- $attributes = $attributes | merge (dict "href" $href) -}}
+{{ $content | safeHTML }}
\ No newline at end of file