mirror of
https://github.com/McShelby/hugo-theme-relearn.git
synced 2025-01-18 10:50:24 +00:00
highlight: add title parameter #616
This commit is contained in:
parent
beb284ee87
commit
df49cdd3ef
4 changed files with 64 additions and 25 deletions
|
@ -20,7 +20,9 @@ This document shows you what's new in the latest release. For a detailed list of
|
|||
|
||||
## 5.19.0 (0000-00-00) {#000}
|
||||
|
||||
- {{% badge style="info" icon="plus-circle" title=" " %}}New{{% /badge %}} The theme has added two new color variants `zen-light` and `zen-dark`.
|
||||
- {{% badge style="info" icon="plus-circle" title=" " %}}New{{% /badge %}} The [`highlight` shortcode]({{% relref "shortcodes/highlight" %}}) now accepts the new parameter `title`. This displays the code like a [single tab]({{% relref "shortcodes/tab" %}}). This is also available using codefences and makes it much easier to write nicer code samples.
|
||||
|
||||
- {{% badge style="info" icon="plus-circle" title=" " %}}New{{% /badge %}} The theme has added two new color variants `zen-light` and `zen-dark`. Check it out!
|
||||
|
||||
- {{% badge style="info" icon="plus-circle" title=" " %}}New{{% /badge %}} The theme now [dispatches the custom event]({{%relref "basics/customization/#javascript" %}}) `themeVariantLoaded` on the `document` when the variant is fully loaded either initially or by switching the variant manually with the variant selector.
|
||||
|
||||
|
|
|
@ -5,26 +5,25 @@ title = "Highlight"
|
|||
|
||||
The `highlight` shortcode renders your code with a syntax highlighter.
|
||||
|
||||
{{< highlight lineNos="true" type="py" wrap="true" >}}
|
||||
{{< highlight lineNos="true" type="py" wrap="true" title="python" >}}
|
||||
print("Hello World!")
|
||||
{{< /highlight >}}
|
||||
|
||||
## Usage
|
||||
|
||||
This shortcode is compatible with Hugo's [`highlight` shortcode](https://gohugo.io/content-management/syntax-highlighting/#highlight-shortcode) but offers some extensions.
|
||||
This shortcode is fully compatible with Hugo's [`highlight` shortcode](https://gohugo.io/content-management/syntax-highlighting/#highlight-shortcode) but **offers some extensions**.
|
||||
|
||||
You can call it interchangeably in the same way as Hugo's own shortcode using positional parameter or by simply using codefences.
|
||||
It is called interchangeably in the same way as Hugo's own shortcode providing positional parameter or by simply using codefences.
|
||||
|
||||
You are free to also call this shortcode from your own partials. In this case it somewhat resemble Hugo's [`highlight` function](https://gohugo.io/functions/highlight/) syntax if you call this shortcode as a partial using compatiblity syntax.
|
||||
You are free to also call this shortcode from your own partials. In this case it resembles Hugo's [`highlight` function](https://gohugo.io/functions/highlight/) syntax if you call this shortcode as a partial using compatiblity syntax.
|
||||
|
||||
While the examples are using shortcodes with named parameter it is recommended to use codefences instead. This is because more and more other software supports codefences (eg. GitHub) and so your markdown becomes more portable.
|
||||
|
||||
|
||||
{{< tabs groupid="shortcode-parameter">}}
|
||||
{{% tab title="codefence" %}}
|
||||
|
||||
````md
|
||||
```py { lineNos="true" wrap="true" }
|
||||
```py { lineNos="true" wrap="true" title="python" }
|
||||
print("Hello World!")
|
||||
```
|
||||
````
|
||||
|
@ -33,7 +32,7 @@ print("Hello World!")
|
|||
{{% tab title="shortcode" %}}
|
||||
|
||||
````go
|
||||
{{</* highlight lineNos="true" type="py" wrap="true" */>}}
|
||||
{{</* highlight lineNos="true" type="py" wrap="true" title="python" */>}}
|
||||
print("Hello World!")
|
||||
{{</* /highlight */>}}
|
||||
````
|
||||
|
@ -42,7 +41,7 @@ print("Hello World!")
|
|||
{{% tab title="shortcode (positional)" %}}
|
||||
|
||||
````go
|
||||
{{</* highlight py "lineNos=true,wrap=true" */>}}
|
||||
{{</* highlight py "lineNos=true,wrap=true,title=python" */>}}
|
||||
print("Hello World!")
|
||||
{{</* /highlight */>}}
|
||||
````
|
||||
|
@ -57,8 +56,8 @@ print("Hello World!")
|
|||
"lineNos" "true"
|
||||
"type" "py"
|
||||
"wrap" "true"
|
||||
"title" "python"
|
||||
)}}
|
||||
|
||||
````
|
||||
|
||||
{{% /tab %}}
|
||||
|
@ -68,10 +67,9 @@ print("Hello World!")
|
|||
{{ partial "shortcodes/highlight.html" (dict
|
||||
"page" .
|
||||
"content" "print(\"Hello World!\")"
|
||||
"options" "lineNos=true,wrap=true"
|
||||
"options" "lineNos=true,wrap=true,title=python"
|
||||
"type" "py"
|
||||
)}}
|
||||
|
||||
````
|
||||
|
||||
{{% /tab %}}
|
||||
|
@ -82,7 +80,8 @@ print("Hello World!")
|
|||
| Name | Default | Notes |
|
||||
|-----------------------|------------------|-------------|
|
||||
| **type** | _<empty>_ | The language of the code to highlight. Choose from one of the [supported languages](https://gohugo.io/content-management/syntax-highlighting/#list-of-chroma-highlighting-languages). Case-insensitive. |
|
||||
| **wrap** | see notes | _Extension_. When `true` the content may wrap on long lines otherwise it will be scrollable.<br><br>The default value can be set in your `config.toml` and overwritten via frontmatter. [See below](#configuration). |
|
||||
| **title** | _<empty>_ | **Extension**. Arbitrary title for code. This displays the code like a [single tab]({{% relref "shortcodes/tab" %}}). |
|
||||
| **wrap** | see notes | **Extension**. When `true` the content may wrap on long lines otherwise it will be scrollable.<br><br>The default value can be set in your `config.toml` and overwritten via frontmatter. [See below](#configuration). |
|
||||
| **options** | _<empty>_ | An optional, comma-separated list of zero or more [Hugo supported options](https://gohugo.io/functions/highlight/#options) as well as extension parameter from this table. |
|
||||
| _**<option>**_ | _<empty>_ | Any of [Hugo's supported options](https://gohugo.io/functions/highlight/#options). |
|
||||
| _**<content>**_ | _<empty>_ | Your code to highlight. |
|
||||
|
@ -135,24 +134,45 @@ highlightWrap = true
|
|||
|
||||
## Examples
|
||||
|
||||
### Line Numbers
|
||||
### Line Numbers with Starting Offset
|
||||
|
||||
As mentioned above, line numbers in a `table` layout will shift if code is wrapping, so better use `inline`. To make things easier for you, set `lineNumbersInTable = false` in your `config.toml` and add `lineNos = true` when calling the shortcode instead of the specific values `table` or `inline`.
|
||||
|
||||
````go
|
||||
{{</* highlight lineNos="true" type="py" */>}}
|
||||
# Quicksort Python One-liner
|
||||
lambda L: [] if L==[] else qsort([x for x in L[1:] if x< L[0]]) + L[0:1] + qsort([x for x in L[1:] if x>=L[0]])
|
||||
# Some more stuff
|
||||
{{</* highlight lineNos="true" lineNoStart="666" type="py" */>}}
|
||||
# the hardest part is to start writing code; here's a kickstart; just copy and paste this; it's free; the next lines will cost you serious credits
|
||||
print("Hello")
|
||||
print(" ")
|
||||
print("World")
|
||||
print("!")
|
||||
{{</* /highlight */>}}
|
||||
````
|
||||
|
||||
{{< highlight lineNos="true" type="py" >}}
|
||||
# Quicksort Python One-liner
|
||||
lambda L: [] if L==[] else qsort([x for x in L[1:] if x< L[0]]) + L[0:1] + qsort([x for x in L[1:] if x>=L[0]])
|
||||
# Some more stuff
|
||||
{{< highlight lineNos="true" lineNoStart="666" type="py" >}}
|
||||
# the hardest part is to start writing code; here's a kickstart; just copy and paste this; it's free; the next lines will cost you serious credits
|
||||
print("Hello")
|
||||
print(" ")
|
||||
print("World")
|
||||
print("!")
|
||||
{{< /highlight >}}
|
||||
|
||||
### Codefence with Title
|
||||
|
||||
|
||||
````markdown
|
||||
```py { title="python" }
|
||||
# a bit shorter
|
||||
print("Hello World!")
|
||||
```
|
||||
````
|
||||
|
||||
```py { title="python" }
|
||||
# a bit shorter
|
||||
print("Hello World!")
|
||||
```
|
||||
|
||||
|
||||
|
||||
### With Wrap
|
||||
|
||||
````go
|
||||
|
|
|
@ -26,6 +26,8 @@
|
|||
{{- end }}
|
||||
{{- else if eq $k "type" }}
|
||||
{{- $type = $v }}
|
||||
{{- else if eq $k "title" }}
|
||||
{{- $otherAttributes = $otherAttributes | merge (dict $k $v) }}
|
||||
{{- else if eq $k "wrap" }}
|
||||
{{- $otherAttributes = $otherAttributes | merge (dict $k $v) }}
|
||||
{{- else }}
|
||||
|
@ -35,7 +37,9 @@
|
|||
{{- $options = $options | merge $otherOptions }}
|
||||
{{- $otherOptions := dict }}
|
||||
{{- range $k, $v := $options }}
|
||||
{{- if eq $k "wrap" }}
|
||||
{{- if eq $k "title" }}
|
||||
{{- $otherAttributes = (dict $k $v) | merge $otherAttributes }}
|
||||
{{- else if eq $k "wrap" }}
|
||||
{{- $otherAttributes = (dict $k $v) | merge $otherAttributes }}
|
||||
{{- else }}
|
||||
{{- $otherOptions = (dict $k $v) | merge $otherOptions }}
|
||||
|
@ -48,6 +52,7 @@
|
|||
{{- $params = $params | append (printf "%s=%s" $k $v) }}
|
||||
{{- end }}
|
||||
{{- $params = delimit $params ", " }}
|
||||
{{- $title := "" }}
|
||||
{{- $wrap := true }}
|
||||
{{- if isset $page.Site.Params "highlightwrap" }}
|
||||
{{- $wrap = $page.Site.Params.highlightWrap }}
|
||||
|
@ -56,7 +61,9 @@
|
|||
{{- $wrap = $page.Params.highlightWrap }}
|
||||
{{- end }}
|
||||
{{- range $k, $v := $attributes }}
|
||||
{{- if eq $k "wrap" }}
|
||||
{{- if eq $k "title" }}
|
||||
{{- $title = $v }}
|
||||
{{- else if eq $k "wrap" }}
|
||||
{{- $wrap = $v }}
|
||||
{{- end }}
|
||||
{{- end }}
|
||||
|
@ -68,4 +75,12 @@
|
|||
{{- if $wrap }}
|
||||
{{- $content = replaceRE "^([\\s\\n\\r]*<div\\s+class=\")" "${1}wrap-code " $content 1 }}
|
||||
{{- end }}
|
||||
{{- $content | safeHTML }}
|
||||
{{- if $title }}
|
||||
{{ partial "shortcodes/tab.html" (dict
|
||||
"page" $page
|
||||
"title" $title
|
||||
"content" $content
|
||||
)}}
|
||||
{{- else }}
|
||||
{{- $content | safeHTML }}
|
||||
{{- end }}
|
|
@ -17,6 +17,8 @@
|
|||
{{- $options = $v }}
|
||||
{{- else if eq $k "type" }}
|
||||
{{- $type = $v }}
|
||||
{{- else if eq $k "title" }}
|
||||
{{- $attributes = $attributes | merge (dict $k $v) }}
|
||||
{{- else if eq $k "wrap" }}
|
||||
{{- $attributes = $attributes | merge (dict $k $v) }}
|
||||
{{- else }}
|
||||
|
|
Loading…
Reference in a new issue