2021-12-13 20:04:12 +00:00
{{- /*
Renders syntax-highlighted configuration data in JSON, TOML, and YAML formats.
2023-05-22 14:43:12 +00:00
@param {string} [config] The section of site.Data.docs.config to render.
@param {bool} [copy=true] If true, display a copy to clipboard button.
@param {string} [file] The file name to display above the rendered code.
@param {bool} [fm=false] If true, render the code as front matter.
@param {bool} [skipHeader=false] If false, omit top level key(s) when rendering a section of site.Data.docs.config.
2021-12-13 20:04:12 +00:00
@returns {template.HTML}
2023-05-22 14:43:12 +00:00
*/}}
2021-12-13 20:04:12 +00:00
2023-05-22 14:43:12 +00:00
{{- /* Initialize. */}}
{{- $config := "" }}
{{- $copy := true }}
{{- $file := "" }}
{{- $fm := false }}
{{- $skipHeader := false }}
2021-12-13 20:04:12 +00:00
2023-05-22 14:43:12 +00:00
{{- /* Get parameters. */}}
{{- $config = .Get "config" }}
{{- $file = .Get "file" }}
{{- if in (slice "false" false 0) (.Get "copy") }}
{{- $copy = false }}
{{- else if in (slice "true" true 1) (.Get "copy")}}
{{- $copy = true }}
{{- end }}
{{- if in (slice "false" false 0) (.Get "fm") }}
{{- $fm = false }}
{{- else if in (slice "true" true 1) (.Get "fm")}}
{{- $fm = true }}
{{- end }}
{{- if in (slice "false" false 0) (.Get "skipHeader") }}
{{- $skipHeader = false }}
{{- else if in (slice "true" true 1) (.Get "skipHeader")}}
{{- $skipHeader = true }}
{{- end }}
2021-12-13 20:04:12 +00:00
2023-05-22 14:43:12 +00:00
{{- /* Define constants. */}}
{{- $delimiters := dict "toml" "+++" "yaml" "---" }}
{{- $langs := slice "yaml" "toml" "json" }}
{{- $placeHolder := "#-hugo-placeholder-#" }}
2021-12-13 20:04:12 +00:00
2023-05-22 14:43:12 +00:00
{{- /* Render. */}}
{{- $code := "" }}
{{- with $config }}
2023-05-27 14:59:59 +00:00
{{- $file = $file | default "hugo" }}
2023-05-22 14:43:12 +00:00
{{- $sections := (split . ".") }}
{{- $configSection := index $.Site.Data.docs.config $sections }}
{{- $code = dict $sections $configSection }}
{{- if $skipHeader }}
{{- $code = $configSection }}
{{- end }}
{{- else }}
{{- $code = $.Inner }}
2021-12-13 20:04:12 +00:00
{{- end }}
< div class = "code relative" { { with $ file } } id = "{{ . | urlize }}" { { end } } >
2021-06-18 15:49:54 +00:00
< div class = "code-nav flex flex-nowrap items-stretch" >
2021-12-13 20:04:12 +00:00
{{- with $file }}
2021-06-18 15:49:54 +00:00
< div class = "san-serif f6 dib lh-solid pl2 pv2 mr2" >
2023-05-22 14:43:12 +00:00
{{ . }}{{ if not $fm }}.{{ end }}
2021-06-18 15:49:54 +00:00
< / div >
2023-05-22 14:43:12 +00:00
{{- end }}
2021-12-13 20:04:12 +00:00
{{- range $langs }}
< button data-toggle-tab = "{{ . }}" class = "tab-button {{ cond (eq . " yaml " ) " active " " " } } ba san-serif f6 dib lh-solid ph2 pv2 " >
2021-06-18 15:49:54 +00:00
{{ . }}
< / button >
2021-12-13 20:04:12 +00:00
{{- end }}
2021-06-18 15:49:54 +00:00
< / div >
< div class = "tab-content" >
2021-12-13 20:04:12 +00:00
{{- range $langs }}
< div data-pane = "{{ . }}" class = "code-copy-content nt3 tab-pane {{ cond (eq . " yaml " ) " active " " " } } " >
2023-05-22 14:43:12 +00:00
{{- $hCode := $code | transform.Remarshal . }}
{{- if and $fm (in (slice "toml" "yaml") .) }}
{{- $hCode = printf "%s\n%s\n%s" $placeHolder $hCode $placeHolder }}
{{- end }}
2021-12-13 20:04:12 +00:00
{{- $hCode = $hCode | replaceRE `\n+` "\n" }}
{{ highlight $hCode . "" | replaceRE $placeHolder (index $delimiters .) | safeHTML }}
2021-06-18 15:49:54 +00:00
< / div >
2021-12-13 20:04:12 +00:00
{{- if $copy }}
2021-06-18 15:49:54 +00:00
< button class = "needs-js copy copy-toggle bg-accent-color-dark f6 absolute top-0 right-0 lh-solid hover-bg-primary-color-dark bn white ph3 pv2" title = "Copy this code to your clipboard." data-clipboard-action = "copy" aria-label = "copy button" > < / button >
2023-05-22 14:43:12 +00:00
{{- /* Functionality located within filesaver.js The copy here is located in the css with .copy class so it can be replaced with JS on success */}}
{{- end }}
2021-12-13 20:04:12 +00:00
{{- end }}
2021-06-18 15:49:54 +00:00
< / div >
2019-12-15 09:35:09 +00:00
< / div >