mirror of
https://github.com/McShelby/hugo-theme-relearn.git
synced 2025-01-18 19:00:24 +00:00
tabs: unify parameter names #277
This commit is contained in:
parent
66d32c48b0
commit
ae666b2b77
3 changed files with 16 additions and 16 deletions
|
@ -5,7 +5,7 @@ title = "Tabbed views"
|
|||
|
||||
The `tabs` shortcode displays arbitrary content in unlimited number of tabs. This comes in handy eg. for providing code snippets for multiple languages or providing configuration in different formats.
|
||||
|
||||
{{< tabs groupId="tabs-example-language" >}}
|
||||
{{< tabs groupid="tabs-example-language" >}}
|
||||
{{% tab name="python" %}}
|
||||
|
||||
```python
|
||||
|
@ -26,7 +26,7 @@ echo "Hello World!"
|
|||
|
||||
While the examples are using shortcodes with named parameter you are free to also call this shortcode from your own partials.
|
||||
|
||||
{{< tabs groupId="shortcode-parameter">}}
|
||||
{{< tabs groupid="shortcode-parameter">}}
|
||||
{{% tab name="shortcode" %}}
|
||||
|
||||
````go
|
||||
|
@ -70,21 +70,21 @@ echo "Hello World!"
|
|||
|
||||
| Name | Default | Notes |
|
||||
|:----------------------|:-----------------|:------------|
|
||||
| **groupId** | `default` | Arbitrary name of the group the tab view belongs to.<br/><br/>Tab views with the same **groupId** sychronize their selected tab. This sychronization applies to the whole site! |
|
||||
| **groupid** | `default` | Arbitrary name of the group the tab view belongs to.<br/><br/>Tab views with the same **groupid** sychronize their selected tab. This sychronization applies to the whole site! |
|
||||
| _**<content>**_ | _<empty>_ | Arbitrary number of tabs defined with the `tab` sub-shortcode. |
|
||||
|
||||
{{% notice note %}}
|
||||
When using tab views with different content sets, make sure to use a common `groupId` for equal sets of tabs but distinct `groupId` for different sets.
|
||||
When using tab views with different content sets, make sure to use a common `groupid` for equal sets of tabs but distinct `groupid` for different sets.
|
||||
|
||||
The tab selection is restored automatically based on the `groupId` and if it cannot find a tab item because it came from the `'default'` group on a different page then the first tab is selected instead.
|
||||
The tab selection is restored automatically based on the `groupid` and if it cannot find a tab item because it came from the `'default'` group on a different page then the first tab is selected instead.
|
||||
{{% /notice %}}
|
||||
|
||||
## Examples
|
||||
|
||||
### Distinct `groupId`
|
||||
### Distinct `groupid`
|
||||
|
||||
````go
|
||||
{{</* tabs groupId="config" */>}}
|
||||
{{</* tabs groupid="config" */>}}
|
||||
{{%/* tab name="json" */%}}
|
||||
```json
|
||||
{
|
||||
|
@ -105,7 +105,7 @@ Hello = World
|
|||
{{</* /tabs */>}}
|
||||
````
|
||||
|
||||
{{< tabs groupId="tabs-example-config" >}}
|
||||
{{< tabs groupid="tabs-example-config" >}}
|
||||
{{% tab name="json" %}}
|
||||
```json
|
||||
{
|
||||
|
@ -125,12 +125,12 @@ Hello = World
|
|||
{{% /tab %}}
|
||||
{{< /tabs >}}
|
||||
|
||||
### Non-Distinct `groupId`
|
||||
### Non-Distinct `groupid`
|
||||
|
||||
See what happens to this tab view if you select **properties** tab from the previous example.
|
||||
|
||||
````go
|
||||
{{</* tabs groupId="config" */>}}
|
||||
{{</* tabs groupid="config" */>}}
|
||||
{{%/* tab name="json" */%}}
|
||||
```json
|
||||
{
|
||||
|
@ -146,7 +146,7 @@ See what happens to this tab view if you select **properties** tab from the prev
|
|||
{{</* /tabs */>}}
|
||||
````
|
||||
|
||||
{{< tabs groupId="tabs-example-config" >}}
|
||||
{{< tabs groupid="tabs-example-config" >}}
|
||||
{{% tab name="json" %}}
|
||||
```json
|
||||
{
|
||||
|
|
|
@ -1,21 +1,21 @@
|
|||
{{- $context := .context }}
|
||||
{{- $tabs := .tabs | default slice }}
|
||||
{{- $groupId := .groupId | default "default" }}
|
||||
{{- $groupid := .groupid | default "default" }}
|
||||
{{- with $context }}
|
||||
<div class="tab-panel">
|
||||
<div class="tab-nav">
|
||||
{{- range $idx, $tab := $tabs }}
|
||||
<button
|
||||
data-tab-item="{{ .name }}"
|
||||
data-tab-group="{{ $groupId }}"
|
||||
data-tab-group="{{ $groupid }}"
|
||||
class="tab-nav-button {{ cond (eq $idx 0) "active" ""}}"
|
||||
onclick="switchTab('{{ $groupId }}','{{ .name }}')"
|
||||
onclick="switchTab('{{ $groupid }}','{{ .name }}')"
|
||||
><span>{{ .name }}</span></button>
|
||||
{{- end }}
|
||||
</div>
|
||||
<div class="tab-content">
|
||||
{{- range $idx, $tab := $tabs }}
|
||||
<div data-tab-item="{{ .name }}" data-tab-group="{{ $groupId }}" class="tab-item {{ cond (eq $idx 0) "active" ""}}">
|
||||
<div data-tab-item="{{ .name }}" data-tab-group="{{ $groupid }}" class="tab-item {{ cond (eq $idx 0) "active" ""}}">
|
||||
{{ .content | safeHTML }}
|
||||
</div>
|
||||
{{- end }}
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
{{- partial "shortcodes/tabs.html" (dict
|
||||
"context" .
|
||||
"content" .Inner
|
||||
"groupId" (.Get "groupId")
|
||||
"groupid" ((.Get "groupid") | default (.Get "groupId"))
|
||||
"tabs" (.Scratch.Get "tabs")
|
||||
) }}
|
Loading…
Reference in a new issue