feat: Add internationalization (i18n) support (#182)
This commit is contained in:
		
							parent
							
								
									e38eaa94d6
								
							
						
					
					
						commit
						25ba1159ad
					
				
					 19 changed files with 189 additions and 52 deletions
				
			
		| 
						 | 
				
			
			@ -1,18 +1,21 @@
 | 
			
		|||
<!-- set data/config yaml file based on website language -->
 | 
			
		||||
{{ $config := cond (eq $.Site.Language.Lang "en") "config" (printf "config.%s" $.Site.Language.Lang) }}
 | 
			
		||||
{{ $data := index $.Site.Data $config }}
 | 
			
		||||
<head>
 | 
			
		||||
  <!-- Meta tags -->
 | 
			
		||||
  <meta charset="UTF-8" />
 | 
			
		||||
  <meta
 | 
			
		||||
    name="description"
 | 
			
		||||
    content="{{if .IsHome}}{{$.Site.Data.config.description}}{{else}}{{.Summary}}{{end}}"
 | 
			
		||||
    content="{{if .IsHome}}{{$data.description | default $.Site.Data.config.description}}{{else}}{{.Summary}}{{end}}"
 | 
			
		||||
  />
 | 
			
		||||
  <title>
 | 
			
		||||
    {{ if .Title }}{{ .Title }}{{ else }}{{ $.Site.Data.config.page_title }}{{
 | 
			
		||||
    {{ if .Title }}{{ .Title }}{{ else }}{{ $data.page_title | default $.Site.Data.config.page_title }}{{
 | 
			
		||||
    end }}
 | 
			
		||||
  </title>
 | 
			
		||||
  <meta name="viewport" content="width=device-width, initial-scale=1" />
 | 
			
		||||
 | 
			
		||||
  <!-- HTML Favicon -->
 | 
			
		||||
  {{ $favicon := $.Site.Data.config.favicon | default (slice (dict "rel" "shortcut icon" "type" "image/png" "href" "icon.png")) }}
 | 
			
		||||
  {{ $favicon := $data.favicon  | default $.Site.Data.config.favicon | default (slice (dict "rel" "shortcut icon" "type" "image/png" "href" "icon.png")) }}
 | 
			
		||||
  {{ $type := (printf "%T" $favicon) }}
 | 
			
		||||
  {{ if eq $type "string" }}
 | 
			
		||||
  {{ $favicon | safeHTML }}
 | 
			
		||||
| 
						 | 
				
			
			@ -29,7 +32,7 @@
 | 
			
		|||
  {{$scss := . | resources.ToCSS (dict "outputStyle" "compressed") }}
 | 
			
		||||
  {{$css = $css | append $scss}}
 | 
			
		||||
  {{end}}
 | 
			
		||||
  {{if $.Site.Data.config.enableCallouts}}
 | 
			
		||||
  {{if $data.enableCallouts | default $.Site.Data.config.enableCallouts}}
 | 
			
		||||
    {{$scss := resources.Get "styles/_callouts.scss" | resources.ToCSS (dict "outputStyle" "compressed") }}
 | 
			
		||||
    {{$css = $css | append $scss}}
 | 
			
		||||
  {{end}}
 | 
			
		||||
| 
						 | 
				
			
			@ -55,17 +58,17 @@
 | 
			
		|||
  <script src="{{$popover.Permalink}}"></script>
 | 
			
		||||
 | 
			
		||||
  <!-- Optional scripts -->
 | 
			
		||||
  {{ if $.Site.Data.config.enableCodeBlockTitle }}
 | 
			
		||||
  {{ if $data.enableCodeBlockTitle | default $.Site.Data.config.enableCallouts }}
 | 
			
		||||
  {{ $codeTitle := resources.Get "js/code-title.js" | resources.Fingerprint "md5" | resources.Minify }}
 | 
			
		||||
  <script src="{{$codeTitle.Permalink}}"></script>
 | 
			
		||||
  {{end}}
 | 
			
		||||
 | 
			
		||||
  {{ if $.Site.Data.config.enableCodeBlockCopy }}
 | 
			
		||||
  {{ if $data.enableCodeBlockCopy | default $.Site.Data.config.enableCodeBlockCopy }}
 | 
			
		||||
  {{ $clipboard := resources.Get "js/clipboard.js" | resources.Fingerprint "md5" | resources.Minify }}
 | 
			
		||||
  <script src="{{$clipboard.Permalink}}"></script>
 | 
			
		||||
  {{ end }}
 | 
			
		||||
 | 
			
		||||
  {{ if $.Site.Data.config.enableCallouts }}
 | 
			
		||||
  {{ if $data.enableCallouts | default $.Site.Data.config.enableCallouts }}
 | 
			
		||||
  {{ $callouts := resources.Get "js/callouts.js" | resources.Fingerprint "md5" | resources.Minify }}
 | 
			
		||||
  <script src="{{$callouts.Permalink}}"></script>
 | 
			
		||||
  {{ end }}
 | 
			
		||||
| 
						 | 
				
			
			@ -101,27 +104,27 @@
 | 
			
		|||
      const pathWindow = window.location.pathname;
 | 
			
		||||
      const isHome = pathBase == pathWindow;
 | 
			
		||||
 | 
			
		||||
      {{if $.Site.Data.config.enableCodeBlockCopy -}}
 | 
			
		||||
      {{if $data.enableCodeBlockCopy | default $.Site.Data.config.enableCodeBlockCopy -}}
 | 
			
		||||
      addCopyButtons();
 | 
			
		||||
      {{ end }}
 | 
			
		||||
 | 
			
		||||
      {{if $.Site.Data.config.enableSPA -}}
 | 
			
		||||
      {{if $data.enableSPA | default $.Site.Data.config.enableSPA -}}
 | 
			
		||||
      addTitleToCodeBlocks();
 | 
			
		||||
      {{ end }}
 | 
			
		||||
 | 
			
		||||
      {{if $.Site.Data.config.enableCallouts -}}
 | 
			
		||||
      {{if $data.enableCallouts | default $.Site.Data.config.enableCallouts -}}
 | 
			
		||||
      addCollapsibleCallouts();
 | 
			
		||||
      {{ end }}
 | 
			
		||||
     
 | 
			
		||||
      {{if $.Site.Data.config.enableLinkPreview}}
 | 
			
		||||
      {{if $data.enableLinkPreview | default $.Site.Data.config.enableLinkPreview}}
 | 
			
		||||
      initPopover(
 | 
			
		||||
        {{strings.TrimRight "/" .Site.BaseURL }},
 | 
			
		||||
        {{$.Site.Data.config.enableContextualBacklinks}},
 | 
			
		||||
        {{$.Site.Data.config.enableLatex}}
 | 
			
		||||
        {{$data.enableContextualBacklinks | default $.Site.Data.config.enableContextualBacklinks}},
 | 
			
		||||
        {{$data.enableLatex | default $.Site.Data.config.enableLatex}}
 | 
			
		||||
      )
 | 
			
		||||
      {{end}}
 | 
			
		||||
 | 
			
		||||
      {{if $.Site.Data.config.enableFooter}}
 | 
			
		||||
      {{if $data.enableFooter | default $.Site.Data.config.enableFooter}}
 | 
			
		||||
      const footer = document.getElementById("footer")
 | 
			
		||||
      if (footer) {
 | 
			
		||||
        const container = document.getElementById("graph-container")
 | 
			
		||||
| 
						 | 
				
			
			@ -144,14 +147,14 @@
 | 
			
		|||
 | 
			
		||||
    const init = (doc = document) => {
 | 
			
		||||
      // NOTE: everything within this callback will be executed for initial page navigation. This is a good place to put JavaScript that only replaces DOM nodes.
 | 
			
		||||
      {{if $.Site.Data.config.enableCodeBlockCopy -}}
 | 
			
		||||
      {{if $data.enableCodeBlockCopy | default $.Site.Data.config.enableCodeBlockCopy -}}
 | 
			
		||||
      addCopyButtons();
 | 
			
		||||
      {{ end }}
 | 
			
		||||
 | 
			
		||||
      {{if $.Site.Data.config.enableCodeBlockTitle -}}
 | 
			
		||||
      {{if $data.enableCodeBlockTitle | default $.Site.Data.config.enableCodeBlockTitle -}}
 | 
			
		||||
      addTitleToCodeBlocks();
 | 
			
		||||
      {{- end -}}
 | 
			
		||||
      {{if $.Site.Data.config.enableLatex}}
 | 
			
		||||
      {{if $data.enableLatex | default $.Site.Data.config.enableLatex}}
 | 
			
		||||
      renderMathInElement(doc.body, {
 | 
			
		||||
        delimiters: [
 | 
			
		||||
          {left: '$$', right: '$$', display: true},
 | 
			
		||||
| 
						 | 
				
			
			@ -162,7 +165,7 @@
 | 
			
		|||
      {{end}}
 | 
			
		||||
    };
 | 
			
		||||
  </script>
 | 
			
		||||
  {{if $.Site.Data.config.enableSPA}}
 | 
			
		||||
  {{if $data.enableSPA | default $.Site.Data.config.enableSPA}}
 | 
			
		||||
  {{ $router := resources.Get "js/router.js" | resources.Fingerprint "md5" |
 | 
			
		||||
  resources.Minify }}
 | 
			
		||||
  <script type="module">
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue